@progress/kendo-angular-gantt 0.2.1-dev.202112101349 → 0.3.0-dev.202201190830

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 (171) hide show
  1. package/dist/cdn/js/kendo-angular-gantt.js +2 -2
  2. package/dist/cdn/main.js +4 -4
  3. package/dist/es/common/touch-enabled.js +9 -0
  4. package/dist/es/dependencies/utils.js +40 -5
  5. package/dist/es/dragging/dependency-drag-create.directive.js +347 -0
  6. package/dist/es/dragging/drag-validation-tooltip.component.js +27 -0
  7. package/dist/es/editing/add-task.component.js +94 -0
  8. package/dist/es/editing/dependencies-table.component.js +131 -0
  9. package/dist/es/editing/edit-dialog.component.js +39 -8
  10. package/dist/es/editing/edit.service.js +92 -8
  11. package/dist/es/editing/task-fields.component.js +43 -0
  12. package/dist/es/editing/{util.js → utils.js} +0 -0
  13. package/dist/es/gantt.component.js +408 -56
  14. package/dist/es/gantt.module.js +37 -9
  15. package/dist/es/index.js +9 -0
  16. package/dist/es/localization/gantt-localization.service.js +26 -0
  17. package/dist/es/localization/messages.js +45 -1
  18. package/dist/es/main.js +1 -0
  19. package/dist/es/models/dependency-type.enum.js +16 -0
  20. package/dist/es/models/events/{add-event.interface.js → dependency-add-event.interface.js} +0 -0
  21. package/dist/es/models/events/{edit-event.interface.js → task-add-event.interface.js} +0 -0
  22. package/dist/es/models/events/{remove-event.interface.js → task-delete-event.interface.js} +0 -0
  23. package/dist/es/models/models.js +1 -0
  24. package/dist/es/models/{toolbar-position.js → toolbar-settings.js} +0 -0
  25. package/dist/{es2015/models/events/add-event.interface.js → es/models/view-item.interface.js} +0 -0
  26. package/dist/{es2015/models/events/edit-event.interface.js → es/navigation/navigation-models.js} +0 -0
  27. package/dist/es/navigation/navigation.service.js +390 -0
  28. package/dist/es/navigation/utils.js +77 -0
  29. package/dist/es/package-metadata.js +1 -1
  30. package/dist/es/rendering/gantt-milestone-task.component.js +12 -6
  31. package/dist/es/rendering/gantt-summary-task.component.js +27 -6
  32. package/dist/es/rendering/gantt-task-base.js +84 -22
  33. package/dist/es/rendering/gantt-task.component.js +13 -8
  34. package/dist/es/rendering/gantt-tasks-table-body.component.js +13 -5
  35. package/dist/es/scrolling/drag-scroll-settings.js +20 -0
  36. package/dist/es/scrolling/timeline-scroll.directive.js +89 -0
  37. package/dist/es/scrolling/timeline-scroll.service.js +39 -0
  38. package/dist/es/scrolling/utils.js +80 -0
  39. package/dist/es/timeline/gantt-timeline.component.js +50 -4
  40. package/dist/es/toolbar/toolbar.component.js +20 -13
  41. package/dist/es/toolbar/view-selector.component.js +1 -1
  42. package/dist/es/utils.js +153 -12
  43. package/dist/es2015/common/touch-enabled.d.ts +9 -0
  44. package/dist/es2015/common/touch-enabled.js +9 -0
  45. package/dist/es2015/dependencies/utils.d.ts +15 -0
  46. package/dist/es2015/dependencies/utils.js +40 -5
  47. package/dist/es2015/dragging/dependency-drag-create.directive.d.ts +72 -0
  48. package/dist/es2015/dragging/dependency-drag-create.directive.js +324 -0
  49. package/dist/es2015/dragging/drag-validation-tooltip.component.d.ts +29 -0
  50. package/dist/es2015/dragging/drag-validation-tooltip.component.js +76 -0
  51. package/dist/es2015/editing/add-task.component.d.ts +45 -0
  52. package/dist/es2015/editing/add-task.component.js +102 -0
  53. package/dist/es2015/editing/dependencies-table.component.d.ts +39 -0
  54. package/dist/es2015/editing/dependencies-table.component.js +160 -0
  55. package/dist/es2015/editing/edit-dialog.component.d.ts +11 -4
  56. package/dist/es2015/editing/edit-dialog.component.js +66 -36
  57. package/dist/es2015/editing/edit.service.d.ts +24 -4
  58. package/dist/es2015/editing/edit.service.js +81 -11
  59. package/dist/es2015/editing/task-fields.component.d.ts +22 -0
  60. package/dist/es2015/editing/task-fields.component.js +67 -0
  61. package/dist/es2015/editing/{util.d.ts → utils.d.ts} +2 -2
  62. package/dist/es2015/editing/{util.js → utils.js} +0 -0
  63. package/dist/es2015/gantt.component.d.ts +134 -31
  64. package/dist/es2015/gantt.component.js +419 -61
  65. package/dist/es2015/gantt.module.js +37 -9
  66. package/dist/es2015/index.d.ts +9 -0
  67. package/dist/es2015/index.js +9 -0
  68. package/dist/es2015/index.metadata.json +1 -1
  69. package/dist/es2015/{models/events/edit-event.interface.d.ts → localization/gantt-localization.service.d.ts} +6 -10
  70. package/dist/es2015/localization/gantt-localization.service.js +25 -0
  71. package/dist/es2015/localization/messages.d.ts +46 -2
  72. package/dist/es2015/localization/messages.js +45 -1
  73. package/dist/es2015/main.d.ts +1 -0
  74. package/dist/es2015/main.js +1 -0
  75. package/dist/es2015/models/dependency-type.enum.d.ts +1 -1
  76. package/dist/es2015/models/dependency-type.enum.js +16 -0
  77. package/dist/es2015/models/events/dependency-add-event.interface.d.ts +26 -0
  78. package/dist/es2015/models/events/{remove-event.interface.js → dependency-add-event.interface.js} +0 -0
  79. package/dist/es2015/models/events/task-add-event.interface.d.ts +31 -0
  80. package/dist/es2015/models/{toolbar-position.js → events/task-add-event.interface.js} +0 -0
  81. package/dist/es2015/models/events/task-click-event.interface.d.ts +3 -3
  82. package/dist/es2015/models/events/task-delete-event.interface.d.ts +21 -0
  83. package/dist/es2015/models/events/task-delete-event.interface.js +4 -0
  84. package/dist/es2015/models/events/task-edit-event.interface.d.ts +36 -6
  85. package/dist/es2015/models/models.d.ts +6 -3
  86. package/dist/es2015/models/models.js +1 -0
  87. package/dist/es2015/models/toolbar-settings.d.ts +29 -0
  88. package/dist/es2015/models/toolbar-settings.js +4 -0
  89. package/dist/es2015/models/view-item.interface.d.ts +35 -0
  90. package/dist/es2015/models/view-item.interface.js +4 -0
  91. package/dist/es2015/navigation/navigation-models.d.ts +34 -0
  92. package/dist/es2015/navigation/navigation-models.js +4 -0
  93. package/dist/es2015/navigation/navigation.service.d.ts +126 -0
  94. package/dist/es2015/navigation/navigation.service.js +355 -0
  95. package/dist/es2015/navigation/utils.d.ts +26 -0
  96. package/dist/es2015/navigation/utils.js +69 -0
  97. package/dist/es2015/package-metadata.js +1 -1
  98. package/dist/es2015/rendering/gantt-milestone-task.component.d.ts +3 -1
  99. package/dist/es2015/rendering/gantt-milestone-task.component.js +35 -8
  100. package/dist/es2015/rendering/gantt-summary-task.component.d.ts +5 -1
  101. package/dist/es2015/rendering/gantt-summary-task.component.js +47 -8
  102. package/dist/es2015/rendering/gantt-task-base.d.ts +20 -6
  103. package/dist/es2015/rendering/gantt-task-base.js +75 -22
  104. package/dist/es2015/rendering/gantt-task.component.d.ts +4 -2
  105. package/dist/es2015/rendering/gantt-task.component.js +47 -13
  106. package/dist/es2015/rendering/gantt-tasks-table-body.component.d.ts +6 -3
  107. package/dist/es2015/rendering/gantt-tasks-table-body.component.js +27 -9
  108. package/dist/es2015/scrolling/drag-scroll-settings.d.ts +47 -0
  109. package/dist/es2015/scrolling/drag-scroll-settings.js +20 -0
  110. package/dist/es2015/scrolling/scroll-sync.service.d.ts +1 -1
  111. package/dist/es2015/scrolling/timeline-scroll.directive.d.ts +24 -0
  112. package/dist/es2015/scrolling/timeline-scroll.directive.js +78 -0
  113. package/dist/es2015/scrolling/timeline-scroll.service.d.ts +20 -0
  114. package/dist/es2015/scrolling/timeline-scroll.service.js +44 -0
  115. package/dist/es2015/scrolling/utils.d.ts +29 -0
  116. package/dist/es2015/scrolling/utils.js +80 -0
  117. package/dist/es2015/timeline/gantt-timeline.component.d.ts +29 -4
  118. package/dist/es2015/timeline/gantt-timeline.component.js +67 -5
  119. package/dist/es2015/toolbar/toolbar-template.directive.d.ts +1 -1
  120. package/dist/es2015/toolbar/toolbar.component.d.ts +6 -5
  121. package/dist/es2015/toolbar/toolbar.component.js +22 -13
  122. package/dist/es2015/toolbar/view-selector.component.js +3 -1
  123. package/dist/es2015/utils.d.ts +77 -8
  124. package/dist/es2015/utils.js +153 -12
  125. package/dist/fesm2015/index.js +5258 -3012
  126. package/dist/fesm5/index.js +2862 -733
  127. package/dist/npm/common/touch-enabled.js +11 -0
  128. package/dist/npm/dependencies/utils.js +40 -5
  129. package/dist/npm/dragging/dependency-drag-create.directive.js +349 -0
  130. package/dist/npm/dragging/drag-validation-tooltip.component.js +29 -0
  131. package/dist/npm/editing/add-task.component.js +96 -0
  132. package/dist/npm/editing/dependencies-table.component.js +133 -0
  133. package/dist/npm/editing/edit-dialog.component.js +38 -7
  134. package/dist/npm/editing/edit.service.js +91 -7
  135. package/dist/npm/editing/task-fields.component.js +45 -0
  136. package/dist/npm/editing/{util.js → utils.js} +0 -0
  137. package/dist/npm/gantt.component.js +409 -57
  138. package/dist/npm/gantt.module.js +35 -7
  139. package/dist/npm/index.js +18 -0
  140. package/dist/npm/localization/gantt-localization.service.js +28 -0
  141. package/dist/npm/localization/messages.js +45 -1
  142. package/dist/npm/main.js +2 -0
  143. package/dist/npm/models/dependency-type.enum.js +16 -0
  144. package/dist/npm/models/events/{add-event.interface.js → dependency-add-event.interface.js} +0 -0
  145. package/dist/npm/models/events/{edit-event.interface.js → task-add-event.interface.js} +0 -0
  146. package/dist/npm/models/events/{remove-event.interface.js → task-delete-event.interface.js} +0 -0
  147. package/dist/npm/models/models.js +2 -0
  148. package/dist/npm/models/{toolbar-position.js → toolbar-settings.js} +0 -0
  149. package/dist/npm/models/view-item.interface.js +6 -0
  150. package/dist/npm/navigation/navigation-models.js +6 -0
  151. package/dist/npm/navigation/navigation.service.js +392 -0
  152. package/dist/npm/navigation/utils.js +79 -0
  153. package/dist/npm/package-metadata.js +1 -1
  154. package/dist/npm/rendering/gantt-milestone-task.component.js +11 -5
  155. package/dist/npm/rendering/gantt-summary-task.component.js +26 -5
  156. package/dist/npm/rendering/gantt-task-base.js +84 -22
  157. package/dist/npm/rendering/gantt-task.component.js +12 -7
  158. package/dist/npm/rendering/gantt-tasks-table-body.component.js +13 -5
  159. package/dist/npm/scrolling/drag-scroll-settings.js +22 -0
  160. package/dist/npm/scrolling/timeline-scroll.directive.js +91 -0
  161. package/dist/npm/scrolling/timeline-scroll.service.js +41 -0
  162. package/dist/npm/scrolling/utils.js +83 -0
  163. package/dist/npm/timeline/gantt-timeline.component.js +49 -3
  164. package/dist/npm/toolbar/toolbar.component.js +18 -11
  165. package/dist/npm/toolbar/view-selector.component.js +1 -1
  166. package/dist/npm/utils.js +153 -12
  167. package/dist/systemjs/kendo-angular-gantt.js +1 -1
  168. package/package.json +7 -4
  169. package/dist/es2015/models/events/add-event.interface.d.ts +0 -16
  170. package/dist/es2015/models/events/remove-event.interface.d.ts +0 -16
  171. package/dist/es2015/models/toolbar-position.d.ts +0 -9
@@ -0,0 +1,133 @@
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
+ "use strict";
6
+ Object.defineProperty(exports, "__esModule", { value: true });
7
+ var tslib_1 = require("tslib");
8
+ var core_1 = require("@angular/core");
9
+ var forms_1 = require("@angular/forms");
10
+ var mapping_service_1 = require("../common/mapping.service");
11
+ var gantt_localization_service_1 = require("../localization/gantt-localization.service");
12
+ var dependency_type_enum_1 = require("../models/dependency-type.enum");
13
+ var edit_service_1 = require("./edit.service");
14
+ /**
15
+ * @hidden
16
+ */
17
+ var DependenciesTableComponent = /** @class */ (function () {
18
+ function DependenciesTableComponent(mapper, editService, localizationService) {
19
+ this.mapper = mapper;
20
+ this.editService = editService;
21
+ this.localizationService = localizationService;
22
+ this.dependenciesChange = new core_1.EventEmitter();
23
+ this.selectedKeys = [];
24
+ this.formGroups = new forms_1.FormArray([]);
25
+ this.dependencyTypes = this.getDependencyTypes();
26
+ }
27
+ Object.defineProperty(DependenciesTableComponent.prototype, "taskId", {
28
+ get: function () {
29
+ return this.editService.dataItem.id;
30
+ },
31
+ enumerable: true,
32
+ configurable: true
33
+ });
34
+ Object.defineProperty(DependenciesTableComponent.prototype, "dependencyIdField", {
35
+ // The target dependency id field
36
+ // e.g. if Predecessors, we have the `fromId` which is the currently edited task,
37
+ // while the `toId` is missing (needs to be selected by the user)
38
+ get: function () {
39
+ return this.dependencyType === 'predecessor' ? 'fromId' : 'toId';
40
+ },
41
+ enumerable: true,
42
+ configurable: true
43
+ });
44
+ DependenciesTableComponent.prototype.ngOnInit = function () {
45
+ var _this = this;
46
+ // generate the FormGroups per each Grid row
47
+ if (this.formGroups.controls.length === 0) {
48
+ var fields_1 = this.mapper.dependencyFields;
49
+ this.dependencies.forEach(function (item) {
50
+ var _a;
51
+ var formGroup = new forms_1.FormGroup((_a = {},
52
+ _a[fields_1.id] = new forms_1.FormControl(_this.mapper.extractFromDependency(item, 'id')),
53
+ _a[fields_1.fromId] = new forms_1.FormControl(_this.mapper.extractFromDependency(item, 'fromId'), forms_1.Validators.required),
54
+ _a[fields_1.toId] = new forms_1.FormControl(_this.mapper.extractFromDependency(item, 'toId'), forms_1.Validators.required),
55
+ _a[fields_1.type] = new forms_1.FormControl(_this.mapper.extractFromDependency(item, 'type'), forms_1.Validators.required),
56
+ _a));
57
+ _this.formGroups.push(formGroup);
58
+ });
59
+ }
60
+ this.formGroups.valueChanges.subscribe(function (val) {
61
+ _this.formGroups.controls.forEach(function (control) {
62
+ if (control.dirty) {
63
+ _this.editService.updateDependencies(control.value);
64
+ }
65
+ });
66
+ _this.dependenciesChange.emit(val);
67
+ });
68
+ };
69
+ DependenciesTableComponent.prototype.getFormControl = function (dataItemIndex, field) {
70
+ // return the FormControl for the respective column editor
71
+ return this.formGroups.controls
72
+ .find(function (_control, index) { return index === dataItemIndex; })
73
+ .get(this.mapper.dependencyFields[field]);
74
+ };
75
+ DependenciesTableComponent.prototype.getText = function (token) {
76
+ return this.localizationService.get(token);
77
+ };
78
+ DependenciesTableComponent.prototype.getDependencyTypes = function () {
79
+ var types = Object.keys(dependency_type_enum_1.DependencyType)
80
+ .filter(function (value) { return typeof dependency_type_enum_1.DependencyType[value] === 'number'; })
81
+ .map(function (type) {
82
+ return {
83
+ type: type,
84
+ id: dependency_type_enum_1.DependencyType[type]
85
+ };
86
+ });
87
+ return types;
88
+ };
89
+ DependenciesTableComponent.prototype.addHandler = function () {
90
+ var _a;
91
+ var fields = this.mapper.dependencyFields;
92
+ var formGroup = new forms_1.FormGroup((_a = {},
93
+ _a[fields.id] = new forms_1.FormControl(),
94
+ _a[fields.fromId] = new forms_1.FormControl(this.dependencyIdField === 'toId' ? this.taskId : null, forms_1.Validators.required),
95
+ _a[fields.toId] = new forms_1.FormControl(this.dependencyIdField === 'fromId' ? this.taskId : null, forms_1.Validators.required),
96
+ _a[fields.type] = new forms_1.FormControl(null, forms_1.Validators.required),
97
+ _a));
98
+ this.formGroups.push(formGroup);
99
+ };
100
+ DependenciesTableComponent.prototype.removeHandler = function () {
101
+ var selectedIndex = this.selectedKeys[0];
102
+ var item = this.formGroups.at(selectedIndex).value;
103
+ this.editService.deleteDependency(item);
104
+ this.formGroups.removeAt(selectedIndex);
105
+ };
106
+ tslib_1.__decorate([
107
+ core_1.Input(),
108
+ tslib_1.__metadata("design:type", Array)
109
+ ], DependenciesTableComponent.prototype, "tasks", void 0);
110
+ tslib_1.__decorate([
111
+ core_1.Input(),
112
+ tslib_1.__metadata("design:type", Array)
113
+ ], DependenciesTableComponent.prototype, "dependencies", void 0);
114
+ tslib_1.__decorate([
115
+ core_1.Input(),
116
+ tslib_1.__metadata("design:type", String)
117
+ ], DependenciesTableComponent.prototype, "dependencyType", void 0);
118
+ tslib_1.__decorate([
119
+ core_1.Output(),
120
+ tslib_1.__metadata("design:type", core_1.EventEmitter)
121
+ ], DependenciesTableComponent.prototype, "dependenciesChange", void 0);
122
+ DependenciesTableComponent = tslib_1.__decorate([
123
+ core_1.Component({
124
+ selector: 'kendo-gantt-dependencies-table',
125
+ template: "\n <kendo-grid\n [data]=\"dependencies\"\n [selectable]=\"{ mode: 'single' }\"\n [(selectedKeys)]=\"selectedKeys\"\n kendoGridSelectBy\n [height]=\"295\"\n >\n <ng-template kendoGridToolbarTemplate>\n <button kendoButton (click)=\"addHandler()\">\n {{ getText('taskEditingDependenciesAddButtonText') }}\n </button>\n <button kendoButton (click)=\"removeHandler()\" [disabled]=\"selectedKeys.length === 0\">\n {{ getText('taskEditingDependenciesRemoveButtonText') }}\n </button>\n </ng-template>\n <kendo-grid-column [title]=\"getText('taskEditingDependenciesGridNameColumnTitle')\" [field]=\"dependencyIdField\">\n <ng-template kendoGridCellTemplate let-dataItem=\"dataItem\" let-column=\"column\" let-rowIndex=\"rowIndex\">\n <kendo-dropdownlist\n [data]=\"tasks\"\n textField=\"title\"\n valueField=\"id\"\n [valuePrimitive]=\"true\"\n [formControl]=\"getFormControl(rowIndex, column.field)\"\n >\n </kendo-dropdownlist>\n </ng-template>\n </kendo-grid-column>\n <kendo-grid-column [title]=\"getText('taskEditingDependenciesGridTypeColumnTitle')\" field=\"type\">\n <ng-template kendoGridCellTemplate let-dataItem=\"dataItem\" let-column=\"column\" let-rowIndex=\"rowIndex\">\n <kendo-dropdownlist\n [data]=\"dependencyTypes\"\n textField=\"type\"\n valueField=\"id\"\n [valuePrimitive]=\"true\"\n [formControl]=\"getFormControl(rowIndex, column.field)\"\n >\n </kendo-dropdownlist>\n </ng-template>\n </kendo-grid-column>\n </kendo-grid>\n "
126
+ }),
127
+ tslib_1.__metadata("design:paramtypes", [mapping_service_1.MappingService,
128
+ edit_service_1.EditService,
129
+ gantt_localization_service_1.GanttLocalizationService])
130
+ ], DependenciesTableComponent);
131
+ return DependenciesTableComponent;
132
+ }());
133
+ exports.DependenciesTableComponent = DependenciesTableComponent;
@@ -6,39 +6,70 @@
6
6
  Object.defineProperty(exports, "__esModule", { value: true });
7
7
  var tslib_1 = require("tslib");
8
8
  var core_1 = require("@angular/core");
9
- var forms_1 = require("@angular/forms");
10
9
  var kendo_angular_l10n_1 = require("@progress/kendo-angular-l10n");
11
10
  var mapping_service_1 = require("../common/mapping.service");
11
+ var dependency_type_enum_1 = require("../models/dependency-type.enum");
12
12
  var edit_service_1 = require("./edit.service");
13
13
  /**
14
14
  * @hidden
15
15
  */
16
16
  var EditDialogComponent = /** @class */ (function () {
17
- function EditDialogComponent(mapper, editService, localizationService) {
17
+ function EditDialogComponent(mapper, editService, cdr, localizationService) {
18
18
  this.mapper = mapper;
19
19
  this.editService = editService;
20
+ this.cdr = cdr;
20
21
  this.localizationService = localizationService;
21
22
  }
23
+ EditDialogComponent.prototype.ngOnInit = function () {
24
+ var _this = this;
25
+ this.editService.loadTasks(this.data).subscribe(function (value) {
26
+ _this.loadedTasks = value;
27
+ });
28
+ };
29
+ Object.defineProperty(EditDialogComponent.prototype, "predecessors", {
30
+ get: function () {
31
+ return this.editService.predecessors;
32
+ },
33
+ set: function (items) {
34
+ this.editService.predecessors = items;
35
+ },
36
+ enumerable: true,
37
+ configurable: true
38
+ });
39
+ Object.defineProperty(EditDialogComponent.prototype, "successors", {
40
+ get: function () {
41
+ return this.editService.successors;
42
+ },
43
+ set: function (items) {
44
+ this.editService.successors = items;
45
+ },
46
+ enumerable: true,
47
+ configurable: true
48
+ });
22
49
  EditDialogComponent.prototype.getText = function (token) {
23
50
  return this.localizationService.get(token);
24
51
  };
52
+ EditDialogComponent.prototype.getDependencyType = function (typeId) {
53
+ return dependency_type_enum_1.DependencyType[typeId];
54
+ };
25
55
  EditDialogComponent.prototype.handleEditingResult = function (editResultType) {
26
56
  this.editService.triggerEditEvent(editResultType);
27
57
  };
28
- EditDialogComponent.prototype.onTaskDelete = function () {
29
- this.editService.showConfirmationDialog.next();
58
+ EditDialogComponent.prototype.handleTaskDelete = function () {
59
+ this.editService.taskDelete.next(this.editService.dataItem);
30
60
  };
31
61
  tslib_1.__decorate([
32
62
  core_1.Input(),
33
- tslib_1.__metadata("design:type", forms_1.FormGroup)
34
- ], EditDialogComponent.prototype, "formGroup", void 0);
63
+ tslib_1.__metadata("design:type", Array)
64
+ ], EditDialogComponent.prototype, "data", void 0);
35
65
  EditDialogComponent = tslib_1.__decorate([
36
66
  core_1.Component({
37
67
  selector: 'kendo-gantt-edit-dialog',
38
- 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 "
68
+ 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\n <kendo-tabstrip [keepTabContent]=\"true\">\n <kendo-tabstrip-tab [title]=\"getText('taskEditingGeneralTabTitle')\" [selected]=\"true\">\n <ng-template kendoTabContent>\n <kendo-gantt-task-fields></kendo-gantt-task-fields>\n </ng-template>\n </kendo-tabstrip-tab>\n <kendo-tabstrip-tab [title]=\"getText('taskEditingPredecessorsTabTitle')\">\n <ng-template kendoTabContent>\n <kendo-gantt-dependencies-table\n [tasks]=\"loadedTasks\"\n [(dependencies)]=\"predecessors\"\n dependencyType=\"predecessor\"\n >\n </kendo-gantt-dependencies-table>\n </ng-template>\n </kendo-tabstrip-tab>\n <kendo-tabstrip-tab [title]=\"getText('taskEditingSuccessorsTabTitle')\">\n <ng-template kendoTabContent>\n <kendo-gantt-dependencies-table\n [tasks]=\"loadedTasks\"\n [(dependencies)]=\"successors\"\n dependencyType=\"successor\">\n </kendo-gantt-dependencies-table>\n </ng-template>\n </kendo-tabstrip-tab>\n </kendo-tabstrip>\n\n <kendo-dialog-actions layout=\"normal\">\n <button\n kendoButton\n [kendoEventsOutsideAngular]=\"{\n click: handleTaskDelete\n }\"\n [scope]=\"this\"\n >\n {{ getText('deleteButtonText') }}\n </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 "
39
69
  }),
40
70
  tslib_1.__metadata("design:paramtypes", [mapping_service_1.MappingService,
41
71
  edit_service_1.EditService,
72
+ core_1.ChangeDetectorRef,
42
73
  kendo_angular_l10n_1.LocalizationService])
43
74
  ], EditDialogComponent);
44
75
  return EditDialogComponent;
@@ -7,34 +7,118 @@ Object.defineProperty(exports, "__esModule", { value: true });
7
7
  var tslib_1 = require("tslib");
8
8
  var core_1 = require("@angular/core");
9
9
  var rxjs_1 = require("rxjs");
10
+ var operators_1 = require("rxjs/operators");
11
+ var mapping_service_1 = require("../common/mapping.service");
12
+ var utils_1 = require("../utils");
10
13
  /**
11
14
  * @hidden
12
15
  */
13
16
  var EditService = /** @class */ (function () {
14
- function EditService() {
17
+ function EditService(mapper) {
18
+ var _this = this;
19
+ this.mapper = mapper;
15
20
  this.showEditingDialog = new rxjs_1.Subject();
16
- this.showConfirmationDialog = new rxjs_1.Subject();
21
+ this.taskDelete = new rxjs_1.Subject();
17
22
  this.editEvent = new rxjs_1.Subject();
23
+ this.addEvent = new rxjs_1.Subject();
24
+ this.predecessors = [];
25
+ this.successors = [];
26
+ this.updatedItems = [];
27
+ this.deletedItems = [];
28
+ this.itemIndex = function (item, data) {
29
+ return data.findIndex(function (dataItem) { return _this.mapper.extractFromTask(dataItem, 'id') === _this.mapper.extractFromTask(item, 'id'); });
30
+ };
18
31
  }
19
- EditService.prototype.createEditDialog = function (dataItem, formGroup) {
32
+ Object.defineProperty(EditService.prototype, "dependencies", {
33
+ get: function () {
34
+ return this.predecessors.concat(this.successors);
35
+ },
36
+ set: function (items) {
37
+ var _this = this;
38
+ // Can this whole thing be moved to edit-dialog? Dependencies might not be needed here
39
+ var dataItemId = this.mapper.extractFromTask(this.dataItem, 'id');
40
+ this.predecessors = items.filter(function (item) { return _this.mapper.extractFromDependency(item, 'toId') === dataItemId; });
41
+ this.successors = items.filter(function (item) { return _this.mapper.extractFromDependency(item, 'fromId') === dataItemId; });
42
+ },
43
+ enumerable: true,
44
+ configurable: true
45
+ });
46
+ EditService.prototype.createEditDialog = function (dataItem, taskFormGroup, dependencies) {
20
47
  this.dataItem = dataItem;
21
- this.formGroup = formGroup;
48
+ this.taskFormGroup = taskFormGroup;
49
+ this.dependencies = dependencies;
22
50
  this.showEditingDialog.next(true);
23
51
  };
24
52
  EditService.prototype.closeEditDialog = function () {
25
53
  this.showEditingDialog.next(false);
26
54
  this.dataItem = undefined;
27
- this.formGroup = undefined;
55
+ this.taskFormGroup = undefined;
56
+ this.dependencies = [];
57
+ this.updatedItems = [];
58
+ this.deletedItems = [];
28
59
  };
29
60
  EditService.prototype.triggerEditEvent = function (editResultType) {
30
61
  this.editEvent.next({
31
- formGroup: this.formGroup,
62
+ taskFormGroup: this.taskFormGroup,
32
63
  dataItem: this.dataItem,
64
+ dependencies: {
65
+ createdItems: this.getCreatedDependencies(),
66
+ updatedItems: this.updatedItems,
67
+ deletedItems: this.deletedItems
68
+ },
33
69
  editResultType: editResultType
34
70
  });
35
71
  };
72
+ EditService.prototype.updateDependencies = function (item) {
73
+ if (!this.isNew(item)) {
74
+ // update
75
+ var index = this.itemIndex(item, this.updatedItems);
76
+ if (index !== -1) {
77
+ this.updatedItems.splice(index, 1, item);
78
+ }
79
+ else {
80
+ this.updatedItems.push(item);
81
+ }
82
+ }
83
+ };
84
+ EditService.prototype.getCreatedDependencies = function () {
85
+ var _this = this;
86
+ return this.dependencies.filter(function (item) { return _this.mapper.extractFromDependency(item, 'id') === null; });
87
+ };
88
+ EditService.prototype.deleteDependency = function (item) {
89
+ var updatedIndex = this.itemIndex(item, this.updatedItems);
90
+ if (updatedIndex !== -1) {
91
+ this.updatedItems.splice(updatedIndex, 1);
92
+ }
93
+ if (!this.isNew(item)) {
94
+ this.deletedItems.push(item);
95
+ }
96
+ };
97
+ EditService.prototype.loadTasks = function (initialValues, isInitializer) {
98
+ var _this = this;
99
+ if (isInitializer === void 0) { isInitializer = true; }
100
+ return rxjs_1.forkJoin(initialValues.map(function (v) { return _this.getElementById(v); })).pipe(operators_1.map(function (value) {
101
+ return value.reduce(function (acc, item) { return acc = acc.concat(utils_1.normalizeGanttData(item)); }, []);
102
+ }), operators_1.expand(function (values) {
103
+ if (values.some(function (el) { return _this.hasChildren(el); })) {
104
+ return _this.loadTasks(values, false);
105
+ }
106
+ return rxjs_1.EMPTY;
107
+ }), operators_1.reduce(function (acc, values) { return acc.concat(values); }, isInitializer ? initialValues.slice() : []));
108
+ };
109
+ EditService.prototype.getElementById = function (item) {
110
+ var children = this.fetchChildren(item);
111
+ if (rxjs_1.isObservable(children)) {
112
+ return children;
113
+ }
114
+ return rxjs_1.of(children);
115
+ };
116
+ EditService.prototype.isNew = function (item) {
117
+ return !utils_1.isPresent(this.mapper.extractFromDependency(item, 'id'));
118
+ };
36
119
  EditService = tslib_1.__decorate([
37
- core_1.Injectable()
120
+ core_1.Injectable(),
121
+ tslib_1.__metadata("design:paramtypes", [mapping_service_1.MappingService])
38
122
  ], EditService);
39
123
  return EditService;
40
124
  }());
@@ -0,0 +1,45 @@
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
+ "use strict";
6
+ Object.defineProperty(exports, "__esModule", { value: true });
7
+ var tslib_1 = require("tslib");
8
+ var core_1 = require("@angular/core");
9
+ var mapping_service_1 = require("../common/mapping.service");
10
+ var gantt_localization_service_1 = require("../localization/gantt-localization.service");
11
+ var edit_service_1 = require("./edit.service");
12
+ /**
13
+ * @hidden
14
+ */
15
+ var TaskFieldsComponent = /** @class */ (function () {
16
+ function TaskFieldsComponent(mapper, editService, localizationService) {
17
+ this.mapper = mapper;
18
+ this.editService = editService;
19
+ this.localizationService = localizationService;
20
+ }
21
+ Object.defineProperty(TaskFieldsComponent.prototype, "formGroup", {
22
+ /**
23
+ * @hidden
24
+ */
25
+ get: function () {
26
+ return this.editService.taskFormGroup;
27
+ },
28
+ enumerable: true,
29
+ configurable: true
30
+ });
31
+ TaskFieldsComponent.prototype.getText = function (token) {
32
+ return this.localizationService.get(token);
33
+ };
34
+ TaskFieldsComponent = tslib_1.__decorate([
35
+ core_1.Component({
36
+ selector: 'kendo-gantt-task-fields',
37
+ template: "\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 "
38
+ }),
39
+ tslib_1.__metadata("design:paramtypes", [mapping_service_1.MappingService,
40
+ edit_service_1.EditService,
41
+ gantt_localization_service_1.GanttLocalizationService])
42
+ ], TaskFieldsComponent);
43
+ return TaskFieldsComponent;
44
+ }());
45
+ exports.TaskFieldsComponent = TaskFieldsComponent;
File without changes