1// Type definitions for dhtmlxGantt 6.3.0 2// Project: https://dhtmlx.com/docs/products/dhtmlxGantt 3 4type GanttCallback = (...args: any[]) => any; 5 6 7type GanttEventName = "onAfterAutoSchedule"|"onAfterBatchUpdate"|"onAfterLightbox"|"onAfterLinkAdd"|"onAfterLinkDelete"|"onAfterLinkUpdate"|"onAfterQuickInfo"|"onAfterRedo"|"onAfterSort"|"onAfterTaskAdd"|"onAfterTaskAutoSchedule"|"onAfterTaskDelete"|"onAfterTaskDrag"|"onAfterTaskMove"|"onAfterTaskUpdate"|"onAfterUndo"|"onAjaxError"|"onAutoScheduleCircularLink"|"onBeforeAutoSchedule"|"onBeforeBatchUpdate"|"onBeforeCollapse"|"onBeforeDataRender"|"onBeforeExpand"|"onBeforeGanttReady"|"onBeforeGanttRender"|"onBeforeLightbox"|"onBeforeLinkAdd"|"onBeforeLinkDelete"|"onBeforeLinkDisplay"|"onBeforeLinkUpdate"|"onBeforeMultiSelect"|"onBeforeParse"|"onBeforeRedo"|"onBeforeRedoStack"|"onBeforeRowDragEnd"|"onBeforeRowDragMove"|"onBeforeTaskAdd"|"onBeforeTaskAutoSchedule"|"onBeforeTaskChanged"|"onBeforeTaskDelete"|"onBeforeTaskDisplay"|"onBeforeTaskDrag"|"onBeforeTaskMove"|"onBeforeTaskMultiSelect"|"onBeforeTaskSelected"|"onBeforeTaskUpdate"|"onBeforeUndo"|"onBeforeUndoStack"|"onCircularLinkError"|"onClear"|"onCollapse"|"onColumnResize"|"onColumnResizeEnd"|"onColumnResizeStart"|"onContextMenu"|"onDataProcessorReady"|"onDataRender"|"onDestroy"|"onEmptyClick"|"onError"|"onExpand"|"onGanttLayoutReady"|"onGanttReady"|"onGanttRender"|"onGanttScroll"|"onGridHeaderClick"|"onGridResize"|"onGridResizeEnd"|"onGridResizeStart"|"onLightbox"|"onLightboxButton"|"onLightboxCancel"|"onLightboxChange"|"onLightboxDelete"|"onLightboxSave"|"onLinkClick"|"onLinkCreated"|"onLinkDblClick"|"onLinkIdChange"|"onLinkValidation"|"onLoadEnd"|"onLoadStart"|"onMouseMove"|"onMultiSelect"|"onOptionsLoad"|"onParse"|"onQuickInfo"|"onRowDragEnd"|"onRowDragStart"|"onScaleAdjusted"|"onScaleClick"|"onTaskClick"|"onTaskClosed"|"onTaskCreated"|"onTaskDblClick"|"onTaskDrag"|"onTaskIdChange"|"onTaskLoading"|"onTaskMultiSelect"|"onTaskOpened"|"onTaskRowClick"|"onTaskSelected"|"onTaskUnselected"|"onTemplatesReady"; 8 9 10interface GanttTemplates { 11 12 /** 13 * specifies the content of start date or end date columns in grid 14 * @param date the date which needs formatting 15 * @param task the task object 16 * @param column the name of the column that called the template 17 */ 18 date_grid(date: Date, task: any, column: string): string; 19 20 /** 21 * specifies the text of tooltips that are displayed when the user creates a new dependency link 22 * @param from the id of the source task 23 * @param from_start <i>true</i>, if the link is being dragged from the start of the source task, <i>false</i> - if <br> from the end of the task 24 * @param to the id of the target task( 'null' or 'undefined', if the target task isn't specified yet) 25 * @param to_start <i>true</i>, if the link is being dragged to the start of the target task, <i>false</i> - if <br> to the end of the task 26 */ 27 drag_link(from: string|number, from_start: boolean, to: string|number, to_start: boolean): string; 28 29 /** 30 * specifies the CSS class that will be applied to the pop-up that appears when a user drags a link 31 * @param from the id of the source task 32 * @param from_start <i>true</i>, if the link is being dragged from the start of the source task, <i>false</i> - if <br> from the end of the task 33 * @param to the id of the target task( 'null' or 'undefined', if the target task isn't specified yet) 34 * @param to_start <i>true</i>, if the link is being dragged to the start of the target task, <i>false</i> - if <br> to the end of the task 35 */ 36 drag_link_class(from: string|number, from_start: boolean, to: string|number, to_start: boolean): string; 37 38 /** 39 * Ņonverts a date object to a date string. Used to send data back to the server 40 * @param date the date which needs formatting 41 */ 42 format_date(date: Date): string; 43 44 /** 45 * specifies the custom content inserted before the labels of child items in the tree column 46 * @param task the task object 47 */ 48 grid_blank(task: any): string; 49 50 /** 51 * specifies the format of dates in the "Start time" column 52 * @param date the date which needs formatting 53 * @param column the name of the column that called the template 54 */ 55 grid_date_format(date: Date, column: string): string; 56 57 /** 58 * specifies the icon of child items in the tree column 59 * @param task the task object 60 */ 61 grid_file(task: any): string; 62 63 /** 64 * specifies the icon of parent items in the tree column 65 * @param task the task object 66 */ 67 grid_folder(task: any): string; 68 69 /** 70 * specifies the CSS class that will be applied to the headers of the table's columns 71 * @param columnName the column's name (as specified in the "name" property of the column object) 72 * @param column column object (as specified in the <i>gantt.config.columns</i> config) 73 */ 74 grid_header_class(columnName: string, column: any): string; 75 76 /** 77 * specifies the indent of the child items in a branch (in the tree column) 78 * @param task the task object 79 */ 80 grid_indent(task: any): string; 81 82 /** 83 * specifies the icon of the open/close sign in the tree column 84 * @param task the task object 85 */ 86 grid_open(task: any): string; 87 88 /** 89 * specifies the CSS class that will be applied to a grid row 90 * @param start the date when a task is scheduled to begin 91 * @param end the date when a task is scheduled to be completed 92 * @param task the task object 93 */ 94 grid_row_class(start: Date, end: Date, task: any): string; 95 96 /** 97 * defines the height of the filled area in the resourceHistogram 98 * @param start_date start date of the scale cell 99 * @param end_date end date of the scale cell 100 * @param resource the resource object 101 * @param tasks tasks that are assigned to the specified resource and overlap start/end dates of the cell 102 */ 103 histogram_cell_allocated(start_date: Date, end_date: Date, resource: any, tasks: any[]): void; 104 105 /** 106 * specifies the height of the line that defines the available capacity of the resource 107 * @param start_date start date of the scale cell 108 * @param end_date end date of the scale cell 109 * @param resource the resource object 110 * @param tasks tasks that are assigned to the specified resource and overlap start/end dates of the cell 111 */ 112 histogram_cell_capacity(start_date: Date, end_date: Date, resource: any, tasks: any[]): void; 113 114 /** 115 * defines the CSS class which is applied to a cell of the resource panel 116 * @param start_date start date of the scale cell 117 * @param end_date end date of the scale cell 118 * @param resource the resource object 119 * @param tasks tasks that are assigned to the specified resource and overlap start/end dates of the cell 120 */ 121 histogram_cell_class(start_date: Date, end_date: Date, resource: any, tasks: any[]): void; 122 123 /** 124 * defines the label inside a cell 125 * @param start_date start date of the scale cell 126 * @param end_date end date of the scale cell 127 * @param resource the resource object 128 * @param tasks tasks that are assigned to the specified resource and overlap start/end dates of the cell 129 */ 130 histogram_cell_label(start_date: Date, end_date: Date, resource: any, tasks: any[]): void; 131 132 /** 133 * specifies the CSS class that will be applied to a link 134 * @param link the link object 135 */ 136 link_class(link: any): string; 137 138 /** 139 * specifies the text in the header of the link's "delete" confirm window 140 * @param link the link object 141 */ 142 link_description(link: any): string; 143 144 /** 145 * converts date string into a Date object 146 * @param date the string which need to be parsed 147 */ 148 parse_date(date: string): Date; 149 150 /** 151 * specifies the text in the completed part of the task bar 152 * @param start the date when a task is scheduled to begin 153 * @param end the date when a task is scheduled to be completed 154 * @param task the task object 155 */ 156 progress_text(start: Date, end: Date, task: any): string; 157 158 /** 159 * specifies the CSS class that will be applied to the pop-up edit form 160 * @param start the date when a task is scheduled to begin 161 * @param end the date when a task is scheduled to be completed 162 * @param task the task object 163 */ 164 quick_info_class(start: Date, end: Date, task: any): void; 165 166 /** 167 * specifies the content of the pop-up edit form 168 * @param start the date when a task is scheduled to begin 169 * @param end the date when a task is scheduled to be completed 170 * @param task the task object 171 */ 172 quick_info_content(start: Date, end: Date, task: any): string; 173 174 /** 175 * specifies the date of the pop-up edit form 176 * @param start the date when a task is scheduled to begin 177 * @param end the date when a task is scheduled to be completed 178 * @param task the task object 179 */ 180 quick_info_date(start: Date, end: Date, task: any): string; 181 182 /** 183 * specifies the title of the pop-up edit form 184 * @param start the date when a task is scheduled to begin 185 * @param end the date when a task is scheduled to be completed 186 * @param task the task object 187 */ 188 quick_info_title(start: Date, end: Date, task: any): string; 189 190 /** 191 * defines the CSS class names of cells in the resource timeline cells 192 * @param start_date start date of the scale cell 193 * @param end_date end date of the scale cell 194 * @param resource the resource object 195 * @param tasks tasks that are assigned to specified resource and overlap start/end dates of the cell 196 */ 197 resource_cell_class(start_date: Date, end_date: Date, resource: any, tasks: any[]): string; 198 199 /** 200 * defines the HTML content of resource timeline cells 201 * @param start_date start date of the scale cell 202 * @param end_date end date of the scale cell 203 * @param resource the resource object 204 * @param tasks tasks that are assigned to specified resource and overlap start/end dates of the cell 205 */ 206 resource_cell_value(start_date: Date, end_date: Date, resource: any, tasks: any[]): string; 207 208 /** 209 * specifies the CSS class that will be applied to cells of the time scale of the timeline area 210 * @param date the date of a cell 211 */ 212 scale_cell_class(date: Date): string; 213 214 /** 215 * specifies the CSS class that will be applied to the time scale 216 * @param scale the scale's configuration object 217 */ 218 scale_row_class(scale: any): string; 219 220 /** 221 * specifies the CSS class that will be applied to task bars 222 * @param start the date when a task is scheduled to begin 223 * @param end the date when a task is scheduled to be completed 224 * @param task the task object 225 */ 226 task_class(start: Date, end: Date, task: any): string; 227 228 /** 229 * specifies the date format of the label in the 'Time period' section of the lightbox 230 * @param date the date which needs formatting 231 */ 232 task_date(date: Date): string; 233 234 /** 235 * specifies the format for the end dates of tasks in the lightbox 236 * @param date the date which needs formatting 237 */ 238 task_end_date(date: Date): string; 239 240 /** 241 * specifies the CSS class that will be applied to the row of the timeline area 242 * @param start the date when a task is scheduled to begin 243 * @param end the date when a task is scheduled to be completed 244 * @param task the task object 245 */ 246 task_row_class(start: Date, end: Date, task: any): string; 247 248 /** 249 * specifies the text in the task bars and the header of the lightbox 250 * @param start the date when a task is scheduled to begin 251 * @param end the date when a task is scheduled to be completed 252 * @param task the task object 253 */ 254 task_text(start: Date, end: Date, task: any): string; 255 256 /** 257 * specifies the date period in the header of the lightbox 258 * @param start the date when a task is scheduled to begin 259 * @param end the date when a task is scheduled to be completed 260 * @param task the task object 261 */ 262 task_time(start: Date, end: Date, task: any): string; 263 264 /** 265 * specifies the dates of unscheduled tasks 266 * @param task the task object 267 */ 268 task_unscheduled_time(task: any): void; 269 270 /** 271 * specifies the format of the drop-down time selector in the lightbox 272 * @param date the date which needs formatting 273 */ 274 time_picker(date: Date): string; 275 276 /** 277 * specifies the CSS class that will be applied to the cells of the timeline area 278 * @param item the task object assigned to the row 279 * @param date the date of a cell 280 */ 281 timeline_cell_class(item: any, date: Date): string; 282 283 /** 284 * specifies the format of start and end dates displayed in the tooltip 285 * @param date the date which needs formatting 286 */ 287 tooltip_date_format(date: Date): string; 288 289 /** 290 * specifies the text of tooltips 291 * @param start the date when a task is scheduled to begin 292 * @param end the date when a task is scheduled to be completed 293 * @param task the task object 294 */ 295 tooltip_text(start: Date, end: Date, task: any): string; 296 297 /** 298 * a string from an XML file is converted into a date object in conformity with this template 299 * @param date the date which needs formatting 300 */ 301 xml_date(date: Date): string; 302 303 /** 304 * a date object is converted into a string in conformity with this template. Used to send data back to the server 305 * @param date the date which needs formatting 306 */ 307 xml_format(date: Date): string; 308 309 /** 310 * specifies the text assigned to tasks bars on the right side 311 * @param start the date when a task is scheduled to begin 312 * @param end the date when a task is scheduled to be completed 313 * @param task the task object 314 */ 315 rightside_text(start: Date, end: Date, task: any): string; 316 317 /** 318 * specifies the text assigned to tasks bars on the left side 319 * @param start the date when a task is scheduled to begin 320 * @param end the date when a task is scheduled to be completed 321 * @param task the task object 322 */ 323 leftside_text(start: Date, end: Date, task: any): string; 324 325 /** 326 * specifies the lightbox's header 327 * @param start_date the date when a task is scheduled to begin 328 * @param end_date the date when a task is scheduled to be completed 329 * @param task the task's object 330 */ 331 lightbox_header(start_date: Date, end_date: Date, task: any): string; 332} 333 334interface GanttConfigOptions { 335 336 /** 337 * enables auto scheduling 338 */ 339 auto_scheduling: boolean; 340 341 /** 342 * disables usage of time contraints for tasks 343 */ 344 auto_scheduling_compatibility: boolean; 345 346 /** 347 * allows or forbids creating links from parent tasks (projects) to their children 348 */ 349 auto_scheduling_descendant_links: boolean; 350 351 /** 352 * defines whether gantt will do autoscheduling on data loading/parsing 353 */ 354 auto_scheduling_initial: boolean; 355 356 /** 357 * defines whether the whole project will be moved (see the details below) 358 */ 359 auto_scheduling_move_projects: boolean; 360 361 /** 362 * enables the auto scheduling mode, in which tasks will always be rescheduled to the earliest possible date 363 */ 364 auto_scheduling_strict: boolean; 365 366 /** 367 * automatically converts tasks with subtasks to projects and projects without subtasks back to tasks 368 */ 369 auto_types: boolean; 370 371 /** 372 * enables automatic adjusting of the grid's columns to the grid's width 373 */ 374 autofit: boolean; 375 376 /** 377 * enables autoscrolling while dragging a task or link out of the current browser screen 378 */ 379 autoscroll: boolean; 380 381 /** 382 * defines the speed of autoscrolling (in ms) while dragging a task or link out of the current browser screen 383 */ 384 autoscroll_speed: number; 385 386 /** 387 * forces the Gantt chart to automatically change its size to show all tasks without scrolling 388 */ 389 autosize: boolean|string; 390 391 /** 392 * sets the minimum width (in pixels) that the Gantt chart can take in the horizontal 'autosize' mode 393 */ 394 autosize_min_width: number; 395 396 /** 397 * enables dynamic loading in the Gantt chart 398 */ 399 branch_loading: boolean; 400 401 /** 402 * specifies that the task has children that are not yet loaded from the backend 403 */ 404 branch_loading_property: string; 405 406 /** 407 * stores a collection of buttons resided in the left bottom corner of the lightbox 408 */ 409 buttons_left: any[]; 410 411 /** 412 * stores a collection of buttons resided in the right bottom corner of the lightbox 413 */ 414 buttons_right: any[]; 415 416 /** 417 * changes the name of the property that affects binding of a calendar to a task/group of tasks 418 */ 419 calendar_property: string; 420 421 /** 422 * enables cascade deleting of nested tasks and links 423 */ 424 cascade_delete: boolean; 425 426 /** 427 * enables advanced drag-n-drop 428 */ 429 click_drag: any; 430 431 /** 432 * configures the columns of the table 433 */ 434 columns: any[]; 435 436 /** 437 * contains all available constraint types 438 */ 439 constraint_types: any; 440 441 /** 442 * enables adjusting the task's start and end dates to the work time (while dragging) 443 */ 444 correct_work_time: boolean; 445 446 /** 447 * sets the date format that is used to parse data from a data set and to send dates back to the server 448 */ 449 date_format: string; 450 451 /** 452 * sets the format of dates in the "Start time" column of the table 453 */ 454 date_grid: string; 455 456 /** 457 * sets the format of the time scale (X-Axis) 458 */ 459 date_scale: string; 460 461 /** 462 * 'says' to open the lightbox while creating new events by clicking the '+' button 463 */ 464 details_on_create: boolean; 465 466 /** 467 * 'says' to open the lightbox after double clicking on a task 468 */ 469 details_on_dblclick: boolean; 470 471 /** 472 * enables the possibility to drag the lightbox by the header 473 */ 474 drag_lightbox: boolean; 475 476 /** 477 * enables creating dependency links by drag-and-drop 478 */ 479 drag_links: boolean; 480 481 /** 482 * stores the types of available drag-and-drop modes 483 */ 484 drag_mode: any; 485 486 /** 487 * enables the possibility to move tasks by drag-and-drop 488 */ 489 drag_move: boolean; 490 491 /** 492 * enables the possibility to drag several selected tasks at once 493 */ 494 drag_multiple: boolean; 495 496 /** 497 * enables the possibility to change the task progress by dragging the progress knob 498 */ 499 drag_progress: boolean; 500 501 /** 502 * enables drag and drop of items of the project type 503 */ 504 drag_project: boolean; 505 506 /** 507 * enables the possibility to resize tasks by drag-and-drop 508 */ 509 drag_resize: boolean; 510 511 /** 512 * configures the behavior of the dhtmlxgantt_drag_timeline extension 513 */ 514 drag_timeline: any; 515 516 /** 517 * sets the number of 'gantt.config.duration_unit' units that will correspond to one unit of the 'duration' data property. 518 */ 519 duration_step: number; 520 521 /** 522 * sets the duration unit 523 */ 524 duration_unit: string; 525 526 /** 527 * changes the name of a property that affects the editing ability of tasks/links in the read-only Gantt chart 528 */ 529 editable_property: string; 530 531 /** 532 * an object that contains definitions of inline editors 533 */ 534 editor_types: any; 535 536 /** 537 * sets the end value of the time scale 538 */ 539 end_date: Date; 540 541 /** 542 * 'says' the Gantt chart to automatically extend the time scale in order to fit all displayed tasks 543 */ 544 fit_tasks: boolean; 545 546 /** 547 * makes the grid resizable by dragging the right grid's border 548 */ 549 grid_resize: boolean; 550 551 /** 552 * sets the name of the attribute of the grid resizer's DOM element 553 */ 554 grid_resizer_attribute: string; 555 556 /** 557 * sets the name of the attribute of the column resizer's DOM element. The attribute presents the column's index 558 */ 559 grid_resizer_column_attribute: string; 560 561 /** 562 * sets the width of the grid 563 */ 564 grid_width: number; 565 566 /** 567 * shows the critical path in the chart 568 */ 569 highlight_critical_path: boolean; 570 571 /** 572 * enables/disables horizontal scroll by the Shift|Alt|Meta key + mouse wheel movement 573 */ 574 horizontal_scroll_key: string|boolean; 575 576 /** 577 * defines whether tasks should inherit work calendars from their summary parents 578 */ 579 inherit_calendar: boolean; 580 581 /** 582 * specifies whether sub-scales shall use the scale_cell_class template by default 583 */ 584 inherit_scale_class: boolean; 585 586 /** 587 * sets whether the timeline area will be initially scrolled to display the earliest task 588 */ 589 initial_scroll: boolean; 590 591 /** 592 * keeps the duration of a task unchanged during editing of the start/end of a task 593 */ 594 inline_editors_date_processing: string; 595 596 /** 597 * 'says' to preserve the initial grid's width while resizing columns within 598 */ 599 keep_grid_width: boolean; 600 601 /** 602 * enables keyboard navigation in gantt 603 */ 604 keyboard_navigation: boolean; 605 606 /** 607 * enables keyboard navigation by cells 608 */ 609 keyboard_navigation_cells: boolean; 610 611 /** 612 * sets the name of the attribute of the task layer's DOM element 613 */ 614 layer_attribute: string; 615 616 /** 617 * specifies the layout object 618 */ 619 layout: any; 620 621 /** 622 * specifies the lightbox object 623 */ 624 lightbox: any; 625 626 /** 627 * increases the height of the lightbox 628 */ 629 lightbox_additional_height: number; 630 631 /** 632 * sets the size of the link arrow 633 */ 634 link_arrow_size: number; 635 636 /** 637 * sets the name of the attribute that will specify the id of the link's HTML element 638 */ 639 link_attribute: string; 640 641 /** 642 * sets the width of dependency links in the timeline area 643 */ 644 link_line_width: number; 645 646 /** 647 * sets the width of the area (over the link) sensitive to clicks 648 */ 649 link_wrapper_width: number; 650 651 /** 652 * stores the types of links dependencies 653 */ 654 links: any; 655 656 /** 657 * sets the minimum width for a column in the timeline area 658 */ 659 min_column_width: number; 660 661 /** 662 * Sets the minimum duration (in milliseconds) that can be set for a task during resizing. 663 */ 664 min_duration: number; 665 666 /** 667 * sets the minumum width for the grid (in pixels) while being resized 668 */ 669 min_grid_column_width: number; 670 671 /** 672 * enables/disables multi-task selection in the Gantt chart 673 */ 674 multiselect: boolean; 675 676 /** 677 * specifies whether multi-task selection will be available within one or any level 678 */ 679 multiselect_one_level: boolean; 680 681 /** 682 * enables the possibility to expand/collapse split tasks by clicking the +/- button 683 */ 684 open_split_tasks: boolean; 685 686 /** 687 * openes all branches initially 688 */ 689 open_tree_initially: boolean; 690 691 /** 692 * activates the 'branch' mode that allows vertically reordering tasks within the same tree level 693 */ 694 order_branch: string|boolean; 695 696 /** 697 * activates the 'branch' mode that allows reordering tasks within the whole gantt 698 */ 699 order_branch_free: boolean; 700 701 /** 702 * adds an empty row into the end of the list of tasks to simplify tasks editing via keyboard 703 */ 704 placeholder_task: boolean; 705 706 /** 707 * preserves the current position of the vertical and horizontal scrolls while re-drawing the gantt chart 708 */ 709 preserve_scroll: boolean; 710 711 /** 712 * specifies whether the gantt container should block the mousewheel event, or should it be propagated up to the window element 713 */ 714 prevent_default_scroll: boolean; 715 716 /** 717 * specifies the end date of a project 718 */ 719 project_end: Date; 720 721 /** 722 * specifies the start date of a project 723 */ 724 project_start: Date; 725 726 /** 727 * defines whether the task form will appear from the left/right side of the screen or near the selected task 728 */ 729 quick_info_detached: boolean; 730 731 /** 732 * stores a collection of buttons resided in the pop-up task's details form 733 */ 734 quickinfo_buttons: any[]; 735 736 /** 737 * activates the read-only mode for the Gantt chart 738 */ 739 readonly: boolean; 740 741 /** 742 * changes the name of a property that affects the read-only behaviour of tasks/links 743 */ 744 readonly_property: string; 745 746 /** 747 * enables the Redo functionality for the gantt 748 */ 749 redo: boolean; 750 751 /** 752 * defines a set of working calendars that can be assigned to a specific resource, e.g. a user 753 */ 754 resource_calendars: any; 755 756 /** 757 * defines the property of a task object that stores a resource id associated with resourceGrid/Timeline/Histogram 758 */ 759 resource_property: string; 760 761 /** 762 * tells the resource timeline to render elements and call templates for non-allocated cells 763 */ 764 resource_render_empty_cells: boolean; 765 766 /** 767 * specifies the name of the dataStore connected to the resourceGrid/resourceTimeline/resourceHistogram views 768 */ 769 resource_store: string; 770 771 /** 772 * sets the id of the virtual root element 773 */ 774 root_id: string|number; 775 776 /** 777 * enables rounding the task's start and end dates to the nearest scale marks 778 */ 779 round_dnd_dates: boolean; 780 781 /** 782 * sets the default height for rows of the table 783 */ 784 row_height: number; 785 786 /** 787 * switches gantt to the right-to-left mode 788 */ 789 rtl: boolean; 790 791 /** 792 * sets the height of the time scale and the header of the grid 793 */ 794 scale_height: number; 795 796 /** 797 * sets the minimal scale unit (in case multiple scales are used) as the interval of the leading/closing empty space 798 */ 799 scale_offset_minimal: boolean; 800 801 /** 802 * sets the unit of the time scale (X-Axis) 803 */ 804 scale_unit: string; 805 806 /** 807 * defines configuration settings of the time scale 808 */ 809 scales: any[]; 810 811 /** 812 * enables backward scheduling 813 */ 814 schedule_from_end: boolean; 815 816 /** 817 * specifies whether the timeline area shall be scrolled while selecting to display the selected task 818 */ 819 scroll_on_click: boolean; 820 821 /** 822 * set the sizes of the vertical (width) and horizontal (height) scrolls 823 */ 824 scroll_size: number; 825 826 /** 827 * enables selection of tasks in the Gantt chart 828 */ 829 select_task: boolean; 830 831 /** 832 * enables converting server-side dates from UTC to a local time zone (and backward) while sending data to the server 833 */ 834 server_utc: boolean; 835 836 /** 837 * shows the chart (timeline) area of the Gantt chart 838 */ 839 show_chart: boolean; 840 841 /** 842 * enables showing error alerts in case of unexpected behavior 843 */ 844 show_errors: boolean; 845 846 /** 847 * shows the grid area of the Gantt chart 848 */ 849 show_grid: boolean; 850 851 /** 852 * enables/disables displaying links in the Gantt chart 853 */ 854 show_links: boolean; 855 856 /** 857 * shows/hides markers on the page 858 */ 859 show_markers: boolean; 860 861 /** 862 * enables displaying of the progress inside the task bars 863 */ 864 show_progress: boolean; 865 866 /** 867 * activates/disables the 'quick_info' extension (pop-up task's details form) 868 */ 869 show_quick_info: boolean; 870 871 /** 872 * enables/disables displaying column borders in the chart area 873 */ 874 show_task_cells: boolean; 875 876 /** 877 * enables showing tasks that are outside the specified date range in the Gantt chart 878 */ 879 show_tasks_outside_timescale: boolean; 880 881 /** 882 * enables showing unscheduled tasks 883 */ 884 show_unscheduled: boolean; 885 886 /** 887 * hides non-working time from the time scale 888 */ 889 skip_off_time: boolean; 890 891 /** 892 * enables the smart rendering mode for gantt's tasks and links rendering 893 */ 894 smart_rendering: boolean; 895 896 /** 897 * specifies that only visible part of the time scale is rendered on the screen 898 */ 899 smart_scales: boolean; 900 901 /** 902 * enables sorting in the table 903 */ 904 sort: boolean; 905 906 /** 907 * sets the start value of the time scale 908 */ 909 start_date: Date; 910 911 /** 912 * sets the starting day of the week 913 */ 914 start_on_monday: boolean; 915 916 /** 917 * generates a background image for the timeline area instead of rendering actual columns' and rows' lines 918 */ 919 static_background: boolean; 920 921 /** 922 * enables rendering of highlighted cells in the static_background mode 923 */ 924 static_background_cells: boolean; 925 926 /** 927 * sets the step of the time scale (X-Axis) 928 */ 929 step: number; 930 931 /** 932 * specifies the second time scale(s) (deprecated) 933 */ 934 subscales: any[]; 935 936 /** 937 * sets the name of the attribute that will specify the id of the task's HTML element 938 */ 939 task_attribute: string; 940 941 /** 942 * sets the format of the date label in the 'Time period' section of the lightbox 943 */ 944 task_date: string; 945 946 /** 947 * sets the height of task bars in the timeline area 948 */ 949 task_height: number|string; 950 951 /** 952 * sets the offset (in pixels) of the nearest task from the left border in the timeline 953 */ 954 task_scroll_offset: number; 955 956 /** 957 * sets the format of the time drop-down selector in the lightbox 958 */ 959 time_picker: string; 960 961 /** 962 * sets the minimum step (in minutes) for the task's time values 963 */ 964 time_step: number; 965 966 /** 967 * sets the length of time, in milliseconds, before the tooltip hides 968 */ 969 tooltip_hide_timeout: number; 970 971 /** 972 * sets the right (if positive) offset of the tooltip's position 973 */ 974 tooltip_offset_x: number; 975 976 /** 977 * sets the top (if positive) offset of the tooltip's position 978 */ 979 tooltip_offset_y: number; 980 981 /** 982 * sets the timeout in milliseconds before the tooltip is displayed for a task 983 */ 984 tooltip_timeout: number; 985 986 /** 987 * enables/disables the touch support for the Gantt chart 988 */ 989 touch: boolean|string; 990 991 /** 992 * defines the time period in milliseconds that is used to differ the long touch gesture from the scroll gesture 993 */ 994 touch_drag: number|boolean; 995 996 /** 997 * returns vibration feedback before/after drag and drop on touch devices 998 */ 999 touch_feedback: boolean; 1000 1001 /** 1002 * defines the duration of vibration feedback before/after drag and drop on touch devices (in milliseconds) 1003 */ 1004 touch_feedback_duration: number; 1005 1006 /** 1007 * redefines functions responsible for displaying different types of tasks 1008 */ 1009 type_renderers: any; 1010 1011 /** 1012 * stores the names of lightbox's structures (used for different types of tasks) 1013 */ 1014 types: any; 1015 1016 /** 1017 * enables the Undo functionality for the gantt 1018 */ 1019 undo: boolean; 1020 1021 /** 1022 * sets the actions that the Undo operation will revert 1023 */ 1024 undo_actions: any; 1025 1026 /** 1027 * sets the number of steps that should be reverted by the undo method 1028 */ 1029 undo_steps: number; 1030 1031 /** 1032 * sets the types of entities for which the Undo operation will be applied 1033 */ 1034 undo_types: any; 1035 1036 /** 1037 * enables WAI-ARIA support to make the component recognizable for screen readers 1038 */ 1039 wai_aria_attributes: boolean; 1040 1041 /** 1042 * enables calculating the duration of tasks in working time instead of calendar time 1043 */ 1044 work_time: boolean; 1045 1046 /** 1047 * defines date formats that are used to parse data from a data set and to send data to a server 1048 */ 1049 xml_date: string; 1050} 1051 1052interface GanttDateHelpers { 1053 add(origin: Date, count: number, unit: string): Date; 1054 copy(origin: Date): Date; 1055 date_part(origin: Date): Date; 1056 time_part(origin: Date): Date; 1057 day_start(origin: Date): Date; 1058 month_start(origin: Date): Date; 1059 week_start(origin: Date): Date; 1060 year_start(origin: Date): Date; 1061 getISOWeek(origin: Date): number; 1062 getUTCISOWeek(origin: Date): number; 1063 date_to_str(format: string): any; 1064 str_to_date(format: string): any; 1065 convert_to_utc(origin: Date): Date; 1066 to_fixed(value: number): string; 1067} 1068 1069interface GanttHotkeys { 1070 edit_save: number; 1071 edit_cancel: number; 1072} 1073 1074interface GanttLocaleDate { 1075 month_full: string[]; 1076 month_short: string[]; 1077 day_full: string[]; 1078 day_short: string[]; 1079} 1080 1081interface GanttLocaleLabels { 1082 new_task: string; 1083 icon_save: string; 1084 icon_cancel: string; 1085 icon_details: string; 1086 icon_edit: string; 1087 icon_delete: string; 1088 confirm_closing: string; 1089 confirm_deleting: string; 1090 section_description: string; 1091 section_time: string; 1092 confirm_link_deleting: string; 1093 link_from: string; 1094 link_to: string; 1095 link_start: string; 1096 link_end: string; 1097 minutes: string; 1098 hours: string; 1099 days: string; 1100 weeks: string; 1101 months: string; 1102 years: string; 1103} 1104 1105interface GanttLocale { 1106 date: GanttLocaleDate; 1107 labels: GanttLocaleLabels; 1108} 1109 1110interface GanttEnterprise { 1111 getGanttInstance(): GanttStatic; 1112} 1113 1114interface GanttStatic { 1115 1116 /** 1117 * redefines the default click behavior for buttons of the Gantt chart 1118 */ 1119 $click: any; 1120 1121 /** 1122 * gantt ajax module 1123 */ 1124 ajax: any; 1125 1126 /** 1127 * the interface of the working calendar object 1128 */ 1129 calendar: any; 1130 1131 /** 1132 * defines configuration options for dates, scale, controls 1133 */ 1134 config: GanttConfigOptions; 1135 1136 /** 1137 * stores various constants to reduce the use of magic numbers in the code 1138 */ 1139 constants: any; 1140 1141 /** 1142 * a set of date formatting methods 1143 */ 1144 date: GanttDateHelpers; 1145 1146 /** 1147 * a set of flags which describe current environment 1148 */ 1149 env: any; 1150 1151 /** 1152 * an object that stores various extensions 1153 */ 1154 ext: any; 1155 1156 /** 1157 * specifies JSON serialization and parsing 1158 */ 1159 json: any; 1160 1161 /** 1162 * defines the hot keys for the Gantt chart 1163 */ 1164 keys: GanttHotkeys; 1165 1166 /** 1167 * returns the license name of dhtmlxGantt 1168 */ 1169 license: any; 1170 1171 /** 1172 * a locale object (region-specific labels) of the Gantt chart 1173 */ 1174 locale: GanttLocale; 1175 1176 /** 1177 * specifies serialization and parsing in the XML format of dhtmlxGantt 1.0 1178 */ 1179 oldxml: any; 1180 1181 /** 1182 * returns the current skin of the Gantt chart 1183 */ 1184 skin: string; 1185 1186 /** 1187 * returns objects of the available skins 1188 */ 1189 skins: any; 1190 1191 /** 1192 * defines formatting templates for dates, titles, tooltips in the Gantt chart 1193 */ 1194 templates: GanttTemplates; 1195 1196 /** 1197 * various helper modules 1198 */ 1199 utils: any; 1200 1201 /** 1202 * returns the version of dhtmlxGantt 1203 */ 1204 version: string; 1205 1206 /** 1207 * specifies XML serialization and parsing 1208 */ 1209 xml: any; 1210 1211 /** 1212 * Promise object constructor 1213 */ 1214 Promise(): void; 1215 1216 /** 1217 * adds a calendar into Gantt 1218 * @param calendar an object with configuration of the calendar 1219 */ 1220 addCalendar(calendar: any): number; 1221 1222 /** 1223 * adds a new dependency link 1224 * @param link the link object 1225 */ 1226 addLink(link: any): string|number; 1227 1228 /** 1229 * displays an additional layer with custom elements for a link in the timeline area 1230 * @param func a render function or a config object 1231 */ 1232 addLinkLayer(func: any): string; 1233 1234 /** 1235 * adds a marker to the timeline area 1236 * @param marker the marker's configuration object 1237 */ 1238 addMarker(marker: any): string; 1239 1240 /** 1241 * adds a new keyboard shortcut 1242 * @param shortcut the key name or the name of keys combination for a shortcut (<a href="desktop/keyboard_navigation.md#shortcutsyntax">shortcut syntax</a>) 1243 * @param handler the handler of the shortcut call 1244 * @param scope the name of the context element to attach the handler function to (<a href="desktop/keyboard_navigation.md#scopes">list of scopes</a>) 1245 */ 1246 addShortcut(shortcut: string, handler: GanttCallback, scope: string): void; 1247 1248 /** 1249 * adds a new task 1250 * @param task the task object 1251 * @param parent optional, optional, the parent's id 1252 * @param index optional, optional, the position the task will be added into (0 or greater) 1253 */ 1254 addTask(task: any, parent?: string|number, index?: number): string|number; 1255 1256 /** 1257 * displays an additional layer with custom elements for a task in the timeline area 1258 * @param func a render function or a config object 1259 */ 1260 addTaskLayer(func: any): string; 1261 1262 /** 1263 * calls an alert message box 1264 * @param config the alert box's configuration 1265 */ 1266 alert(config: any): HTMLElement; 1267 1268 /** 1269 * if the specified expression is false, an errorMessage is shown in the red popup at the top right corner of the screen 1270 * @param expression true to assert the expression, false - if assertion fails 1271 * @param errorMessage an error message that will be shown in the red popup 1272 */ 1273 assert(expression: boolean, errorMessage: string): void; 1274 1275 /** 1276 * attaches the handler to an inner event of dhtmlxGantt 1277 * @param name the event's name, case-insensitive 1278 * @param handler the handler function 1279 */ 1280 attachEvent(name: GanttEventName, handler: GanttCallback): string; 1281 1282 /** 1283 * recalculates the schedule of the project 1284 * @param taskId optional, optional, the task id 1285 */ 1286 autoSchedule(taskId?: string|number): void; 1287 1288 /** 1289 * updates multiple tasks/links at once 1290 * @param callback the callback function 1291 */ 1292 batchUpdate(callback: GanttCallback): void; 1293 1294 /** 1295 * creates a new function that, when called, has its <i>this</i> keyword set to the provided value 1296 * @param method the target function 1297 * @param thisArg the value to be passed as the <i>this</i> parameter to the target function when the bound function is called 1298 */ 1299 bind(method: GanttCallback, thisArg: any): GanttCallback; 1300 1301 /** 1302 * calculates the duration of a task 1303 * @param config the <a href="#configurationobjectproperties">configuration object</a> of a time span 1304 */ 1305 calculateDuration(config: any): number; 1306 1307 /** 1308 * calculates the end date of a task 1309 * @param config the <a href="#configurationobjectproperties">configuration object</a> of a time span 1310 */ 1311 calculateEndDate(config: any): Date; 1312 1313 /** 1314 * calculates the level of a task 1315 * @param task the task's object 1316 */ 1317 calculateTaskLevel(task: any): number; 1318 1319 /** 1320 * calls an inner event 1321 * @param name the event's name, case-insensitive 1322 * @param params an array of the event-related data 1323 */ 1324 callEvent(name: string, params: any[]): boolean; 1325 1326 /** 1327 * repaints the lighbox for the task according to its type 1328 * @param type the task type 1329 */ 1330 changeLightboxType(type: string): void; 1331 1332 /** 1333 * changes the link's id 1334 * @param id the current link's id 1335 * @param new_id the new link's id 1336 */ 1337 changeLinkId(id: string|number, new_id: string|number): void; 1338 1339 /** 1340 * changes the task's id 1341 * @param id the current task's id 1342 * @param new_id the new task's id 1343 */ 1344 changeTaskId(id: string|number, new_id: string|number): void; 1345 1346 /** 1347 * checks whether an event has some handler(s) specified 1348 * @param name the event's name 1349 */ 1350 checkEvent(name: GanttEventName): boolean; 1351 1352 /** 1353 * removes all tasks and additional elements (including markers) from the Gantt chart 1354 */ 1355 clearAll(): void; 1356 1357 /** 1358 * clears the stack of stored redo commands 1359 */ 1360 clearRedoStack(): void; 1361 1362 /** 1363 * clears the stack of stored undo commands 1364 */ 1365 clearUndoStack(): void; 1366 1367 /** 1368 * closes the branch with the specified id 1369 * @param id the branch id 1370 */ 1371 close(id: string|number): void; 1372 1373 /** 1374 * collapses gantt from the full screen mode to the normal mode 1375 */ 1376 collapse(): void; 1377 1378 /** 1379 * returns the index of the column by the date 1380 * @param date a date object 1381 */ 1382 columnIndexByDate(date: Date): void; 1383 1384 /** 1385 * calls a confirm message box 1386 * @param config the confirm box's configuration 1387 */ 1388 confirm(config: any): HTMLElement; 1389 1390 /** 1391 * creates a deep copy of provided object 1392 * @param task the object that needs to be copied 1393 */ 1394 copy(task: any): any; 1395 1396 /** 1397 * recalculates the task duration in the work time 1398 * @param task the task's object 1399 */ 1400 correctTaskWorkTime(task: any): void; 1401 1402 /** 1403 * creates a working calendar 1404 * @param parentCalendar optional, (optional) an existing calendar that is used for creating a new one on the base of it 1405 */ 1406 createCalendar(parentCalendar?: any): void; 1407 1408 /** 1409 * Ņreates a new dataProcessor instance and attaches it to gantt 1410 * @param config dataProcessor configuration object 1411 */ 1412 createDataProcessor(config: any): any; 1413 1414 /** 1415 * creates a datastore according to the provided configuration 1416 * @param config a configuration object of a datastore 1417 */ 1418 createDatastore(config: any): void; 1419 1420 /** 1421 * adds a new task and opens the lightbox to confirm 1422 * @param task the task object 1423 * @param parent the parent's id 1424 * @param index optional, optional, the position the task will be added into (0 or greater) 1425 */ 1426 createTask(task: any, parent: string, index?: number): string|number; 1427 1428 /** 1429 * dataProcessor constructor 1430 * @param url url to the data feed 1431 */ 1432 dataProcessor(url: string): void; 1433 1434 /** 1435 * gets the date of the specified horizontal position in the chart area 1436 * @param pos the relative horizontal position you want to know the date of 1437 */ 1438 dateFromPos(pos: number): Date; 1439 1440 /** 1441 * returns false if the provided argument is undefined, otherwise true 1442 * @param task the object that should be checked 1443 */ 1444 defined(task: any): boolean; 1445 1446 /** 1447 * deletes a task calendar by its id 1448 * @param id the id of the calendar 1449 */ 1450 deleteCalendar(id: string|number): void; 1451 1452 /** 1453 * deletes the specified dependency link 1454 * @param id the dependency link's id 1455 */ 1456 deleteLink(id: string|number): void; 1457 1458 /** 1459 * deletes the specified marker 1460 * @param markerId the marker's id 1461 */ 1462 deleteMarker(markerId: string): void; 1463 1464 /** 1465 * deletes the specified task 1466 * @param id the task's id 1467 */ 1468 deleteTask(id: string|number): void; 1469 1470 /** 1471 * destroys the gantt instance 1472 */ 1473 destructor(): void; 1474 1475 /** 1476 * detaches all events from dhtmlxGantt (both custom and inner ones) 1477 */ 1478 detachAllEvents(): void; 1479 1480 /** 1481 * detaches a handler from an event (which was attached before by the attachEvent() method) 1482 * @param id the event's id 1483 */ 1484 detachEvent(id: string): void; 1485 1486 /** 1487 * iterates over all parent tasks of the specified task in the Gantt chart 1488 * @param code a function that will iterate over tasks. Takes a task object as a parameter 1489 * @param startTask the id of the item the parent tasks of which should be iterated over 1490 * @param master optional, the object, that 'this' will refer to 1491 */ 1492 eachParent(code: GanttCallback, startTask: string|number, master?: any): void; 1493 1494 /** 1495 * iterates over all selected tasks in the Gantt chart 1496 * @param code a function that will iterate over tasks. Takes a task id as a parameter 1497 */ 1498 eachSelectedTask(code: GanttCallback): void; 1499 1500 /** 1501 * iterates over all child tasks of a specific task or the of whole Gantt chart 1502 * @param code a function that will iterate over tasks. Takes a task object as a parameter 1503 * @param parent optional, the parent id. If specified, the function will iterate over children of the <br> specified parent 1504 * @param master optional, the object, that 'this' will refer to 1505 */ 1506 eachTask(code: GanttCallback, parent?: string|number, master?: any): void; 1507 1508 /** 1509 * attaches an event handler to an HTML element 1510 * @param node the HTML node or its id 1511 * @param event the name of an HTML event (without the 'on' prefix) 1512 * @param handler the event handler 1513 * @param options optional, optional, the value of either the <i>useCapture</i> or <i>options</i> parameter. <a href="https://developer.mozilla.org/en-US/docs/Web/API/EventTarget/addEventListener">Read details</a> 1514 */ 1515 event(node: HTMLElement|string, event: string, handler: GanttCallback, options?: any): void; 1516 1517 /** 1518 * removes an event handler from an HTML element 1519 * @param node the HTML node or its id 1520 * @param event the name of an HTML event (without the 'on' prefix) 1521 * @param handler the event handler 1522 * @param options optional, optional, the value of either the <i>useCapture</i> or <i>options</i> parameter. <a href="https://developer.mozilla.org/en-US/docs/Web/API/EventTarget/removeEventListener">Read details</a> 1523 */ 1524 eventRemove(node: HTMLElement|string, event: string, handler: GanttCallback, options?: any): void; 1525 1526 /** 1527 * expands gantt to the full screen mode 1528 */ 1529 expand(): void; 1530 1531 /** 1532 * exports data from the Gantt chart to an Excel document 1533 * @param _export_ an object with export settings (see the details) 1534 */ 1535 exportToExcel(_export_: any): void; 1536 1537 /** 1538 * exports data from the Gantt chart to an iCal string 1539 * @param _export_ an object with export settings (see the details) 1540 */ 1541 exportToICal(_export_: any): void; 1542 1543 /** 1544 * exports the structure and data of a Gantt chart into a JSON object 1545 * @param config an object with Gantt configuration 1546 */ 1547 exportToJSON(config: any): void; 1548 1549 /** 1550 * exports data from the Gantt chart to MS Project 1551 * @param _export_ an object with export settings (see the details) 1552 */ 1553 exportToMSProject(_export_: any): void; 1554 1555 /** 1556 * exports a Gantt chart into the PDF format 1557 * @param _export_ an object with export settings (see the details) 1558 */ 1559 exportToPDF(_export_: any): void; 1560 1561 /** 1562 * exports a Gantt chart into the PNG format 1563 * @param _export_ an object with export settings (see the details) 1564 */ 1565 exportToPNG(_export_: any): void; 1566 1567 /** 1568 * returns all dependency loops in the chart 1569 */ 1570 findCycles(): any[]; 1571 1572 /** 1573 * sets focus on the gantt 1574 */ 1575 focus(): void; 1576 1577 /** 1578 * gets worktime calendar by id 1579 * @param calendarId the id of the global calendar or "global" 1580 */ 1581 getCalendar(calendarId: string|number): any; 1582 1583 /** 1584 * gets all the calendars added into Gantt 1585 */ 1586 getCalendars(): any[]; 1587 1588 /** 1589 * returns the 1st-level child tasks of the specified parent branch 1590 * @param id the parent branch's id 1591 */ 1592 getChildren(id: string|number): any[]; 1593 1594 /** 1595 * returns the closest working time 1596 * @param config the configuration object 1597 */ 1598 getClosestWorkTime(config: any): Date; 1599 1600 /** 1601 * returns the index of the column by its name 1602 * @param name the name of the column 1603 */ 1604 getColumnIndex(name: string): number; 1605 1606 /** 1607 * returns all tasks and links that a task is connected with 1608 * @param id optional, optional, the id of a task 1609 */ 1610 getConnectedGroup(id?: string|number): any; 1611 1612 /** 1613 * returns the earliest and latest dates allowed by the constraint applied to a task 1614 * @param task a task object 1615 */ 1616 getConstraintLimitations(task: any): void; 1617 1618 /** 1619 * returns the constraint type applied to the task 1620 * @param task a task object 1621 */ 1622 getConstraintType(task: any): string; 1623 1624 /** 1625 * returns the configuration object of a datastore 1626 * @param name the name of the datastore 1627 */ 1628 getDatastore(name: string): any; 1629 1630 /** 1631 * returns the free slack of a task 1632 * @param task the object of a task 1633 */ 1634 getFreeSlack(task: any): number; 1635 1636 /** 1637 * gets the index of a task in the tree 1638 * @param id the task id 1639 */ 1640 getGlobalTaskIndex(id: string|number): number; 1641 1642 /** 1643 * gets the configuration object of a column 1644 * @param name the column's name 1645 */ 1646 getGridColumn(name: string): any; 1647 1648 /** 1649 * gets columns of the Gantt chart 1650 */ 1651 getGridColumns(): any[]; 1652 1653 /** 1654 * gets the label of a select control in the lightbox 1655 * @param property the name of a data property that the control is mapped to 1656 * @param key the option's id. This parameter is compared with the task's data property to <br> assign the select's option to the task 1657 */ 1658 getLabel(property: string, key: string|number): string; 1659 1660 /** 1661 * returns the id of the last selected task 1662 */ 1663 getLastSelectedTask(): string|number; 1664 1665 /** 1666 * gets the lightbox's HTML object element 1667 */ 1668 getLightbox(): HTMLElement; 1669 1670 /** 1671 * returns the object of the lightbox's section 1672 * @param name the name of the section 1673 */ 1674 getLightboxSection(name: string): any; 1675 1676 /** 1677 * returns the name of the active lighbox's structure 1678 */ 1679 getLightboxType(): string; 1680 1681 /** 1682 * returns values of the lightbox's sections 1683 */ 1684 getLightboxValues(): any; 1685 1686 /** 1687 * returns the dependency link object by the specified id 1688 * @param id the link id 1689 */ 1690 getLink(id: string|number): any; 1691 1692 /** 1693 * returns the number of all dependency links presented in the Gantt chart 1694 */ 1695 getLinkCount(): number; 1696 1697 /** 1698 * returns the HTML element of the specified dependency link 1699 * @param id the link id 1700 */ 1701 getLinkNode(id: string|number): HTMLElement; 1702 1703 /** 1704 * returns all links presented in the Gantt chart 1705 */ 1706 getLinks(): any[]; 1707 1708 /** 1709 * gets the marker's object 1710 * @param markerId the marker's id 1711 */ 1712 getMarker(markerId: string): any; 1713 1714 /** 1715 * returns the id of the next item (no matter what the level of nesting is: the same or different) 1716 * @param id the task id 1717 */ 1718 getNext(id: string|number): string|number; 1719 1720 /** 1721 * returns the id of the next task of the same level 1722 * @param id the task id 1723 */ 1724 getNextSibling(id: string|number): string|number; 1725 1726 /** 1727 * returns the id of the parent task 1728 * @param id the task id 1729 */ 1730 getParent(id: string|number): string|number; 1731 1732 /** 1733 * returns the id of the previous item (no matter what the level of nesting is: the same or different) 1734 * @param id the task id 1735 */ 1736 getPrev(id: string|number): string|number; 1737 1738 /** 1739 * returns the id of the previous task of the same level 1740 * @param id the task id 1741 */ 1742 getPrevSibling(id: string|number): string|number; 1743 1744 /** 1745 * returns the stack of stored redo user actions 1746 */ 1747 getRedoStack(): any[]; 1748 1749 /** 1750 * returns all tasks assigned to the resource 1751 * @param resourceId the id of the resource 1752 */ 1753 getResourceAssignments(resourceId: string|number): any[]; 1754 1755 /** 1756 * returns the configuration of the time scale 1757 */ 1758 getScale(): any; 1759 1760 /** 1761 * returns the scroll position 1762 */ 1763 getScrollState(): any; 1764 1765 /** 1766 * returns the id of the selected task 1767 */ 1768 getSelectedId(): string; 1769 1770 /** 1771 * returns an array of the currently selected tasks 1772 */ 1773 getSelectedTasks(): any[]; 1774 1775 /** 1776 * gets a key navigation shortcut handler 1777 * @param shortcut the key name or the name of keys combination for a shortcut (<a href="desktop/keyboard_navigation.md#shortcutsyntax">shortcut syntax</a>) 1778 * @param scope the name of the context element to attach the handler function to (<a href="desktop/keyboard_navigation.md#scopes">list of scopes</a>) 1779 */ 1780 getShortcutHandler(shortcut: string, scope: string): GanttCallback; 1781 1782 /** 1783 * returns siblings of the specified task (including itself) 1784 * @param id the task id 1785 */ 1786 getSiblings(id: string|number): any[]; 1787 1788 /** 1789 * checks how much time (in the current duration unit) a task has before it starts to affect other tasks 1790 * @param task1 the object of the 1st task to check the slack for 1791 * @param task2 the object of the 2nd task to check the slack for 1792 */ 1793 getSlack(task1: any, task2: any): number|string; 1794 1795 /** 1796 * gets the current state of the Gantt chart 1797 */ 1798 getState(): any; 1799 1800 /** 1801 * calculates the combined start/end dates of tasks nested in a project or another task 1802 * @param task_id optional, the task's id, api/gantt_root_id_config.md will be used if not specified 1803 */ 1804 getSubtaskDates(task_id?: string|number): any; 1805 1806 /** 1807 * calculates the combined duration of tasks nested in a project or another task. 1808 * @param task_id optional, the task's id, api/gantt_root_id_config.md will be used if not specified 1809 */ 1810 getSubtaskDuration(task_id?: string|number): number; 1811 1812 /** 1813 * returns the task object 1814 * @param id the task id 1815 */ 1816 getTask(id: string|number): any; 1817 1818 /** 1819 * finds a task by the specified criteria 1820 * @param propertyName the name of the property to match, or a filter function 1821 * @param propertyValue the property value 1822 */ 1823 getTaskBy(propertyName: string|GanttCallback, propertyValue: any): any[]; 1824 1825 /** 1826 * returns a task by its global task index 1827 * @param index the task index in the tree (zero-based numbering) 1828 */ 1829 getTaskByIndex(index: number): any; 1830 1831 /** 1832 * returns a collection of tasks which occur during the specified period 1833 * @param from optional, the start date of the period 1834 * @param to optional, the end date of the period 1835 */ 1836 getTaskByTime(from?: Date, to?: Date): any[]; 1837 1838 /** 1839 * returns a task by its WBS code 1840 * @param code the WBS code of the task 1841 */ 1842 getTaskByWBSCode(code: string): any; 1843 1844 /** 1845 * gets a calendar assigned to the specified task (a task level calendar) 1846 * @param task the object of a task 1847 */ 1848 getTaskCalendar(task: any): any; 1849 1850 /** 1851 * gets the number of tasks that are currently loaded in the gantt 1852 */ 1853 getTaskCount(): number; 1854 1855 /** 1856 * returns the visible height of a task 1857 */ 1858 getTaskHeight(): number; 1859 1860 /** 1861 * gets the index of a task in the branch 1862 * @param id the task id 1863 */ 1864 getTaskIndex(id: string|number): number; 1865 1866 /** 1867 * returns the HTML element of the task bar 1868 * @param id the task id 1869 */ 1870 getTaskNode(id: string|number): HTMLElement; 1871 1872 /** 1873 * calculates the position and size of the task's DOM element in the timeline area 1874 * @param task the task object 1875 * @param from the start date of the item 1876 * @param to the end date of the item 1877 */ 1878 getTaskPosition(task: any, from: Date, to: Date): any; 1879 1880 /** 1881 * returns the HTML element of the task row in the table 1882 * @param id the task id 1883 */ 1884 getTaskRowNode(id: string|number): HTMLElement; 1885 1886 /** 1887 * gets the top position of the task's DOM element in the timeline area 1888 * @param id the task's id 1889 */ 1890 getTaskTop(id: number|string): number; 1891 1892 /** 1893 * returns the type of a task 1894 * @param task the task object 1895 */ 1896 getTaskType(task: any): string; 1897 1898 /** 1899 * returns the total slack of a task 1900 * @param task the object of a task 1901 */ 1902 getTotalSlack(task: any): number; 1903 1904 /** 1905 * returns the stack of stored undo user actions 1906 */ 1907 getUndoStack(): any[]; 1908 1909 /** 1910 * gets the number of tasks visible on the screen (those that are not collapsed) 1911 */ 1912 getVisibleTaskCount(): number; 1913 1914 /** 1915 * returns the WBS code (the outline number) of a task 1916 * @param task the object of a task 1917 */ 1918 getWBSCode(task: any): string; 1919 1920 /** 1921 * returns the working hours of the specified date 1922 * @param date a date to check 1923 */ 1924 getWorkHours(date: Date): any[]; 1925 1926 /** 1927 * groups tasks by the specified task's attribute 1928 * @param config the grouping configuration object, or false to ungroup tasks 1929 */ 1930 groupBy(config: any): void; 1931 1932 /** 1933 * checks whether the specified item has child tasks 1934 * @param id the task id 1935 */ 1936 hasChild(id: string|number): boolean; 1937 1938 /** 1939 * hides the lightbox modal overlay that blocks interactions with the remaining screen 1940 * @param box optional, an element to hide 1941 */ 1942 hideCover(box?: HTMLElement): void; 1943 1944 /** 1945 * closes the lightbox if it's currently active 1946 */ 1947 hideLightbox(): void; 1948 1949 /** 1950 * hides the pop-up task form (if it's currently active) 1951 */ 1952 hideQuickInfo(): void; 1953 1954 /** 1955 * converts an Excel file to JSON 1956 * @param config an object with configuration properties of an imported file 1957 */ 1958 importFromExcel(config: any): void; 1959 1960 /** 1961 * converts an XML or MPP MS Project file to JSON 1962 * @param config an object with configuration properties of an imported file 1963 */ 1964 importFromMSProject(config: any): void; 1965 1966 /** 1967 * initializes a dhtmlxGantt inside a container 1968 * @param container an HTML container (or its id) where a dhtmlxGantt object will be initialized 1969 * @param from optional, the start value of the time scale (X–Axis) 1970 * @param to optional, the end value of the time scale (X–Axis) 1971 */ 1972 init(container: string|HTMLElement, from?: Date, to?: Date): void; 1973 1974 /** 1975 * checks whether a task is a child of a different task 1976 * @param childId the id of a task that you want to check as a child 1977 * @param parentId the id of a task that you want to check as a parent 1978 */ 1979 isChildOf(childId: string|number, parentId: string|number): boolean; 1980 1981 /** 1982 * checks whether the link is circular 1983 * @param link the link object 1984 */ 1985 isCircularLink(link: any): boolean; 1986 1987 /** 1988 * checks whether the specified link is critical 1989 * @param link the link's object 1990 */ 1991 isCriticalLink(link: any): boolean; 1992 1993 /** 1994 * checks whether the specified task is critical 1995 * @param task the task's object 1996 */ 1997 isCriticalTask(task: any): boolean; 1998 1999 /** 2000 * checks whether the specified link is correct 2001 * @param link the link object 2002 */ 2003 isLinkAllowed(link: any): boolean; 2004 2005 /** 2006 * checks whether the specified link exists 2007 * @param id the link id 2008 */ 2009 isLinkExists(id: string|number): boolean; 2010 2011 /** 2012 * checks whether the specified task or link is read-only 2013 * @param id the task/link id 2014 */ 2015 isReadonly(id: string|number): boolean; 2016 2017 /** 2018 * checks whether the specified task is currently selected 2019 * @param task the task's id 2020 */ 2021 isSelectedTask(task: string|number): boolean; 2022 2023 /** 2024 * checks whether the specified task is split 2025 * @param task the object of a task 2026 */ 2027 isSplitTask(task: any): boolean; 2028 2029 /** 2030 * checks whether the specified task is summary 2031 * @param task the object of a task 2032 */ 2033 isSummaryTask(task: any): boolean; 2034 2035 /** 2036 * checks whether the specified task exists 2037 * @param id the task id 2038 */ 2039 isTaskExists(id: string|number): boolean; 2040 2041 /** 2042 * checks whether the specifies task is currently rendered in the Gantt chart 2043 * @param id the task's id 2044 */ 2045 isTaskVisible(id: string|number): boolean; 2046 2047 /** 2048 * checks if the task is unscheduled 2049 * @param task the task's object 2050 */ 2051 isUnscheduledTask(task: any): boolean; 2052 2053 /** 2054 * checks whether the specified date is working or not 2055 * @param config the configuration object of a time span 2056 */ 2057 isWorkTime(config: any): boolean; 2058 2059 /** 2060 * loads data to the gantt from an external data source 2061 * @param url the server-side url (may be a static file or a server side script that outputs data) 2062 * @param type optional, <i>('json', 'xml', 'oldxml')</i> the data type. The default value - <i>'json'</i> 2063 * @param callback optional, the callback function 2064 */ 2065 load(url: string, type?: string, callback?: GanttCallback): any; 2066 2067 /** 2068 * gets the id of a task from the specified HTML event 2069 * @param e a native event 2070 */ 2071 locate(e: Event): string|number; 2072 2073 /** 2074 * calls a message box of the specified type 2075 * @param config the message box's configuration 2076 */ 2077 message(config: any): HTMLElement; 2078 2079 /** 2080 * adds properties of the 'source' object into the 'target' object 2081 * @param target the target object 2082 * @param source the source object 2083 * @param force if true, properties of the 'source' will overwrite matching properties of the 'target', if there are any. If false, properties that already exist in the 'target' will be omitted 2084 */ 2085 mixin(target: any, source: any, force: boolean): void; 2086 2087 /** 2088 * calls a modalbox 2089 * @param config the modal box's configuration 2090 */ 2091 modalbox(config: any): HTMLElement; 2092 2093 /** 2094 * moves a task to a new position 2095 * @param sid the id of the task to move 2096 * @param tindex the index of the position that the task will be moved to <br> (the index within a branch) 2097 * @param parent optional, the parent id. If specified, the <b>tindex</b> will refer to the index in the <br> <b>'parent'</b> branch 2098 */ 2099 moveTask(sid: string|number, tindex: number, parent?: string|number): boolean; 2100 2101 /** 2102 * opens the branch with the specified id 2103 * @param id the branch id 2104 */ 2105 open(id: string|number): void; 2106 2107 /** 2108 * loads data from a client-side resource 2109 * @param url a string or object which represents data 2110 * @param type optional, optional, (<i>'json', 'xml'</i>) the data type. The default value - <i>'json'</i> 2111 */ 2112 parse(url: any, type?: string): void; 2113 2114 /** 2115 * gets the relative horizontal position of the specified date in the chart area 2116 * @param date a date you want to know the position of 2117 */ 2118 posFromDate(date: Date): number; 2119 2120 /** 2121 * applies the reverted changes to the gantt once again 2122 */ 2123 redo(): void; 2124 2125 /** 2126 * refreshes data in the Gantt chart 2127 */ 2128 refreshData(): void; 2129 2130 /** 2131 * refreshes the specifies link 2132 * @param id the link id 2133 */ 2134 refreshLink(id: string|number): void; 2135 2136 /** 2137 * refreshes the task and its related links 2138 * @param id the task id 2139 * @param refresh_links optional, optional, defines whether links related to the task should be refreshed, <em>true</em> by default 2140 */ 2141 refreshTask(id: string|number, refresh_links?: boolean): void; 2142 2143 /** 2144 * removes the specified layer related to a link 2145 * @param layerId a DOM element that will be displayed in the layer 2146 */ 2147 removeLinkLayer(layerId: string): void; 2148 2149 /** 2150 * removes a keyboard shortcut 2151 * @param shortcut the key name or the name of keys combination for a shortcut (<a href="desktop/keyboard_navigation.md#shortcutsyntax">shortcut syntax</a>) 2152 * @param scope the element to which the shortcut is attached (<a href="desktop/keyboard_navigation.md#scopes">list of scopes</a>) 2153 */ 2154 removeShortcut(shortcut: string, scope: any): void; 2155 2156 /** 2157 * removes the specified layer related to a task 2158 * @param layerId a DOM element that will be displayed in the layer 2159 */ 2160 removeTaskLayer(layerId: string): void; 2161 2162 /** 2163 * renders the whole Gantt chart 2164 */ 2165 render(): void; 2166 2167 /** 2168 * updates all markers on the page 2169 */ 2170 renderMarkers(): void; 2171 2172 /** 2173 * removes the current lightbox's HTML object element 2174 */ 2175 resetLightbox(): void; 2176 2177 /** 2178 * re-calculates the duration of a project task depending on the dates of its children 2179 * @param task the task's object 2180 */ 2181 resetProjectDates(task: any): void; 2182 2183 /** 2184 * re-calculates the skin's settings from the related attached skin CSS file 2185 */ 2186 resetSkin(): void; 2187 2188 /** 2189 * forces the lightbox to resize 2190 */ 2191 resizeLightbox(): void; 2192 2193 /** 2194 * rounds the specified date to the nearest date in the time scale 2195 * @param date the Date object to round 2196 */ 2197 roundDate(date: Date): Date; 2198 2199 /** 2200 * rounds the start and end task's dates to the nearest dates in the time scale 2201 * @param task the task object 2202 */ 2203 roundTaskDates(task: any): void; 2204 2205 /** 2206 * scrolls the Gantt container to the specified position 2207 * @param x value of horizontal scroll or 'null' (if the scroll position shouldn't be changed) 2208 * @param y value of vertical scroll or 'null' (if the scroll position shouldn't be changed) 2209 */ 2210 scrollTo(x: number|null, y: number|null): void; 2211 2212 /** 2213 * selects the specified task 2214 * @param id the task id 2215 */ 2216 selectTask(id: string|number): string|number; 2217 2218 /** 2219 * serializes the data into JSON or XML format 2220 * @param type optional, the format that the data will be serialized into. <br> Possible values: 'json' (<i>default</i> ), 'xml'. 2221 */ 2222 serialize(type?: string): void; 2223 2224 /** 2225 * returns a list of options 2226 * @param list_name the name of a list 2227 * @param options optional, an array of options 2228 */ 2229 serverList(list_name: string, options?: any[]): any[]; 2230 2231 /** 2232 * set the parent for a task 2233 * @param task the task id 2234 * @param pid the parent task id 2235 */ 2236 setParent(task: number|string, pid: number|string): void; 2237 2238 /** 2239 * resizes the Gantt chart 2240 */ 2241 setSizes(): void; 2242 2243 /** 2244 * sets the working time for the Gantt chart 2245 * @param config the configuration object of a time span 2246 */ 2247 setWorkTime(config: any): void; 2248 2249 /** 2250 * shows the lightbox modal overlay that blocks interactions with the remaining screen 2251 * @param box optional, an element to hide 2252 */ 2253 showCover(box?: HTMLElement): void; 2254 2255 /** 2256 * scrolls the chart area to makes the specified date visible 2257 * @param date the date to show in the chart 2258 */ 2259 showDate(date: Date): void; 2260 2261 /** 2262 * opens the lightbox for the specified task 2263 * @param id the task id 2264 */ 2265 showLightbox(id: string|number): void; 2266 2267 /** 2268 * displays the pop-up task form for the specified task 2269 * @param id the task id 2270 */ 2271 showQuickInfo(id: string|number): void; 2272 2273 /** 2274 * makes the specified task visible on the screen 2275 * @param id the task id 2276 */ 2277 showTask(id: string|number): void; 2278 2279 /** 2280 * sorts tasks in the grid 2281 * @param field the name of the column that the grid will be sorted by or a custom sorting function 2282 * @param desc optional, specifies the sorting direction: <i>true</i> - descending sort and <i>false</i> - ascending<br> sort. By default, <i>false</i> 2283 * @param parent optional, the id of the parent task. Specify the parameter if you want to sort tasks only in the branch of the specified parent. 2284 * @param silent optional, specifies whether rendering should be invoked after reordering items 2285 */ 2286 sort(field: string|GanttCallback, desc?: boolean, parent?: string|number, silent?: boolean): void; 2287 2288 /** 2289 * selects the specified task if it was unselected and vice versa 2290 * @param task the task's id 2291 */ 2292 toggleTaskSelection(task: string|number): void; 2293 2294 /** 2295 * returns a unique id 2296 */ 2297 uid(): number; 2298 2299 /** 2300 * reverts the changes made in the gantt 2301 */ 2302 undo(): void; 2303 2304 /** 2305 * removes selection from the selected task 2306 * @param id optional, optional, the id of the task to remove selection from, see details 2307 */ 2308 unselectTask(id?: string|number): void; 2309 2310 /** 2311 * unsets a working time in the Gantt Chart 2312 * @param config the configuration object of a time span 2313 */ 2314 unsetWorkTime(config: any): void; 2315 2316 /** 2317 * updates the specified collection with new options 2318 * @param collection the name of the collection to update 2319 * @param options the new values of the collection 2320 */ 2321 updateCollection(collection: string, options: any[]): boolean; 2322 2323 /** 2324 * updates the specified dependency link 2325 * @param id the task id 2326 */ 2327 updateLink(id: string): void; 2328 2329 /** 2330 * updates the specified marker 2331 * @param markerId the marker's id 2332 */ 2333 updateMarker(markerId: string): void; 2334 2335 /** 2336 * updates the specified task 2337 * @param id the task id 2338 */ 2339 updateTask(id: string): void; 2340} 2341 2342declare var gantt: GanttStatic; 2343 2344declare module "gantt" { 2345 export = gantt; 2346} 2347 2348declare var Gantt: GanttEnterprise; 2349 2350declare module "Gantt" { 2351 export = Gantt; 2352}