@progress/kendo-angular-gantt 0.1.5 → 0.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (137) hide show
  1. package/dist/cdn/js/kendo-angular-gantt.js +2 -76
  2. package/dist/cdn/main.js +23 -1
  3. package/dist/es/columns/column.component.js +5 -0
  4. package/dist/es/columns/columns.js +1 -0
  5. package/dist/es/columns/edit-template.directive.js +34 -0
  6. package/dist/es/columns/span-column.component.js +6 -0
  7. package/dist/es/common/default-callbacks.js +4 -0
  8. package/dist/es/editing/edit-dialog.component.js +44 -0
  9. package/dist/es/editing/edit.service.js +39 -0
  10. package/dist/es/editing/util.js +17 -0
  11. package/dist/es/gantt.component.js +478 -22
  12. package/dist/es/gantt.module.js +62 -5
  13. package/dist/es/index.js +6 -0
  14. package/dist/es/localization/custom-messages.component.js +44 -0
  15. package/dist/es/localization/localized-messages.directive.js +35 -0
  16. package/dist/es/localization/messages.js +246 -0
  17. package/dist/es/localization/treelist-messages.directive.js +31 -0
  18. package/dist/es/main.js +1 -0
  19. package/dist/es/models/events/cell-click-event.interface.js +4 -0
  20. package/dist/es/models/events/cell-close-event.interface.js +19 -0
  21. package/dist/es/models/events/preventable-event.js +32 -0
  22. package/dist/es/models/events/task-click-event.interface.js +4 -0
  23. package/dist/es/models/events/task-edit-event.interface.js +4 -0
  24. package/dist/es/models/gantt-task-model-fields.interface.js +2 -1
  25. package/dist/es/package-metadata.js +1 -1
  26. package/dist/es/rendering/gantt-milestone-task.component.js +1 -1
  27. package/dist/es/rendering/gantt-summary-task.component.js +1 -1
  28. package/dist/es/rendering/gantt-task-base.js +8 -0
  29. package/dist/es/rendering/gantt-task.component.js +12 -4
  30. package/dist/es/rendering/gantt-tasks-table-body.component.js +5 -1
  31. package/dist/es/selection/selectable.directive.js +141 -0
  32. package/dist/es/selection/selection-change-event.js +4 -0
  33. package/dist/es/timeline/gantt-timeline.component.js +5 -1
  34. package/dist/es/toolbar/view-selector.component.js +7 -4
  35. package/dist/es/utils.js +48 -1
  36. package/dist/es2015/columns/column.component.d.ts +2 -0
  37. package/dist/es2015/columns/column.component.js +5 -0
  38. package/dist/es2015/columns/columns.d.ts +1 -0
  39. package/dist/es2015/columns/columns.js +1 -0
  40. package/dist/es2015/columns/edit-template.directive.d.ts +23 -0
  41. package/dist/es2015/columns/edit-template.directive.js +33 -0
  42. package/dist/es2015/columns/span-column.component.d.ts +2 -0
  43. package/dist/es2015/columns/span-column.component.js +6 -0
  44. package/dist/es2015/common/default-callbacks.d.ts +4 -0
  45. package/dist/es2015/common/default-callbacks.js +4 -0
  46. package/dist/es2015/editing/edit-dialog.component.d.ts +21 -0
  47. package/dist/es2015/editing/edit-dialog.component.js +86 -0
  48. package/dist/es2015/editing/edit.service.d.ts +20 -0
  49. package/dist/es2015/editing/edit.service.js +41 -0
  50. package/dist/es2015/editing/util.d.ts +10 -0
  51. package/dist/es2015/editing/util.js +17 -0
  52. package/dist/es2015/gantt.component.d.ts +236 -12
  53. package/dist/es2015/gantt.component.js +662 -21
  54. package/dist/es2015/gantt.module.d.ts +29 -1
  55. package/dist/es2015/gantt.module.js +62 -5
  56. package/dist/es2015/index.d.ts +6 -0
  57. package/dist/es2015/index.js +6 -0
  58. package/dist/es2015/index.metadata.json +1 -1
  59. package/dist/es2015/localization/custom-messages.component.d.ts +15 -0
  60. package/dist/es2015/localization/custom-messages.component.js +36 -0
  61. package/dist/es2015/localization/localized-messages.directive.d.ts +13 -0
  62. package/dist/es2015/localization/localized-messages.directive.js +31 -0
  63. package/dist/es2015/localization/messages.d.ts +246 -0
  64. package/dist/es2015/localization/messages.js +240 -0
  65. package/dist/es2015/localization/treelist-messages.directive.d.ts +14 -0
  66. package/dist/es2015/localization/treelist-messages.directive.js +29 -0
  67. package/dist/es2015/main.d.ts +2 -0
  68. package/dist/es2015/main.js +1 -0
  69. package/dist/es2015/models/events/cell-click-event.interface.d.ts +43 -0
  70. package/dist/es2015/models/events/cell-click-event.interface.js +4 -0
  71. package/dist/es2015/models/events/cell-close-event.interface.d.ts +48 -0
  72. package/dist/es2015/models/events/cell-close-event.interface.js +14 -0
  73. package/dist/es2015/models/events/preventable-event.d.ts +24 -0
  74. package/dist/es2015/models/events/preventable-event.js +30 -0
  75. package/dist/es2015/models/events/task-click-event.interface.d.ts +30 -0
  76. package/dist/es2015/models/events/task-click-event.interface.js +4 -0
  77. package/dist/es2015/models/events/task-edit-event.interface.d.ts +46 -0
  78. package/dist/es2015/models/events/task-edit-event.interface.js +4 -0
  79. package/dist/es2015/models/gantt-task-model-fields.interface.d.ts +1 -0
  80. package/dist/es2015/models/gantt-task-model-fields.interface.js +2 -1
  81. package/dist/es2015/models/models.d.ts +2 -0
  82. package/dist/es2015/package-metadata.js +1 -1
  83. package/dist/es2015/rendering/gantt-milestone-task.component.js +2 -0
  84. package/dist/es2015/rendering/gantt-summary-task.component.js +2 -0
  85. package/dist/es2015/rendering/gantt-task-base.d.ts +2 -0
  86. package/dist/es2015/rendering/gantt-task-base.js +8 -0
  87. package/dist/es2015/rendering/gantt-task.component.d.ts +4 -1
  88. package/dist/es2015/rendering/gantt-task.component.js +18 -2
  89. package/dist/es2015/rendering/gantt-tasks-table-body.component.d.ts +1 -0
  90. package/dist/es2015/rendering/gantt-tasks-table-body.component.js +11 -1
  91. package/dist/es2015/selection/selectable.directive.d.ts +42 -0
  92. package/dist/es2015/selection/selectable.directive.js +122 -0
  93. package/dist/es2015/selection/selection-change-event.d.ts +25 -0
  94. package/dist/es2015/selection/selection-change-event.js +4 -0
  95. package/dist/es2015/timeline/gantt-timeline.component.d.ts +1 -0
  96. package/dist/es2015/timeline/gantt-timeline.component.js +5 -0
  97. package/dist/es2015/toolbar/view-selector.component.d.ts +3 -0
  98. package/dist/es2015/toolbar/view-selector.component.js +8 -7
  99. package/dist/es2015/utils.d.ts +39 -0
  100. package/dist/es2015/utils.js +48 -1
  101. package/dist/fesm2015/index.js +1388 -35
  102. package/dist/fesm5/index.js +1191 -45
  103. package/dist/npm/columns/column.component.js +5 -0
  104. package/dist/npm/columns/columns.js +2 -0
  105. package/dist/npm/columns/edit-template.directive.js +36 -0
  106. package/dist/npm/columns/span-column.component.js +6 -0
  107. package/dist/npm/common/default-callbacks.js +4 -0
  108. package/dist/npm/editing/edit-dialog.component.js +46 -0
  109. package/dist/npm/editing/edit.service.js +41 -0
  110. package/dist/npm/editing/util.js +19 -0
  111. package/dist/npm/gantt.component.js +475 -19
  112. package/dist/npm/gantt.module.js +61 -4
  113. package/dist/npm/index.js +12 -0
  114. package/dist/npm/localization/custom-messages.component.js +46 -0
  115. package/dist/npm/localization/localized-messages.directive.js +37 -0
  116. package/dist/npm/localization/messages.js +248 -0
  117. package/dist/npm/localization/treelist-messages.directive.js +33 -0
  118. package/dist/npm/main.js +2 -0
  119. package/dist/npm/models/events/cell-click-event.interface.js +6 -0
  120. package/dist/npm/models/events/cell-close-event.interface.js +21 -0
  121. package/dist/npm/models/events/preventable-event.js +34 -0
  122. package/dist/npm/models/events/task-click-event.interface.js +6 -0
  123. package/dist/npm/models/events/task-edit-event.interface.js +6 -0
  124. package/dist/npm/models/gantt-task-model-fields.interface.js +2 -1
  125. package/dist/npm/package-metadata.js +1 -1
  126. package/dist/npm/rendering/gantt-milestone-task.component.js +1 -1
  127. package/dist/npm/rendering/gantt-summary-task.component.js +1 -1
  128. package/dist/npm/rendering/gantt-task-base.js +8 -0
  129. package/dist/npm/rendering/gantt-task.component.js +12 -4
  130. package/dist/npm/rendering/gantt-tasks-table-body.component.js +5 -1
  131. package/dist/npm/selection/selectable.directive.js +143 -0
  132. package/dist/npm/selection/selection-change-event.js +6 -0
  133. package/dist/npm/timeline/gantt-timeline.component.js +5 -1
  134. package/dist/npm/toolbar/view-selector.component.js +7 -4
  135. package/dist/npm/utils.js +47 -0
  136. package/dist/systemjs/kendo-angular-gantt.js +1 -1
  137. package/package.json +5 -2
@@ -13,6 +13,7 @@ import { FilterCellTemplateDirective } from './filter-cell-template.directive';
13
13
  import { FilterMenuTemplateDirective } from './filter-menu-template.directive';
14
14
  import { FooterTemplateDirective } from './footer-template.directive';
15
15
  import { HeaderTemplateDirective } from './header-template.directive';
16
+ import { EditTemplateDirective } from './edit-template.directive';
16
17
  var GanttColumnComponent = /** @class */ (function (_super) {
17
18
  tslib_1.__extends(GanttColumnComponent, _super);
18
19
  function GanttColumnComponent(options, parent) {
@@ -70,6 +71,10 @@ var GanttColumnComponent = /** @class */ (function (_super) {
70
71
  ContentChild(CellTemplateDirective, { static: false }),
71
72
  tslib_1.__metadata("design:type", CellTemplateDirective)
72
73
  ], GanttColumnComponent.prototype, "template", void 0);
74
+ tslib_1.__decorate([
75
+ ContentChild(EditTemplateDirective, { static: false }),
76
+ tslib_1.__metadata("design:type", EditTemplateDirective)
77
+ ], GanttColumnComponent.prototype, "editTemplate", void 0);
73
78
  tslib_1.__decorate([
74
79
  ContentChild(FilterCellTemplateDirective, { static: false }),
75
80
  tslib_1.__metadata("design:type", FilterCellTemplateDirective)
@@ -12,3 +12,4 @@ export { FooterTemplateDirective } from './footer-template.directive';
12
12
  export { ColumnMenuTemplateDirective } from './column-menu-template.directive';
13
13
  export { FilterCellTemplateDirective } from './filter-cell-template.directive';
14
14
  export { FilterMenuTemplateDirective } from './filter-menu-template.directive';
15
+ export { EditTemplateDirective } from './edit-template.directive';
@@ -0,0 +1,34 @@
1
+ /**-----------------------------------------------------------------------------------------
2
+ * Copyright © 2021 Progress Software Corporation. All rights reserved.
3
+ * Licensed under commercial license. See LICENSE.md in the project root for more information
4
+ *-------------------------------------------------------------------------------------------*/
5
+ import * as tslib_1 from "tslib";
6
+ import { Directive, TemplateRef, Optional } from '@angular/core';
7
+ /**
8
+ * Represents the column edit-cell template of the Gantt.
9
+ * Helps to customize the content of the edited cells. To define the cell template, nest an `<ng-template>`
10
+ * tag with the `kendoGanttEditTemplate` directive inside a `<kendo-gantt-column>` tag.
11
+ *
12
+ * The template context contains the following fields:
13
+ * - `column`&mdash;The current column instance.
14
+ * - `dataItem`&mdash;The current data item.
15
+ * - `cellContext`&mdash;An object used to pass context information to built-in directives.
16
+ * - `formGroup`&mdash;The current [`FormGroup`]({{ site.data.urls.angular['formgroupapi'] }}).
17
+ * If you use the Gantt inside [Template-Driven Forms]({{ site.data.urls.angular['forms'] }}), it will be `undefined`.
18
+ * - `isNew`&mdash;The state of the current item.
19
+ * - `rowIndex`&mdash;The current row index. If inside a new item row, `rowIndex` is `-1`.
20
+ */
21
+ var EditTemplateDirective = /** @class */ (function () {
22
+ function EditTemplateDirective(templateRef) {
23
+ this.templateRef = templateRef;
24
+ }
25
+ EditTemplateDirective = tslib_1.__decorate([
26
+ Directive({
27
+ selector: '[kendoGanttEditTemplate]'
28
+ }),
29
+ tslib_1.__param(0, Optional()),
30
+ tslib_1.__metadata("design:paramtypes", [TemplateRef])
31
+ ], EditTemplateDirective);
32
+ return EditTemplateDirective;
33
+ }());
34
+ export { EditTemplateDirective };
@@ -9,6 +9,7 @@ import { OptionChangesService } from '../common/option-changes.service';
9
9
  import { CellTemplateDirective } from './cell-template.directive';
10
10
  import { GanttColumnBase } from './column-base';
11
11
  import { GanttColumnComponent } from './column.component';
12
+ import { EditTemplateDirective } from './edit-template.directive';
12
13
  var GanttSpanColumnComponent = /** @class */ (function (_super) {
13
14
  tslib_1.__extends(GanttSpanColumnComponent, _super);
14
15
  function GanttSpanColumnComponent(options, parent) {
@@ -19,6 +20,7 @@ var GanttSpanColumnComponent = /** @class */ (function (_super) {
19
20
  */
20
21
  _this.childColumns = new QueryList();
21
22
  _this.template = new QueryList();
23
+ _this.editTemplate = new QueryList();
22
24
  return _this;
23
25
  }
24
26
  GanttSpanColumnComponent_1 = GanttSpanColumnComponent;
@@ -34,6 +36,10 @@ var GanttSpanColumnComponent = /** @class */ (function (_super) {
34
36
  ContentChildren(CellTemplateDirective, { descendants: false }),
35
37
  tslib_1.__metadata("design:type", QueryList)
36
38
  ], GanttSpanColumnComponent.prototype, "template", void 0);
39
+ tslib_1.__decorate([
40
+ ContentChildren(EditTemplateDirective, { descendants: false }),
41
+ tslib_1.__metadata("design:type", QueryList)
42
+ ], GanttSpanColumnComponent.prototype, "editTemplate", void 0);
37
43
  tslib_1.__decorate([
38
44
  Input(),
39
45
  tslib_1.__metadata("design:type", Boolean)
@@ -19,3 +19,7 @@ export var rowClassCallback = function () { return null; };
19
19
  * @hidden
20
20
  */
21
21
  export var taskClassCallback = function () { return null; };
22
+ /**
23
+ * @hidden
24
+ */
25
+ export var isSelected = function () { return false; };
@@ -0,0 +1,44 @@
1
+ /**-----------------------------------------------------------------------------------------
2
+ * Copyright © 2021 Progress Software Corporation. All rights reserved.
3
+ * Licensed under commercial license. See LICENSE.md in the project root for more information
4
+ *-------------------------------------------------------------------------------------------*/
5
+ import * as tslib_1 from "tslib";
6
+ import { Component, Input } from '@angular/core';
7
+ import { FormGroup } from '@angular/forms';
8
+ import { LocalizationService } from '@progress/kendo-angular-l10n';
9
+ import { MappingService } from '../common/mapping.service';
10
+ import { EditService } from './edit.service';
11
+ /**
12
+ * @hidden
13
+ */
14
+ var EditDialogComponent = /** @class */ (function () {
15
+ function EditDialogComponent(mapper, editService, localizationService) {
16
+ this.mapper = mapper;
17
+ this.editService = editService;
18
+ this.localizationService = localizationService;
19
+ }
20
+ EditDialogComponent.prototype.getText = function (token) {
21
+ return this.localizationService.get(token);
22
+ };
23
+ EditDialogComponent.prototype.handleEditingResult = function (editResultType) {
24
+ this.editService.triggerEditEvent(editResultType);
25
+ };
26
+ EditDialogComponent.prototype.onTaskDelete = function () {
27
+ this.editService.showConfirmationDialog.next();
28
+ };
29
+ tslib_1.__decorate([
30
+ Input(),
31
+ tslib_1.__metadata("design:type", FormGroup)
32
+ ], EditDialogComponent.prototype, "formGroup", void 0);
33
+ EditDialogComponent = tslib_1.__decorate([
34
+ Component({
35
+ selector: 'kendo-gantt-edit-dialog',
36
+ template: "\n <kendo-dialog\n [title]=\"getText('taskEditingDialogTitle')\"\n [width]=\"575\"\n [height]=\"470\"\n (close)=\"handleEditingResult('cancel')\">\n <kendo-dialog-messages\n [closeTitle]=\"getText('taskEditingDialogCloseTitle')\"></kendo-dialog-messages>\n <form class=\"k-form\" [formGroup]=\"formGroup\">\n <kendo-formfield *ngIf=\"formGroup.contains(mapper.taskFields.title)\">\n <kendo-label [for]=\"mapper.taskFields.title\" [text]=\"getText('titleFieldInputLabel')\"></kendo-label>\n <input class=\"k-textbox\" [formControlName]=\"mapper.taskFields.title\" />\n </kendo-formfield>\n <div class=\"k-hstack\">\n <kendo-formfield [style.width.%]=\"49\" *ngIf=\"formGroup.contains(mapper.taskFields.start)\">\n <kendo-label [for]=\"mapper.taskFields.start\" [text]=\"getText('startFieldInputLabel')\"></kendo-label>\n <kendo-datetimepicker [formControlName]=\"mapper.taskFields.start\"></kendo-datetimepicker>\n </kendo-formfield>\n <kendo-treelist-spacer></kendo-treelist-spacer>\n <kendo-formfield [style.width.%]=\"49\" *ngIf=\"formGroup.contains(mapper.taskFields.end)\">\n <kendo-label [for]=\"mapper.taskFields.end\" [text]=\"getText('endFieldInputLabel')\"></kendo-label>\n <kendo-datetimepicker [formControlName]=\"mapper.taskFields.end\"></kendo-datetimepicker>\n </kendo-formfield>\n </div>\n <kendo-formfield [style.width.%]=\"49\" *ngIf=\"formGroup.contains(mapper.taskFields.completionRatio)\">\n <kendo-label [for]=\"mapper.taskFields.completionRatio\" [text]=\"getText('completionRatioFieldInputLabel')\"></kendo-label>\n <kendo-numerictextbox\n [formControlName]=\"mapper.taskFields.completionRatio\"\n [min]=\"0\"\n [max]=\"1\"\n [decimals]=\"2\"\n format=\"p2\"\n [step]=\"0.01\"\n ></kendo-numerictextbox>\n </kendo-formfield>\n </form>\n <kendo-dialog-actions layout=\"normal\">\n <button kendoButton (click)=\"onTaskDelete()\">{{ getText('deleteButtonText') }}</button>\n <kendo-treelist-spacer></kendo-treelist-spacer>\n <button kendoButton [primary]=\"true\" (click)=\"handleEditingResult('save')\">{{ getText('saveButtonText') }}</button>\n <button kendoButton (click)=\"handleEditingResult('cancel')\">{{ getText('cancelButtonText') }}</button>\n </kendo-dialog-actions>\n </kendo-dialog>\n "
37
+ }),
38
+ tslib_1.__metadata("design:paramtypes", [MappingService,
39
+ EditService,
40
+ LocalizationService])
41
+ ], EditDialogComponent);
42
+ return EditDialogComponent;
43
+ }());
44
+ export { EditDialogComponent };
@@ -0,0 +1,39 @@
1
+ /**-----------------------------------------------------------------------------------------
2
+ * Copyright © 2021 Progress Software Corporation. All rights reserved.
3
+ * Licensed under commercial license. See LICENSE.md in the project root for more information
4
+ *-------------------------------------------------------------------------------------------*/
5
+ import * as tslib_1 from "tslib";
6
+ import { Injectable } from '@angular/core';
7
+ import { Subject } from 'rxjs';
8
+ /**
9
+ * @hidden
10
+ */
11
+ var EditService = /** @class */ (function () {
12
+ function EditService() {
13
+ this.showEditingDialog = new Subject();
14
+ this.showConfirmationDialog = new Subject();
15
+ this.editEvent = new Subject();
16
+ }
17
+ EditService.prototype.createEditDialog = function (dataItem, formGroup) {
18
+ this.dataItem = dataItem;
19
+ this.formGroup = formGroup;
20
+ this.showEditingDialog.next(true);
21
+ };
22
+ EditService.prototype.closeEditDialog = function () {
23
+ this.showEditingDialog.next(false);
24
+ this.dataItem = undefined;
25
+ this.formGroup = undefined;
26
+ };
27
+ EditService.prototype.triggerEditEvent = function (editResultType) {
28
+ this.editEvent.next({
29
+ formGroup: this.formGroup,
30
+ dataItem: this.dataItem,
31
+ editResultType: editResultType
32
+ });
33
+ };
34
+ EditService = tslib_1.__decorate([
35
+ Injectable()
36
+ ], EditService);
37
+ return EditService;
38
+ }());
39
+ export { EditService };
@@ -0,0 +1,17 @@
1
+ /**-----------------------------------------------------------------------------------------
2
+ * Copyright © 2021 Progress Software Corporation. All rights reserved.
3
+ * Licensed under commercial license. See LICENSE.md in the project root for more information
4
+ *-------------------------------------------------------------------------------------------*/
5
+ /**
6
+ * @hidden
7
+ */
8
+ export var getEditItem = function (dataItem, data, mapper) {
9
+ var treeListDataItem = data.find(function (item) { return mapper.extractFromTask(item.data, 'id') === mapper.extractFromTask(dataItem, 'id'); });
10
+ return mapPath(treeListDataItem);
11
+ };
12
+ var mapPath = function (item) { return ({
13
+ dataItem: item.data,
14
+ parent: item.parent.data ? mapPath(item.parent) : null
15
+ }); };
16
+ var ɵ0 = mapPath;
17
+ export { ɵ0 };