@mintplayer/ng-bootstrap 13.3.4 → 13.3.8
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.
- package/_bootstrap.scss +1 -0
- package/esm2020/lib/components/calendar/calendar.component.mjs +4 -4
- package/esm2020/lib/components/index.mjs +2 -1
- package/esm2020/lib/components/navbar/navbar/navbar.component.mjs +2 -2
- package/esm2020/lib/components/navbar/navbar-content/navbar-content.directive.mjs +6 -3
- package/esm2020/lib/components/offcanvas/components/index.mjs +4 -0
- package/esm2020/lib/components/offcanvas/components/offcanvas/offcanvas.component.mjs +57 -0
- package/esm2020/lib/components/offcanvas/components/offcanvas-body/offcanvas-body.component.mjs +14 -0
- package/esm2020/lib/components/offcanvas/components/offcanvas-header/offcanvas-header.component.mjs +14 -0
- package/esm2020/lib/components/offcanvas/directives/index.mjs +2 -0
- package/esm2020/lib/components/offcanvas/directives/offcanvas-close/offcanvas-close.directive.mjs +27 -0
- package/esm2020/lib/components/offcanvas/index.mjs +7 -0
- package/esm2020/lib/components/offcanvas/interfaces/index.mjs +2 -0
- package/esm2020/lib/components/offcanvas/interfaces/offcanvas-animation-meta.mjs +2 -0
- package/esm2020/lib/components/offcanvas/offcanvas.module.mjs +45 -0
- package/esm2020/lib/components/offcanvas/providers/offcanvas-content.provider.mjs +3 -0
- package/esm2020/lib/components/offcanvas/services/index.mjs +2 -0
- package/esm2020/lib/components/offcanvas/services/offcanvas/offcanvas.service.mjs +72 -0
- package/esm2020/lib/components/offcanvas/types/index.mjs +2 -0
- package/esm2020/lib/components/offcanvas/types/position.mjs +2 -0
- package/esm2020/lib/components/scheduler/components/index.mjs +2 -1
- package/esm2020/lib/components/scheduler/components/resource-group-presenter/resource-group-presenter.component.mjs +84 -0
- package/esm2020/lib/components/scheduler/components/scheduler/scheduler.component.mjs +197 -72
- package/esm2020/lib/components/scheduler/constants/available-scales.mjs +12 -0
- package/esm2020/lib/components/scheduler/constants/index.mjs +2 -0
- package/esm2020/lib/components/scheduler/enums/index.mjs +2 -0
- package/esm2020/lib/components/scheduler/enums/scheduler-mode.mjs +6 -0
- package/esm2020/lib/components/scheduler/index.mjs +4 -1
- package/esm2020/lib/components/scheduler/interfaces/index.mjs +6 -0
- package/esm2020/lib/components/scheduler/interfaces/resource-group.mjs +2 -0
- package/esm2020/lib/components/scheduler/interfaces/resource-or-group.mjs +2 -0
- package/esm2020/lib/components/scheduler/interfaces/resource.mjs +2 -0
- package/esm2020/lib/components/scheduler/interfaces/scheduler-schale.mjs +2 -0
- package/esm2020/lib/components/scheduler/interfaces/scheduler-stamp-with-slots.mjs +2 -0
- package/esm2020/lib/components/scheduler/interfaces/timeline-options.mjs +2 -0
- package/esm2020/lib/components/scheduler/interfaces/week-options.mjs +2 -0
- package/esm2020/lib/components/scheduler/scheduler.module.mjs +9 -4
- package/esm2020/lib/components/snackbar/service/snackbar.service.mjs +6 -7
- package/esm2020/lib/components/snackbar/snackbar.module.mjs +2 -9
- package/fesm2015/mintplayer-ng-bootstrap.mjs +514 -91
- package/fesm2015/mintplayer-ng-bootstrap.mjs.map +1 -1
- package/fesm2020/mintplayer-ng-bootstrap.mjs +512 -91
- package/fesm2020/mintplayer-ng-bootstrap.mjs.map +1 -1
- package/lib/components/calendar/calendar.component.d.ts +1 -1
- package/lib/components/index.d.ts +1 -0
- package/lib/components/offcanvas/components/index.d.ts +3 -0
- package/lib/components/offcanvas/components/offcanvas/offcanvas.component.d.ts +21 -0
- package/lib/components/offcanvas/components/offcanvas-body/offcanvas-body.component.d.ts +8 -0
- package/lib/components/offcanvas/components/offcanvas-header/offcanvas-header.component.d.ts +8 -0
- package/lib/components/offcanvas/directives/index.d.ts +1 -0
- package/lib/components/offcanvas/directives/offcanvas-close/offcanvas-close.directive.d.ts +11 -0
- package/lib/components/offcanvas/index.d.ts +6 -0
- package/lib/components/offcanvas/interfaces/index.d.ts +1 -0
- package/lib/components/offcanvas/interfaces/offcanvas-animation-meta.d.ts +7 -0
- package/lib/components/offcanvas/offcanvas.module.d.ts +12 -0
- package/lib/components/offcanvas/providers/offcanvas-content.provider.d.ts +2 -0
- package/lib/components/offcanvas/services/index.d.ts +1 -0
- package/lib/components/offcanvas/services/offcanvas/offcanvas.service.d.ts +13 -0
- package/lib/components/offcanvas/types/index.d.ts +1 -0
- package/lib/components/offcanvas/types/position.d.ts +1 -0
- package/lib/components/scheduler/components/index.d.ts +1 -0
- package/lib/components/scheduler/components/resource-group-presenter/resource-group-presenter.component.d.ts +26 -0
- package/lib/components/scheduler/components/scheduler/scheduler.component.d.ts +32 -11
- package/lib/components/scheduler/constants/available-scales.d.ts +2 -0
- package/lib/components/scheduler/constants/index.d.ts +1 -0
- package/lib/components/scheduler/enums/index.d.ts +1 -0
- package/lib/components/scheduler/enums/scheduler-mode.d.ts +4 -0
- package/lib/components/scheduler/index.d.ts +3 -0
- package/lib/components/scheduler/interfaces/index.d.ts +5 -0
- package/lib/components/scheduler/interfaces/resource-group.d.ts +5 -0
- package/lib/components/scheduler/interfaces/resource-or-group.d.ts +6 -0
- package/lib/components/scheduler/interfaces/resource.d.ts +5 -0
- package/lib/components/scheduler/interfaces/scheduler-schale.d.ts +5 -0
- package/lib/components/scheduler/interfaces/scheduler-stamp-with-slots.d.ts +6 -0
- package/lib/components/scheduler/interfaces/timeline-options.d.ts +3 -0
- package/lib/components/scheduler/interfaces/week-options.d.ts +3 -0
- package/lib/components/scheduler/scheduler.module.d.ts +3 -2
- package/lib/components/snackbar/service/snackbar.service.d.ts +2 -3
- package/package.json +1 -1
- package/src/styles/utilities/overflow.scss +10 -0
|
@@ -0,0 +1,84 @@
|
|
|
1
|
+
import { Component, Input } from '@angular/core';
|
|
2
|
+
import { BehaviorSubject, filter, map, Subject, take } from 'rxjs';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@angular/common";
|
|
5
|
+
export class ResourceGroupPresenterComponent {
|
|
6
|
+
constructor() {
|
|
7
|
+
this.level = 0;
|
|
8
|
+
this.resourceOrGroup$ = new BehaviorSubject(null);
|
|
9
|
+
this.timeSlots$ = new BehaviorSubject([]);
|
|
10
|
+
this.isExpanded$ = new BehaviorSubject(false);
|
|
11
|
+
this.destroyed$ = new Subject();
|
|
12
|
+
this.data$ = this.resourceOrGroup$
|
|
13
|
+
.pipe(map((resourceOrGroup) => {
|
|
14
|
+
if (!resourceOrGroup) {
|
|
15
|
+
return null;
|
|
16
|
+
}
|
|
17
|
+
else if ('children' in resourceOrGroup) {
|
|
18
|
+
return {
|
|
19
|
+
resource: null,
|
|
20
|
+
resourceGroup: resourceOrGroup
|
|
21
|
+
};
|
|
22
|
+
}
|
|
23
|
+
else {
|
|
24
|
+
return {
|
|
25
|
+
resource: resourceOrGroup,
|
|
26
|
+
resourceGroup: null
|
|
27
|
+
};
|
|
28
|
+
}
|
|
29
|
+
}))
|
|
30
|
+
.pipe(filter((resourceOrGroup) => !!resourceOrGroup))
|
|
31
|
+
.pipe(map((resourceOrGroup) => resourceOrGroup));
|
|
32
|
+
this.colSpan$ = this.timeSlots$
|
|
33
|
+
.pipe(map(timeSlots => timeSlots
|
|
34
|
+
.map(timeslot => timeslot.slots.length)
|
|
35
|
+
.reduce((sum, current) => sum + current, 0)));
|
|
36
|
+
}
|
|
37
|
+
//#region resourceOrGroup
|
|
38
|
+
get resourceOrGroup() {
|
|
39
|
+
return this.resourceOrGroup$.value;
|
|
40
|
+
}
|
|
41
|
+
set resourceGroup(value) {
|
|
42
|
+
this.resourceOrGroup$.next(value);
|
|
43
|
+
}
|
|
44
|
+
//#endregion
|
|
45
|
+
//#region timeSlots
|
|
46
|
+
get timeSlots() {
|
|
47
|
+
return this.timeSlots$.value;
|
|
48
|
+
}
|
|
49
|
+
set timeSlots(value) {
|
|
50
|
+
this.timeSlots$.next(value);
|
|
51
|
+
}
|
|
52
|
+
//#endregion
|
|
53
|
+
//#region isExpanded
|
|
54
|
+
get isExpanded() {
|
|
55
|
+
return this.isExpanded$.value;
|
|
56
|
+
}
|
|
57
|
+
set isExpanded(value) {
|
|
58
|
+
this.isExpanded$.next(value);
|
|
59
|
+
}
|
|
60
|
+
//#endregion
|
|
61
|
+
toggleExpanded() {
|
|
62
|
+
this.isExpanded$.pipe(take(1)).subscribe((isExpanded) => {
|
|
63
|
+
this.isExpanded$.next(!isExpanded);
|
|
64
|
+
});
|
|
65
|
+
}
|
|
66
|
+
ngOnDestroy() {
|
|
67
|
+
this.destroyed$.next(true);
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
ResourceGroupPresenterComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.0", ngImport: i0, type: ResourceGroupPresenterComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
71
|
+
ResourceGroupPresenterComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.0", type: ResourceGroupPresenterComponent, selector: "bs-resource-group-presenter", inputs: { level: "level", resourceGroup: "resourceGroup", timeSlots: "timeSlots", isExpanded: "isExpanded" }, ngImport: i0, template: "<ng-container *ngIf=\"(data$ | async) as data\">\n\n <!-- Data is a resource group -->\n <ng-container *ngIf=\"data.resourceGroup\">\n <!-- Header -->\n <tr class=\"p-0 cursor-pointer\" *ngIf=\"(timeSlots$ | async) as timeSlots\" [title]=\"data.resourceGroup.description\">\n <ng-container *ngIf=\"(colSpan$ | async) as colspan\">\n <td class=\"p-2 cursor-pointer\" [colSpan]=\"colspan + 1\" (click)=\"toggleExpanded()\">\n <span class=\"p-2 align-middle position-sticky\">\n <i class=\"bi bi-chevron-down\" [style.padding-left.px]=\"level * 20\" *ngIf=\"isExpanded$ | async\"></i>\n <i class=\"bi bi-chevron-right\" [style.padding-left.px]=\"level * 20\" *ngIf=\"(isExpanded$ | async) === false\"></i>\n {{ data.resourceGroup.description }}\n </span>\n </td>\n </ng-container>\n </tr>\n\n <!-- Subgroups or resources -->\n <ng-container *ngIf=\"isExpanded$ | async\">\n <ng-container *ngIf=\"(timeSlots$ | async) as timeSlots\">\n <ng-container *ngFor=\"let child of data.resourceGroup.children\">\n <bs-resource-group-presenter [resourceGroup]=\"child\" [timeSlots]=\"timeSlots\" [level]=\"level + 1\"></bs-resource-group-presenter>\n </ng-container>\n </ng-container>\n </ng-container>\n </ng-container>\n\n <!-- Data is a resource -->\n <tr *ngIf=\"data.resource\" class=\"p-0 bordered\" [title]=\"data.resource.description\">\n <td class=\"p-0 bg-white\">\n <div class=\"p-2\">{{ data.resource.description }}</div>\n </td>\n <ng-container *ngFor=\"let slots of (timeSlots$ | async)\">\n <td class=\"bg-white border-1\" *ngFor=\"let slot of slots.slots\">\n <!-- {{ slot.start | date: 'dd/MM/yyyy HH:mm:ss' }} -->\n </td>\n </ng-container>\n </tr>\n</ng-container>", styles: [":host{display:contents}tr{border-bottom-width:1px}tr:not(.bordered) td span.position-sticky{left:0;right:0}\n"], components: [{ type: ResourceGroupPresenterComponent, selector: "bs-resource-group-presenter", inputs: ["level", "resourceGroup", "timeSlots", "isExpanded"] }], directives: [{ type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], pipes: { "async": i1.AsyncPipe } });
|
|
72
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.0", ngImport: i0, type: ResourceGroupPresenterComponent, decorators: [{
|
|
73
|
+
type: Component,
|
|
74
|
+
args: [{ selector: 'bs-resource-group-presenter', template: "<ng-container *ngIf=\"(data$ | async) as data\">\n\n <!-- Data is a resource group -->\n <ng-container *ngIf=\"data.resourceGroup\">\n <!-- Header -->\n <tr class=\"p-0 cursor-pointer\" *ngIf=\"(timeSlots$ | async) as timeSlots\" [title]=\"data.resourceGroup.description\">\n <ng-container *ngIf=\"(colSpan$ | async) as colspan\">\n <td class=\"p-2 cursor-pointer\" [colSpan]=\"colspan + 1\" (click)=\"toggleExpanded()\">\n <span class=\"p-2 align-middle position-sticky\">\n <i class=\"bi bi-chevron-down\" [style.padding-left.px]=\"level * 20\" *ngIf=\"isExpanded$ | async\"></i>\n <i class=\"bi bi-chevron-right\" [style.padding-left.px]=\"level * 20\" *ngIf=\"(isExpanded$ | async) === false\"></i>\n {{ data.resourceGroup.description }}\n </span>\n </td>\n </ng-container>\n </tr>\n\n <!-- Subgroups or resources -->\n <ng-container *ngIf=\"isExpanded$ | async\">\n <ng-container *ngIf=\"(timeSlots$ | async) as timeSlots\">\n <ng-container *ngFor=\"let child of data.resourceGroup.children\">\n <bs-resource-group-presenter [resourceGroup]=\"child\" [timeSlots]=\"timeSlots\" [level]=\"level + 1\"></bs-resource-group-presenter>\n </ng-container>\n </ng-container>\n </ng-container>\n </ng-container>\n\n <!-- Data is a resource -->\n <tr *ngIf=\"data.resource\" class=\"p-0 bordered\" [title]=\"data.resource.description\">\n <td class=\"p-0 bg-white\">\n <div class=\"p-2\">{{ data.resource.description }}</div>\n </td>\n <ng-container *ngFor=\"let slots of (timeSlots$ | async)\">\n <td class=\"bg-white border-1\" *ngFor=\"let slot of slots.slots\">\n <!-- {{ slot.start | date: 'dd/MM/yyyy HH:mm:ss' }} -->\n </td>\n </ng-container>\n </tr>\n</ng-container>", styles: [":host{display:contents}tr{border-bottom-width:1px}tr:not(.bordered) td span.position-sticky{left:0;right:0}\n"] }]
|
|
75
|
+
}], ctorParameters: function () { return []; }, propDecorators: { level: [{
|
|
76
|
+
type: Input
|
|
77
|
+
}], resourceGroup: [{
|
|
78
|
+
type: Input
|
|
79
|
+
}], timeSlots: [{
|
|
80
|
+
type: Input
|
|
81
|
+
}], isExpanded: [{
|
|
82
|
+
type: Input
|
|
83
|
+
}] } });
|
|
84
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resource-group-presenter.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/mintplayer-ng-bootstrap/src/lib/components/scheduler/components/resource-group-presenter/resource-group-presenter.component.ts","../../../../../../../../../libs/mintplayer-ng-bootstrap/src/lib/components/scheduler/components/resource-group-presenter/resource-group-presenter.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnDestroy } from '@angular/core';\nimport { BehaviorSubject, filter, map, Observable, Subject, take, takeUntil } from 'rxjs';\nimport { Resource, ResourceGroup } from '../../interfaces';\nimport { ResourceOrGroup } from '../../interfaces/resource-or-group';\nimport { SchedulerStampWithSlots } from '../../interfaces/scheduler-stamp-with-slots';\nimport { TimeSlot } from '../../interfaces/time-slot';\n\n@Component({\n  selector: 'bs-resource-group-presenter',\n  templateUrl: './resource-group-presenter.component.html',\n  styleUrls: ['./resource-group-presenter.component.scss'],\n  \n})\nexport class ResourceGroupPresenterComponent implements OnDestroy {\n  \n  constructor() {\n    this.data$ = this.resourceOrGroup$\n      .pipe(map((resourceOrGroup) => {\n        if (!resourceOrGroup) {\n          return null;\n        } else if ('children' in resourceOrGroup) {\n          return <ResourceOrGroup>{\n            resource: null,\n            resourceGroup: resourceOrGroup\n          };\n        } else {\n          return <ResourceOrGroup>{\n            resource: resourceOrGroup,\n            resourceGroup: null\n          };\n        }\n      }))\n      .pipe(filter((resourceOrGroup) => !!resourceOrGroup))\n      .pipe(map((resourceOrGroup) => <ResourceOrGroup>resourceOrGroup));\n\n    this.colSpan$ = this.timeSlots$\n      .pipe(map(timeSlots => timeSlots\n        .map(timeslot => timeslot.slots.length)\n        .reduce((sum, current) => sum + current, 0)\n      ));\n  }\n\n  @Input() level = 0;\n  resourceOrGroup$ = new BehaviorSubject<Resource | ResourceGroup | null>(null);\n  timeSlots$ = new BehaviorSubject<SchedulerStampWithSlots[]>([]);\n  isExpanded$ = new BehaviorSubject<boolean>(false);\n  data$: Observable<ResourceOrGroup>;\n  colSpan$: Observable<number>;\n  destroyed$ = new Subject();\n\n  //#region resourceOrGroup\n  public get resourceOrGroup() {\n    return this.resourceOrGroup$.value;\n  }\n  @Input() public set resourceGroup(value: Resource | ResourceGroup | null) {\n    this.resourceOrGroup$.next(value);\n  }\n  //#endregion\n\n  //#region timeSlots\n  public get timeSlots() {\n    return this.timeSlots$.value;\n  }\n  @Input() public set timeSlots(value: SchedulerStampWithSlots[]) {\n    this.timeSlots$.next(value);\n  }\n  //#endregion\n\n  //#region isExpanded\n  public get isExpanded() {\n    return this.isExpanded$.value;\n  }\n  @Input() public set isExpanded(value: boolean) {\n    this.isExpanded$.next(value);\n  }\n  //#endregion\n\n  toggleExpanded() {\n    this.isExpanded$.pipe(take(1)).subscribe((isExpanded) => {\n      this.isExpanded$.next(!isExpanded);\n    });\n  }\n\n  ngOnDestroy() {\n    this.destroyed$.next(true);\n  }\n\n}\n","<ng-container *ngIf=\"(data$ | async) as data\">\n\n    <!-- Data is a resource group -->\n    <ng-container *ngIf=\"data.resourceGroup\">\n        <!-- Header -->\n        <tr class=\"p-0 cursor-pointer\" *ngIf=\"(timeSlots$ | async) as timeSlots\" [title]=\"data.resourceGroup.description\">\n            <ng-container *ngIf=\"(colSpan$ | async) as colspan\">\n                <td class=\"p-2 cursor-pointer\" [colSpan]=\"colspan + 1\" (click)=\"toggleExpanded()\">\n                    <span class=\"p-2 align-middle position-sticky\">\n                        <i class=\"bi bi-chevron-down\" [style.padding-left.px]=\"level * 20\" *ngIf=\"isExpanded$ | async\"></i>\n                        <i class=\"bi bi-chevron-right\" [style.padding-left.px]=\"level * 20\" *ngIf=\"(isExpanded$ | async) === false\"></i>\n                        {{ data.resourceGroup.description }}\n                    </span>\n                </td>\n            </ng-container>\n        </tr>\n\n        <!-- Subgroups or resources -->\n        <ng-container *ngIf=\"isExpanded$ | async\">\n            <ng-container *ngIf=\"(timeSlots$ | async) as timeSlots\">\n                <ng-container *ngFor=\"let child of data.resourceGroup.children\">\n                    <bs-resource-group-presenter [resourceGroup]=\"child\" [timeSlots]=\"timeSlots\" [level]=\"level + 1\"></bs-resource-group-presenter>\n                </ng-container>\n            </ng-container>\n        </ng-container>\n    </ng-container>\n\n    <!-- Data is a resource -->\n    <tr *ngIf=\"data.resource\" class=\"p-0 bordered\" [title]=\"data.resource.description\">\n        <td class=\"p-0 bg-white\">\n            <div class=\"p-2\">{{ data.resource.description }}</div>\n        </td>\n        <ng-container *ngFor=\"let slots of (timeSlots$ | async)\">\n            <td class=\"bg-white border-1\" *ngFor=\"let slot of slots.slots\">\n                <!-- {{ slot.start | date: 'dd/MM/yyyy HH:mm:ss' }} -->\n            </td>\n        </ng-container>\n    </tr>\n</ng-container>"]}
|