@worktile/gantt 18.1.0-next.1 → 19.0.0-next.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 (75) hide show
  1. package/components/main/gantt-main.component.d.ts +4 -3
  2. package/fesm2022/worktile-gantt.mjs +132 -117
  3. package/fesm2022/worktile-gantt.mjs.map +1 -1
  4. package/gantt-item-upper.d.ts +1 -1
  5. package/gantt-upper.d.ts +1 -1
  6. package/gantt.module.d.ts +1 -1
  7. package/gantt.pipe.d.ts +6 -1
  8. package/package.json +1 -3
  9. package/views/factory.d.ts +1 -1
  10. package/esm2022/class/baseline.mjs +0 -18
  11. package/esm2022/class/date-point.mjs +0 -11
  12. package/esm2022/class/event.mjs +0 -27
  13. package/esm2022/class/group.mjs +0 -17
  14. package/esm2022/class/index.mjs +0 -9
  15. package/esm2022/class/item.mjs +0 -85
  16. package/esm2022/class/link.mjs +0 -19
  17. package/esm2022/class/toolbar.mjs +0 -2
  18. package/esm2022/class/view-type.mjs +0 -10
  19. package/esm2022/components/bar/bar-drag.mjs +0 -560
  20. package/esm2022/components/bar/bar.component.mjs +0 -132
  21. package/esm2022/components/baseline/baseline.component.mjs +0 -43
  22. package/esm2022/components/calendar/grid/calendar-grid.component.mjs +0 -66
  23. package/esm2022/components/calendar/header/calendar-header.component.mjs +0 -70
  24. package/esm2022/components/drag-backdrop/drag-backdrop.component.mjs +0 -21
  25. package/esm2022/components/icon/icon.component.mjs +0 -37
  26. package/esm2022/components/icon/icons.mjs +0 -93
  27. package/esm2022/components/links/lines/curve.mjs +0 -95
  28. package/esm2022/components/links/lines/factory.mjs +0 -14
  29. package/esm2022/components/links/lines/line.mjs +0 -24
  30. package/esm2022/components/links/lines/straight.mjs +0 -58
  31. package/esm2022/components/links/links.component.mjs +0 -196
  32. package/esm2022/components/loader/loader.component.mjs +0 -30
  33. package/esm2022/components/main/gantt-main.component.mjs +0 -94
  34. package/esm2022/components/range/range.component.mjs +0 -25
  35. package/esm2022/components/scrollbar/scrollbar.component.mjs +0 -27
  36. package/esm2022/components/table/body/gantt-table-body.component.mjs +0 -329
  37. package/esm2022/components/table/header/gantt-table-header.component.mjs +0 -152
  38. package/esm2022/components/toolbar/toolbar.component.mjs +0 -37
  39. package/esm2022/gantt-abstract.mjs +0 -3
  40. package/esm2022/gantt-dom.service.mjs +0 -156
  41. package/esm2022/gantt-drag-container.mjs +0 -78
  42. package/esm2022/gantt-item-upper.mjs +0 -67
  43. package/esm2022/gantt-print.service.mjs +0 -94
  44. package/esm2022/gantt-upper.mjs +0 -402
  45. package/esm2022/gantt.component.mjs +0 -361
  46. package/esm2022/gantt.config.mjs +0 -69
  47. package/esm2022/gantt.module.mjs +0 -141
  48. package/esm2022/gantt.pipe.mjs +0 -61
  49. package/esm2022/gantt.styles.mjs +0 -10
  50. package/esm2022/i18n/i18n.mjs +0 -12
  51. package/esm2022/i18n/index.mjs +0 -18
  52. package/esm2022/i18n/locales/de-de.mjs +0 -51
  53. package/esm2022/i18n/locales/en-us.mjs +0 -49
  54. package/esm2022/i18n/locales/ja-jp.mjs +0 -49
  55. package/esm2022/i18n/locales/ru-ru.mjs +0 -51
  56. package/esm2022/i18n/locales/zh-hans.mjs +0 -49
  57. package/esm2022/i18n/locales/zh-hant.mjs +0 -49
  58. package/esm2022/public-api.mjs +0 -28
  59. package/esm2022/root.component.mjs +0 -174
  60. package/esm2022/table/gantt-column.component.mjs +0 -46
  61. package/esm2022/table/gantt-table.component.mjs +0 -49
  62. package/esm2022/utils/date.mjs +0 -180
  63. package/esm2022/utils/drag-scroll.mjs +0 -54
  64. package/esm2022/utils/helpers.mjs +0 -73
  65. package/esm2022/utils/passive-listeners.mjs +0 -30
  66. package/esm2022/utils/set-style-with-vendor-prefix.mjs +0 -15
  67. package/esm2022/views/day.mjs +0 -58
  68. package/esm2022/views/factory.mjs +0 -22
  69. package/esm2022/views/hour.mjs +0 -89
  70. package/esm2022/views/month.mjs +0 -52
  71. package/esm2022/views/quarter.mjs +0 -55
  72. package/esm2022/views/view.mjs +0 -177
  73. package/esm2022/views/week.mjs +0 -53
  74. package/esm2022/views/year.mjs +0 -54
  75. package/esm2022/worktile-gantt.mjs +0 -5
@@ -1,94 +0,0 @@
1
- import { Component, HostBinding, Inject, Input, Output, EventEmitter } from '@angular/core';
2
- import { GANTT_UPPER_TOKEN } from '../../gantt-upper';
3
- import { IsGanttRangeItemPipe, IsGanttBarItemPipe, IsGanttCustomItemPipe } from '../../gantt.pipe';
4
- import { NgxGanttBaselineComponent } from '../baseline/baseline.component';
5
- import { NgxGanttBarComponent } from '../bar/bar.component';
6
- import { NgxGanttRangeComponent } from '../range/range.component';
7
- import { NgFor, NgIf, NgClass, NgTemplateOutlet } from '@angular/common';
8
- import { GanttLinksComponent } from '../links/links.component';
9
- import { GanttIconComponent } from '../icon/icon.component';
10
- import { combineLatest, from, Subject, take, takeUntil } from 'rxjs';
11
- import * as i0 from "@angular/core";
12
- import * as i1 from "../../gantt-dom.service";
13
- import * as i2 from "../../gantt-upper";
14
- export class GanttMainComponent {
15
- constructor(ganttUpper, dom, ngZone) {
16
- this.ganttUpper = ganttUpper;
17
- this.dom = dom;
18
- this.ngZone = ngZone;
19
- this.barClick = new EventEmitter();
20
- this.lineClick = new EventEmitter();
21
- this.ganttMainClass = true;
22
- this.unsubscribe$ = new Subject();
23
- }
24
- ngOnInit() {
25
- const onStable$ = this.ngZone.isStable ? from(Promise.resolve()) : this.ngZone.onStable.pipe(take(1));
26
- this.ngZone.runOutsideAngular(() => {
27
- onStable$.pipe(takeUntil(this.unsubscribe$)).subscribe(() => {
28
- this.setupResize();
29
- });
30
- });
31
- }
32
- trackBy(index, item) {
33
- return item.id || index;
34
- }
35
- setupResize() {
36
- combineLatest([this.dom.getResize(), this.dom.getResizeByElement(this.dom.mainContainer)])
37
- .pipe(takeUntil(this.unsubscribe$))
38
- .subscribe(() => {
39
- this.dom.setVisibleRangeX();
40
- });
41
- }
42
- quickTime(item, type) {
43
- const date = type === 'left' ? item.start || item.end : item.end || item.start;
44
- this.ganttRoot.scrollToDate(date);
45
- }
46
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: GanttMainComponent, deps: [{ token: GANTT_UPPER_TOKEN }, { token: i1.GanttDomService }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component }); }
47
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.0", type: GanttMainComponent, isStandalone: true, selector: "gantt-main", inputs: { viewportItems: "viewportItems", flatItems: "flatItems", groupHeaderTemplate: "groupHeaderTemplate", itemTemplate: "itemTemplate", barTemplate: "barTemplate", rangeTemplate: "rangeTemplate", baselineTemplate: "baselineTemplate", ganttRoot: "ganttRoot", quickTimeFocus: "quickTimeFocus" }, outputs: { barClick: "barClick", lineClick: "lineClick" }, host: { properties: { "class.gantt-main-container": "this.ganttMainClass" } }, ngImport: i0, template: "<gantt-links-overlay [flatItems]=\"flatItems\" (lineClick)=\"lineClick.emit($event)\"></gantt-links-overlay>\n<div class=\"gantt-main-groups\" [style.width.px]=\"ganttUpper.view.width\">\n <ng-container *ngFor=\"let data of viewportItems; trackBy: trackBy\">\n <div class=\"gantt-group\" [style.height.px]=\"ganttUpper.styles.lineHeight\" [ngClass]=\"data.class\" *ngIf=\"data.items\">\n <ng-template [ngTemplateOutlet]=\"groupHeaderTemplate\" [ngTemplateOutletContext]=\"{ group: data }\"></ng-template>\n </div>\n <div\n *ngIf=\"!data.items\"\n class=\"gantt-item\"\n [style.height.px]=\"ganttUpper.styles.lineHeight\"\n [class.gantt-main-item-active]=\"ganttUpper.isSelected(data.id)\"\n >\n <ng-container *ngIf=\"data.type | isGanttCustomItem\">\n <ng-template\n [ngTemplateOutlet]=\"itemTemplate\"\n [ngTemplateOutletContext]=\"{\n item: data.origin,\n refs: data.refs,\n baseline: ganttUpper.baselineItemsMap[data.id]?.origin,\n baselineRefs: ganttUpper.baselineItemsMap[data.id]?.refs\n }\"\n >\n </ng-template>\n </ng-container>\n\n <ng-container *ngIf=\"(data.type | isGanttRangeItem) || (data.type | isGanttBarItem)\">\n <gantt-range *ngIf=\"data.type | isGanttRangeItem\" [template]=\"rangeTemplate\" [item]=\"data\"></gantt-range>\n <gantt-bar *ngIf=\"data.type | isGanttBarItem\" [item]=\"data\" [template]=\"barTemplate\" (barClick)=\"barClick.emit($event)\"></gantt-bar>\n <gantt-baseline\n *ngIf=\"ganttUpper.baselineItemsMap[data.id]\"\n [baselineItem]=\"ganttUpper.baselineItemsMap[data.id]\"\n [template]=\"baselineTemplate\"\n ></gantt-baseline>\n </ng-container>\n </div>\n </ng-container>\n</div>\n\n@if (quickTimeFocus) {\n<div class=\"gantt-quick-time-focus-container\" [style.width.px]=\"ganttUpper.view.width\">\n <div class=\"gantt-quick-time-focus\" [style.width.px]=\"dom.visibleRangeX().max - dom.visibleRangeX().min\">\n <ng-container *ngFor=\"let data of viewportItems; let i = index; trackBy: trackBy\">\n <div class=\"gantt-quick-time-focus-item\" [style.height.px]=\"ganttUpper.styles.lineHeight\">\n <span class=\"ml-2\">\n @if ((data.refs.x < dom.visibleRangeX().min ) && data.refs.width ) {\n <a class=\"gantt-quick-time-focus-item-arrow link-secondary\" href=\"javascript:;\" (click)=\"quickTime(data.origin, 'left')\">\n <gantt-icon iconName=\"arrow-left\"></gantt-icon>\n </a>\n }\n </span>\n\n <span class=\"mr-2\">\n @if((data.refs.x + data.refs.width > dom.visibleRangeX().max) && data.refs.width) {\n <a class=\"gantt-quick-time-focus-item-arrow link-secondary\" href=\"javascript:;\" (click)=\"quickTime(data.origin, 'right')\">\n <gantt-icon iconName=\"arrow-right\"></gantt-icon>\n </a>\n }\n </span>\n </div>\n </ng-container>\n </div>\n</div>\n}\n", dependencies: [{ kind: "component", type: GanttLinksComponent, selector: "gantt-links-overlay", inputs: ["flatItems"], outputs: ["lineClick"] }, { kind: "directive", type: NgFor, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: NgxGanttRangeComponent, selector: "ngx-gantt-range,gantt-range" }, { kind: "component", type: NgxGanttBarComponent, selector: "ngx-gantt-bar,gantt-bar", outputs: ["barClick"] }, { kind: "component", type: NgxGanttBaselineComponent, selector: "ngx-gantt-baseline,gantt-baseline", inputs: ["baselineItem", "template"] }, { kind: "pipe", type: IsGanttRangeItemPipe, name: "isGanttRangeItem" }, { kind: "pipe", type: IsGanttBarItemPipe, name: "isGanttBarItem" }, { kind: "pipe", type: IsGanttCustomItemPipe, name: "isGanttCustomItem" }, { kind: "component", type: GanttIconComponent, selector: "gantt-icon", inputs: ["iconName"] }] }); }
48
- }
49
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: GanttMainComponent, decorators: [{
50
- type: Component,
51
- args: [{ selector: 'gantt-main', standalone: true, imports: [
52
- GanttLinksComponent,
53
- NgFor,
54
- NgIf,
55
- NgClass,
56
- NgTemplateOutlet,
57
- NgxGanttRangeComponent,
58
- NgxGanttBarComponent,
59
- NgxGanttBaselineComponent,
60
- IsGanttRangeItemPipe,
61
- IsGanttBarItemPipe,
62
- IsGanttCustomItemPipe,
63
- GanttIconComponent
64
- ], template: "<gantt-links-overlay [flatItems]=\"flatItems\" (lineClick)=\"lineClick.emit($event)\"></gantt-links-overlay>\n<div class=\"gantt-main-groups\" [style.width.px]=\"ganttUpper.view.width\">\n <ng-container *ngFor=\"let data of viewportItems; trackBy: trackBy\">\n <div class=\"gantt-group\" [style.height.px]=\"ganttUpper.styles.lineHeight\" [ngClass]=\"data.class\" *ngIf=\"data.items\">\n <ng-template [ngTemplateOutlet]=\"groupHeaderTemplate\" [ngTemplateOutletContext]=\"{ group: data }\"></ng-template>\n </div>\n <div\n *ngIf=\"!data.items\"\n class=\"gantt-item\"\n [style.height.px]=\"ganttUpper.styles.lineHeight\"\n [class.gantt-main-item-active]=\"ganttUpper.isSelected(data.id)\"\n >\n <ng-container *ngIf=\"data.type | isGanttCustomItem\">\n <ng-template\n [ngTemplateOutlet]=\"itemTemplate\"\n [ngTemplateOutletContext]=\"{\n item: data.origin,\n refs: data.refs,\n baseline: ganttUpper.baselineItemsMap[data.id]?.origin,\n baselineRefs: ganttUpper.baselineItemsMap[data.id]?.refs\n }\"\n >\n </ng-template>\n </ng-container>\n\n <ng-container *ngIf=\"(data.type | isGanttRangeItem) || (data.type | isGanttBarItem)\">\n <gantt-range *ngIf=\"data.type | isGanttRangeItem\" [template]=\"rangeTemplate\" [item]=\"data\"></gantt-range>\n <gantt-bar *ngIf=\"data.type | isGanttBarItem\" [item]=\"data\" [template]=\"barTemplate\" (barClick)=\"barClick.emit($event)\"></gantt-bar>\n <gantt-baseline\n *ngIf=\"ganttUpper.baselineItemsMap[data.id]\"\n [baselineItem]=\"ganttUpper.baselineItemsMap[data.id]\"\n [template]=\"baselineTemplate\"\n ></gantt-baseline>\n </ng-container>\n </div>\n </ng-container>\n</div>\n\n@if (quickTimeFocus) {\n<div class=\"gantt-quick-time-focus-container\" [style.width.px]=\"ganttUpper.view.width\">\n <div class=\"gantt-quick-time-focus\" [style.width.px]=\"dom.visibleRangeX().max - dom.visibleRangeX().min\">\n <ng-container *ngFor=\"let data of viewportItems; let i = index; trackBy: trackBy\">\n <div class=\"gantt-quick-time-focus-item\" [style.height.px]=\"ganttUpper.styles.lineHeight\">\n <span class=\"ml-2\">\n @if ((data.refs.x < dom.visibleRangeX().min ) && data.refs.width ) {\n <a class=\"gantt-quick-time-focus-item-arrow link-secondary\" href=\"javascript:;\" (click)=\"quickTime(data.origin, 'left')\">\n <gantt-icon iconName=\"arrow-left\"></gantt-icon>\n </a>\n }\n </span>\n\n <span class=\"mr-2\">\n @if((data.refs.x + data.refs.width > dom.visibleRangeX().max) && data.refs.width) {\n <a class=\"gantt-quick-time-focus-item-arrow link-secondary\" href=\"javascript:;\" (click)=\"quickTime(data.origin, 'right')\">\n <gantt-icon iconName=\"arrow-right\"></gantt-icon>\n </a>\n }\n </span>\n </div>\n </ng-container>\n </div>\n</div>\n}\n" }]
65
- }], ctorParameters: () => [{ type: i2.GanttUpper, decorators: [{
66
- type: Inject,
67
- args: [GANTT_UPPER_TOKEN]
68
- }] }, { type: i1.GanttDomService }, { type: i0.NgZone }], propDecorators: { viewportItems: [{
69
- type: Input
70
- }], flatItems: [{
71
- type: Input
72
- }], groupHeaderTemplate: [{
73
- type: Input
74
- }], itemTemplate: [{
75
- type: Input
76
- }], barTemplate: [{
77
- type: Input
78
- }], rangeTemplate: [{
79
- type: Input
80
- }], baselineTemplate: [{
81
- type: Input
82
- }], ganttRoot: [{
83
- type: Input
84
- }], quickTimeFocus: [{
85
- type: Input
86
- }], barClick: [{
87
- type: Output
88
- }], lineClick: [{
89
- type: Output
90
- }], ganttMainClass: [{
91
- type: HostBinding,
92
- args: ['class.gantt-main-container']
93
- }] } });
94
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gantt-main.component.js","sourceRoot":"","sources":["../../../../../packages/gantt/src/components/main/gantt-main.component.ts","../../../../../packages/gantt/src/components/main/gantt-main.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, HostBinding, Inject, Input, TemplateRef, Output, EventEmitter, OnInit, AfterViewInit, NgZone } from '@angular/core';\nimport { GanttGroupInternal, GanttItemInternal, GanttBarClickEvent, GanttLineClickEvent } from '../../class';\nimport { GANTT_UPPER_TOKEN, GanttUpper } from '../../gantt-upper';\nimport { IsGanttRangeItemPipe, IsGanttBarItemPipe, IsGanttCustomItemPipe } from '../../gantt.pipe';\nimport { NgxGanttBaselineComponent } from '../baseline/baseline.component';\nimport { NgxGanttBarComponent } from '../bar/bar.component';\nimport { NgxGanttRangeComponent } from '../range/range.component';\nimport { NgFor, NgIf, NgClass, NgTemplateOutlet } from '@angular/common';\nimport { GanttLinksComponent } from '../links/links.component';\nimport { NgxGanttRootComponent } from 'ngx-gantt';\nimport { GanttIconComponent } from '../icon/icon.component';\nimport { GanttDomService } from '../../gantt-dom.service';\nimport { combineLatest, from, Subject, take, takeUntil } from 'rxjs';\n\n@Component({\n    selector: 'gantt-main',\n    templateUrl: './gantt-main.component.html',\n    standalone: true,\n    imports: [\n        GanttLinksComponent,\n        NgFor,\n        NgIf,\n        NgClass,\n        NgTemplateOutlet,\n        NgxGanttRangeComponent,\n        NgxGanttBarComponent,\n        NgxGanttBaselineComponent,\n        IsGanttRangeItemPipe,\n        IsGanttBarItemPipe,\n        IsGanttCustomItemPipe,\n        GanttIconComponent\n    ]\n})\nexport class GanttMainComponent implements OnInit {\n    @Input() viewportItems: (GanttGroupInternal | GanttItemInternal)[];\n\n    @Input() flatItems: (GanttGroupInternal | GanttItemInternal)[];\n\n    @Input() groupHeaderTemplate: TemplateRef<any>;\n\n    @Input() itemTemplate: TemplateRef<any>;\n\n    @Input() barTemplate: TemplateRef<any>;\n\n    @Input() rangeTemplate: TemplateRef<any>;\n\n    @Input() baselineTemplate: TemplateRef<any>;\n\n    @Input() ganttRoot: NgxGanttRootComponent;\n\n    @Input() quickTimeFocus: boolean;\n\n    @Output() barClick = new EventEmitter<GanttBarClickEvent>();\n\n    @Output() lineClick = new EventEmitter<GanttLineClickEvent>();\n\n    @HostBinding('class.gantt-main-container') ganttMainClass = true;\n\n    private unsubscribe$ = new Subject<void>();\n\n    constructor(@Inject(GANTT_UPPER_TOKEN) public ganttUpper: GanttUpper, public dom: GanttDomService, protected ngZone: NgZone) {}\n\n    ngOnInit(): void {\n        const onStable$ = this.ngZone.isStable ? from(Promise.resolve()) : this.ngZone.onStable.pipe(take(1));\n        this.ngZone.runOutsideAngular(() => {\n            onStable$.pipe(takeUntil(this.unsubscribe$)).subscribe(() => {\n                this.setupResize();\n            });\n        });\n    }\n\n    trackBy(index: number, item: GanttGroupInternal | GanttItemInternal) {\n        return item.id || index;\n    }\n\n    private setupResize() {\n        combineLatest([this.dom.getResize(), this.dom.getResizeByElement(this.dom.mainContainer)])\n            .pipe(takeUntil(this.unsubscribe$))\n            .subscribe(() => {\n                this.dom.setVisibleRangeX();\n            });\n    }\n\n    quickTime(item: GanttItemInternal, type: 'left' | 'right') {\n        const date = type === 'left' ? item.start || item.end : item.end || item.start;\n        this.ganttRoot.scrollToDate(date);\n    }\n}\n","<gantt-links-overlay [flatItems]=\"flatItems\" (lineClick)=\"lineClick.emit($event)\"></gantt-links-overlay>\n<div class=\"gantt-main-groups\" [style.width.px]=\"ganttUpper.view.width\">\n  <ng-container *ngFor=\"let data of viewportItems; trackBy: trackBy\">\n    <div class=\"gantt-group\" [style.height.px]=\"ganttUpper.styles.lineHeight\" [ngClass]=\"data.class\" *ngIf=\"data.items\">\n      <ng-template [ngTemplateOutlet]=\"groupHeaderTemplate\" [ngTemplateOutletContext]=\"{ group: data }\"></ng-template>\n    </div>\n    <div\n      *ngIf=\"!data.items\"\n      class=\"gantt-item\"\n      [style.height.px]=\"ganttUpper.styles.lineHeight\"\n      [class.gantt-main-item-active]=\"ganttUpper.isSelected(data.id)\"\n    >\n      <ng-container *ngIf=\"data.type | isGanttCustomItem\">\n        <ng-template\n          [ngTemplateOutlet]=\"itemTemplate\"\n          [ngTemplateOutletContext]=\"{\n            item: data.origin,\n            refs: data.refs,\n            baseline: ganttUpper.baselineItemsMap[data.id]?.origin,\n            baselineRefs: ganttUpper.baselineItemsMap[data.id]?.refs\n          }\"\n        >\n        </ng-template>\n      </ng-container>\n\n      <ng-container *ngIf=\"(data.type | isGanttRangeItem) || (data.type | isGanttBarItem)\">\n        <gantt-range *ngIf=\"data.type | isGanttRangeItem\" [template]=\"rangeTemplate\" [item]=\"data\"></gantt-range>\n        <gantt-bar *ngIf=\"data.type | isGanttBarItem\" [item]=\"data\" [template]=\"barTemplate\" (barClick)=\"barClick.emit($event)\"></gantt-bar>\n        <gantt-baseline\n          *ngIf=\"ganttUpper.baselineItemsMap[data.id]\"\n          [baselineItem]=\"ganttUpper.baselineItemsMap[data.id]\"\n          [template]=\"baselineTemplate\"\n        ></gantt-baseline>\n      </ng-container>\n    </div>\n  </ng-container>\n</div>\n\n@if (quickTimeFocus) {\n<div class=\"gantt-quick-time-focus-container\" [style.width.px]=\"ganttUpper.view.width\">\n  <div class=\"gantt-quick-time-focus\" [style.width.px]=\"dom.visibleRangeX().max - dom.visibleRangeX().min\">\n    <ng-container *ngFor=\"let data of viewportItems; let i = index; trackBy: trackBy\">\n      <div class=\"gantt-quick-time-focus-item\" [style.height.px]=\"ganttUpper.styles.lineHeight\">\n        <span class=\"ml-2\">\n          @if ((data.refs.x < dom.visibleRangeX().min ) && data.refs.width ) {\n          <a class=\"gantt-quick-time-focus-item-arrow link-secondary\" href=\"javascript:;\" (click)=\"quickTime(data.origin, 'left')\">\n            <gantt-icon iconName=\"arrow-left\"></gantt-icon>\n          </a>\n          }\n        </span>\n\n        <span class=\"mr-2\">\n          @if((data.refs.x + data.refs.width > dom.visibleRangeX().max) && data.refs.width) {\n          <a class=\"gantt-quick-time-focus-item-arrow link-secondary\" href=\"javascript:;\" (click)=\"quickTime(data.origin, 'right')\">\n            <gantt-icon iconName=\"arrow-right\"></gantt-icon>\n          </a>\n          }\n        </span>\n      </div>\n    </ng-container>\n  </div>\n</div>\n}\n"]}
@@ -1,25 +0,0 @@
1
- import { Component, HostBinding, Inject } from '@angular/core';
2
- import { GANTT_UPPER_TOKEN } from '../../gantt-upper';
3
- import { GanttItemUpper } from '../../gantt-item-upper';
4
- import { NgIf, NgTemplateOutlet } from '@angular/common';
5
- import * as i0 from "@angular/core";
6
- import * as i1 from "../../gantt-upper";
7
- export class NgxGanttRangeComponent extends GanttItemUpper {
8
- constructor(elementRef, ganttUpper) {
9
- super(elementRef, ganttUpper);
10
- this.ganttRangeClass = true;
11
- }
12
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: NgxGanttRangeComponent, deps: [{ token: i0.ElementRef }, { token: GANTT_UPPER_TOKEN }], target: i0.ɵɵFactoryTarget.Component }); }
13
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.0", type: NgxGanttRangeComponent, isStandalone: true, selector: "ngx-gantt-range,gantt-range", host: { properties: { "class.gantt-range": "this.ganttRangeClass" } }, usesInheritance: true, ngImport: i0, template: "<ng-container *ngIf=\"item.start && item.end\">\n <div class=\"gantt-range-main\">\n <div class=\"gantt-range-main-progress\" *ngIf=\"item.progress >= 0\" [style.width.%]=\"item.progress * 100\"></div>\n </div>\n <div class=\"gantt-range-triangle left\"></div>\n <div class=\"gantt-range-triangle right\"></div>\n <ng-template [ngTemplateOutlet]=\"template\" [ngTemplateOutletContext]=\"{ item: item.origin, refs: item.refs }\"></ng-template>\n</ng-container>\n", dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }] }); }
14
- }
15
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: NgxGanttRangeComponent, decorators: [{
16
- type: Component,
17
- args: [{ selector: 'ngx-gantt-range,gantt-range', standalone: true, imports: [NgIf, NgTemplateOutlet], template: "<ng-container *ngIf=\"item.start && item.end\">\n <div class=\"gantt-range-main\">\n <div class=\"gantt-range-main-progress\" *ngIf=\"item.progress >= 0\" [style.width.%]=\"item.progress * 100\"></div>\n </div>\n <div class=\"gantt-range-triangle left\"></div>\n <div class=\"gantt-range-triangle right\"></div>\n <ng-template [ngTemplateOutlet]=\"template\" [ngTemplateOutletContext]=\"{ item: item.origin, refs: item.refs }\"></ng-template>\n</ng-container>\n" }]
18
- }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i1.GanttUpper, decorators: [{
19
- type: Inject,
20
- args: [GANTT_UPPER_TOKEN]
21
- }] }], propDecorators: { ganttRangeClass: [{
22
- type: HostBinding,
23
- args: ['class.gantt-range']
24
- }] } });
25
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmFuZ2UuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZ2FudHQvc3JjL2NvbXBvbmVudHMvcmFuZ2UvcmFuZ2UuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZ2FudHQvc3JjL2NvbXBvbmVudHMvcmFuZ2UvcmFuZ2UuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxXQUFXLEVBQWMsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzNFLE9BQU8sRUFBRSxpQkFBaUIsRUFBYyxNQUFNLG1CQUFtQixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUN4RCxPQUFPLEVBQUUsSUFBSSxFQUFFLGdCQUFnQixFQUFFLE1BQU0saUJBQWlCLENBQUM7OztBQVF6RCxNQUFNLE9BQU8sc0JBQXVCLFNBQVEsY0FBYztJQUd0RCxZQUFZLFVBQXNDLEVBQTZCLFVBQXNCO1FBQ2pHLEtBQUssQ0FBQyxVQUFVLEVBQUUsVUFBVSxDQUFDLENBQUM7UUFIQSxvQkFBZSxHQUFHLElBQUksQ0FBQztJQUl6RCxDQUFDOzhHQUxRLHNCQUFzQiw0Q0FHNkIsaUJBQWlCO2tHQUhwRSxzQkFBc0IscUxDWG5DLHVkQVFBLDRDRENjLElBQUksNkZBQUUsZ0JBQWdCOzsyRkFFdkIsc0JBQXNCO2tCQU5sQyxTQUFTOytCQUNJLDZCQUE2QixjQUUzQixJQUFJLFdBQ1AsQ0FBQyxJQUFJLEVBQUUsZ0JBQWdCLENBQUM7OzBCQUtvQixNQUFNOzJCQUFDLGlCQUFpQjt5Q0FGM0MsZUFBZTtzQkFBaEQsV0FBVzt1QkFBQyxtQkFBbUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEhvc3RCaW5kaW5nLCBFbGVtZW50UmVmLCBJbmplY3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEdBTlRUX1VQUEVSX1RPS0VOLCBHYW50dFVwcGVyIH0gZnJvbSAnLi4vLi4vZ2FudHQtdXBwZXInO1xuaW1wb3J0IHsgR2FudHRJdGVtVXBwZXIgfSBmcm9tICcuLi8uLi9nYW50dC1pdGVtLXVwcGVyJztcbmltcG9ydCB7IE5nSWYsIE5nVGVtcGxhdGVPdXRsZXQgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ25neC1nYW50dC1yYW5nZSxnYW50dC1yYW5nZScsXG4gICAgdGVtcGxhdGVVcmw6ICcuL3JhbmdlLmNvbXBvbmVudC5odG1sJyxcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxuICAgIGltcG9ydHM6IFtOZ0lmLCBOZ1RlbXBsYXRlT3V0bGV0XVxufSlcbmV4cG9ydCBjbGFzcyBOZ3hHYW50dFJhbmdlQ29tcG9uZW50IGV4dGVuZHMgR2FudHRJdGVtVXBwZXIge1xuICAgIEBIb3N0QmluZGluZygnY2xhc3MuZ2FudHQtcmFuZ2UnKSBnYW50dFJhbmdlQ2xhc3MgPSB0cnVlO1xuXG4gICAgY29uc3RydWN0b3IoZWxlbWVudFJlZjogRWxlbWVudFJlZjxIVE1MRGl2RWxlbWVudD4sIEBJbmplY3QoR0FOVFRfVVBQRVJfVE9LRU4pIGdhbnR0VXBwZXI6IEdhbnR0VXBwZXIpIHtcbiAgICAgICAgc3VwZXIoZWxlbWVudFJlZiwgZ2FudHRVcHBlcik7XG4gICAgfVxufVxuIiwiPG5nLWNvbnRhaW5lciAqbmdJZj1cIml0ZW0uc3RhcnQgJiYgaXRlbS5lbmRcIj5cbiAgPGRpdiBjbGFzcz1cImdhbnR0LXJhbmdlLW1haW5cIj5cbiAgICA8ZGl2IGNsYXNzPVwiZ2FudHQtcmFuZ2UtbWFpbi1wcm9ncmVzc1wiICpuZ0lmPVwiaXRlbS5wcm9ncmVzcyA+PSAwXCIgW3N0eWxlLndpZHRoLiVdPVwiaXRlbS5wcm9ncmVzcyAqIDEwMFwiPjwvZGl2PlxuICA8L2Rpdj5cbiAgPGRpdiBjbGFzcz1cImdhbnR0LXJhbmdlLXRyaWFuZ2xlIGxlZnRcIj48L2Rpdj5cbiAgPGRpdiBjbGFzcz1cImdhbnR0LXJhbmdlLXRyaWFuZ2xlIHJpZ2h0XCI+PC9kaXY+XG4gIDxuZy10ZW1wbGF0ZSBbbmdUZW1wbGF0ZU91dGxldF09XCJ0ZW1wbGF0ZVwiIFtuZ1RlbXBsYXRlT3V0bGV0Q29udGV4dF09XCJ7IGl0ZW06IGl0ZW0ub3JpZ2luLCByZWZzOiBpdGVtLnJlZnMgfVwiPjwvbmctdGVtcGxhdGU+XG48L25nLWNvbnRhaW5lcj5cbiJdfQ==
@@ -1,27 +0,0 @@
1
- import { Component, Inject, Input } from '@angular/core';
2
- import { GANTT_UPPER_TOKEN } from '../../gantt-upper';
3
- import { NgClass } from '@angular/common';
4
- import * as i0 from "@angular/core";
5
- import * as i1 from "../../gantt-upper";
6
- export class GanttScrollbarComponent {
7
- constructor(ganttUpper) {
8
- this.ganttUpper = ganttUpper;
9
- this.hasFooter = false;
10
- }
11
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: GanttScrollbarComponent, deps: [{ token: GANTT_UPPER_TOKEN }], target: i0.ɵɵFactoryTarget.Component }); }
12
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.0", type: GanttScrollbarComponent, isStandalone: true, selector: "gantt-scrollbar", inputs: { hasFooter: "hasFooter", tableWidth: "tableWidth", ganttRoot: "ganttRoot" }, ngImport: i0, template: "<div\n class=\"gantt-scrollbar\"\n [ngClass]=\"{ 'gantt-scrollbar-bg': hasFooter }\"\n [style.height.px]=\"ganttRoot?.horizontalScrollbarHeight + 1\"\n [style.right.px]=\"ganttRoot?.verticalScrollbarWidth\"\n>\n <div class=\"gantt-table-scrollbar\" [class.with-scrollbar]=\"ganttRoot?.horizontalScrollbarHeight\" [style.width.px]=\"tableWidth\"></div>\n <div class=\"gantt-main-scrollbar\">\n <div class=\"h-100\" [style.width.px]=\"ganttRoot['view']?.width\"></div>\n </div>\n</div>\n", dependencies: [{ kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }] }); }
13
- }
14
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: GanttScrollbarComponent, decorators: [{
15
- type: Component,
16
- args: [{ selector: 'gantt-scrollbar', imports: [NgClass], standalone: true, template: "<div\n class=\"gantt-scrollbar\"\n [ngClass]=\"{ 'gantt-scrollbar-bg': hasFooter }\"\n [style.height.px]=\"ganttRoot?.horizontalScrollbarHeight + 1\"\n [style.right.px]=\"ganttRoot?.verticalScrollbarWidth\"\n>\n <div class=\"gantt-table-scrollbar\" [class.with-scrollbar]=\"ganttRoot?.horizontalScrollbarHeight\" [style.width.px]=\"tableWidth\"></div>\n <div class=\"gantt-main-scrollbar\">\n <div class=\"h-100\" [style.width.px]=\"ganttRoot['view']?.width\"></div>\n </div>\n</div>\n" }]
17
- }], ctorParameters: () => [{ type: i1.GanttUpper, decorators: [{
18
- type: Inject,
19
- args: [GANTT_UPPER_TOKEN]
20
- }] }], propDecorators: { hasFooter: [{
21
- type: Input
22
- }], tableWidth: [{
23
- type: Input
24
- }], ganttRoot: [{
25
- type: Input
26
- }] } });
27
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2Nyb2xsYmFyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2dhbnR0L3NyYy9jb21wb25lbnRzL3Njcm9sbGJhci9zY3JvbGxiYXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZ2FudHQvc3JjL2NvbXBvbmVudHMvc2Nyb2xsYmFyL3Njcm9sbGJhci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekQsT0FBTyxFQUFFLGlCQUFpQixFQUFjLE1BQU0sbUJBQW1CLENBQUM7QUFDbEUsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLGlCQUFpQixDQUFDOzs7QUFTMUMsTUFBTSxPQUFPLHVCQUF1QjtJQU9oQyxZQUE4QyxVQUFzQjtRQUF0QixlQUFVLEdBQVYsVUFBVSxDQUFZO1FBTjNELGNBQVMsR0FBWSxLQUFLLENBQUM7SUFNbUMsQ0FBQzs4R0FQL0QsdUJBQXVCLGtCQU9aLGlCQUFpQjtrR0FQNUIsdUJBQXVCLGlLQ1hwQyxpZkFXQSw0Q0RIYyxPQUFPOzsyRkFHUix1QkFBdUI7a0JBTm5DLFNBQVM7K0JBQ0ksaUJBQWlCLFdBRWxCLENBQUMsT0FBTyxDQUFDLGNBQ04sSUFBSTs7MEJBU0gsTUFBTTsyQkFBQyxpQkFBaUI7eUNBTjVCLFNBQVM7c0JBQWpCLEtBQUs7Z0JBRUcsVUFBVTtzQkFBbEIsS0FBSztnQkFFRyxTQUFTO3NCQUFqQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbmplY3QsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBHQU5UVF9VUFBFUl9UT0tFTiwgR2FudHRVcHBlciB9IGZyb20gJy4uLy4uL2dhbnR0LXVwcGVyJztcbmltcG9ydCB7IE5nQ2xhc3MgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgTmd4R2FudHRSb290Q29tcG9uZW50IH0gZnJvbSAnLi4vLi4vcm9vdC5jb21wb25lbnQnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ2dhbnR0LXNjcm9sbGJhcicsXG4gICAgdGVtcGxhdGVVcmw6IGAuL3Njcm9sbGJhci5jb21wb25lbnQuaHRtbGAsXG4gICAgaW1wb3J0czogW05nQ2xhc3NdLFxuICAgIHN0YW5kYWxvbmU6IHRydWVcbn0pXG5leHBvcnQgY2xhc3MgR2FudHRTY3JvbGxiYXJDb21wb25lbnQge1xuICAgIEBJbnB1dCgpIGhhc0Zvb3RlcjogYm9vbGVhbiA9IGZhbHNlO1xuXG4gICAgQElucHV0KCkgdGFibGVXaWR0aDogbnVtYmVyO1xuXG4gICAgQElucHV0KCkgZ2FudHRSb290OiBOZ3hHYW50dFJvb3RDb21wb25lbnQ7XG5cbiAgICBjb25zdHJ1Y3RvcihASW5qZWN0KEdBTlRUX1VQUEVSX1RPS0VOKSBwdWJsaWMgZ2FudHRVcHBlcjogR2FudHRVcHBlcikge31cbn1cbiIsIjxkaXZcbiAgY2xhc3M9XCJnYW50dC1zY3JvbGxiYXJcIlxuICBbbmdDbGFzc109XCJ7ICdnYW50dC1zY3JvbGxiYXItYmcnOiBoYXNGb290ZXIgfVwiXG4gIFtzdHlsZS5oZWlnaHQucHhdPVwiZ2FudHRSb290Py5ob3Jpem9udGFsU2Nyb2xsYmFySGVpZ2h0ICsgMVwiXG4gIFtzdHlsZS5yaWdodC5weF09XCJnYW50dFJvb3Q/LnZlcnRpY2FsU2Nyb2xsYmFyV2lkdGhcIlxuPlxuICA8ZGl2IGNsYXNzPVwiZ2FudHQtdGFibGUtc2Nyb2xsYmFyXCIgW2NsYXNzLndpdGgtc2Nyb2xsYmFyXT1cImdhbnR0Um9vdD8uaG9yaXpvbnRhbFNjcm9sbGJhckhlaWdodFwiIFtzdHlsZS53aWR0aC5weF09XCJ0YWJsZVdpZHRoXCI+PC9kaXY+XG4gIDxkaXYgY2xhc3M9XCJnYW50dC1tYWluLXNjcm9sbGJhclwiPlxuICAgIDxkaXYgY2xhc3M9XCJoLTEwMFwiIFtzdHlsZS53aWR0aC5weF09XCJnYW50dFJvb3RbJ3ZpZXcnXT8ud2lkdGhcIj48L2Rpdj5cbiAgPC9kaXY+XG48L2Rpdj5cbiJdfQ==