barsa-calendar 1.0.456 → 2.0.1
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/{esm2020 → esm2022}/barsa-calendar.mjs +4 -4
- package/esm2022/lib/barsa-calendar.module.mjs +117 -0
- package/esm2022/lib/calendar-container/calendar-container.component.mjs +230 -0
- package/esm2022/lib/calendar-header/calendar-header.component.mjs +66 -0
- package/esm2022/lib/calendar-list/calendar-list.component.mjs +18 -0
- package/esm2022/lib/calendar-list-container/calendar-list-container.component.mjs +29 -0
- package/{esm2020 → esm2022}/lib/calendar-list-item/calendar-list-item.component.mjs +14 -14
- package/esm2022/lib/calendar-month/calendar-month.component.mjs +246 -0
- package/esm2022/lib/calendar-selection-days/calendar-selection-days.component.mjs +196 -0
- package/esm2022/lib/calendar-week/calendar-week.component.mjs +252 -0
- package/{esm2020 → esm2022}/lib/constants.mjs +3 -3
- package/esm2022/lib/date-time-picker/date-time-picker.component.mjs +431 -0
- package/esm2022/lib/day-event-list/day-event-list.component.mjs +55 -0
- package/esm2022/lib/day-number-box/day-number-box.component.mjs +105 -0
- package/{esm2020 → esm2022}/lib/days-in-week.pipe.mjs +17 -17
- package/esm2022/lib/equal-date.pipe.mjs +23 -0
- package/esm2022/lib/event-button/event-button.component.mjs +97 -0
- package/esm2022/lib/event-button-end-arrow/event-button-end-arrow.component.mjs +29 -0
- package/esm2022/lib/event-button-start-arrow/event-button-start-arrow.component.mjs +29 -0
- package/esm2022/lib/event-date.pipe.mjs +24 -0
- package/esm2022/lib/event-preview/event-preview.component.mjs +79 -0
- package/{esm2020 → esm2022}/lib/event-time.pipe.mjs +22 -22
- package/{esm2020 → esm2022}/lib/from-to-time.pipe.mjs +23 -23
- package/esm2022/lib/models.mjs +14 -0
- package/esm2022/lib/month-days/month-days.component.mjs +222 -0
- package/esm2022/lib/services/calendar.service.mjs +645 -0
- package/{esm2020 → esm2022}/public-api.mjs +23 -23
- package/fesm2022/barsa-calendar.mjs +2816 -0
- package/fesm2022/barsa-calendar.mjs.map +1 -0
- package/index.d.ts +5 -5
- package/lib/barsa-calendar.module.d.ts +53 -53
- package/lib/calendar-container/calendar-container.component.d.ts +89 -89
- package/lib/calendar-header/calendar-header.component.d.ts +33 -33
- package/lib/calendar-list/calendar-list.component.d.ts +8 -8
- package/lib/calendar-list-container/calendar-list-container.component.d.ts +14 -14
- package/lib/calendar-list-item/calendar-list-item.component.d.ts +7 -7
- package/lib/calendar-month/calendar-month.component.d.ts +70 -70
- package/lib/calendar-selection-days/calendar-selection-days.component.d.ts +48 -48
- package/lib/calendar-week/calendar-week.component.d.ts +70 -70
- package/lib/constants.d.ts +1 -1
- package/lib/date-time-picker/date-time-picker.component.d.ts +113 -112
- package/lib/day-event-list/day-event-list.component.d.ts +20 -20
- package/lib/day-number-box/day-number-box.component.d.ts +30 -30
- package/lib/days-in-week.pipe.d.ts +9 -9
- package/lib/equal-date.pipe.d.ts +8 -8
- package/lib/event-button/event-button.component.d.ts +31 -31
- package/lib/event-button-end-arrow/event-button-end-arrow.component.d.ts +12 -12
- package/lib/event-button-start-arrow/event-button-start-arrow.component.d.ts +12 -12
- package/lib/event-date.pipe.d.ts +9 -9
- package/lib/event-preview/event-preview.component.d.ts +24 -24
- package/lib/event-time.pipe.d.ts +9 -9
- package/lib/from-to-time.pipe.d.ts +9 -9
- package/lib/models.d.ts +110 -110
- package/lib/month-days/month-days.component.d.ts +69 -69
- package/lib/services/calendar.service.d.ts +70 -70
- package/package.json +7 -13
- package/public-api.d.ts +19 -19
- package/esm2020/lib/barsa-calendar.module.mjs +0 -117
- package/esm2020/lib/calendar-container/calendar-container.component.mjs +0 -230
- package/esm2020/lib/calendar-header/calendar-header.component.mjs +0 -67
- package/esm2020/lib/calendar-list/calendar-list.component.mjs +0 -19
- package/esm2020/lib/calendar-list-container/calendar-list-container.component.mjs +0 -30
- package/esm2020/lib/calendar-month/calendar-month.component.mjs +0 -246
- package/esm2020/lib/calendar-selection-days/calendar-selection-days.component.mjs +0 -195
- package/esm2020/lib/calendar-week/calendar-week.component.mjs +0 -249
- package/esm2020/lib/date-time-picker/date-time-picker.component.mjs +0 -433
- package/esm2020/lib/day-event-list/day-event-list.component.mjs +0 -56
- package/esm2020/lib/day-number-box/day-number-box.component.mjs +0 -105
- package/esm2020/lib/equal-date.pipe.mjs +0 -23
- package/esm2020/lib/event-button/event-button.component.mjs +0 -97
- package/esm2020/lib/event-button-end-arrow/event-button-end-arrow.component.mjs +0 -29
- package/esm2020/lib/event-button-start-arrow/event-button-start-arrow.component.mjs +0 -29
- package/esm2020/lib/event-date.pipe.mjs +0 -24
- package/esm2020/lib/event-preview/event-preview.component.mjs +0 -79
- package/esm2020/lib/models.mjs +0 -14
- package/esm2020/lib/month-days/month-days.component.mjs +0 -222
- package/esm2020/lib/services/calendar.service.mjs +0 -645
- package/fesm2015/barsa-calendar.mjs +0 -2813
- package/fesm2015/barsa-calendar.mjs.map +0 -1
- package/fesm2020/barsa-calendar.mjs +0 -2817
- package/fesm2020/barsa-calendar.mjs.map +0 -1
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
+
import { BaseComponent } from 'barsa-novin-ray-core';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "../calendar-list/calendar-list.component";
|
|
5
|
+
export class CalendarListContainerComponent extends BaseComponent {
|
|
6
|
+
constructor() {
|
|
7
|
+
super(...arguments);
|
|
8
|
+
this.showEventsTap = new EventEmitter();
|
|
9
|
+
}
|
|
10
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: CalendarListContainerComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
11
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.5", type: CalendarListContainerComponent, selector: "bc-calendar-list-container", inputs: { view: "view", reportItemComponentName: "reportItemComponentName", showEvents: "showEvents", selectedDay: "selectedDay", calendarFields: "calendarFields" }, outputs: { showEventsTap: "showEventsTap" }, usesInheritance: true, ngImport: i0, template: "@if (selectedDay) {\n<bc-calendar-list [moDataList]=\"selectedDay.tasks\"></bc-calendar-list>\n}\n", styles: [""], dependencies: [{ kind: "component", type: i1.CalendarListComponent, selector: "bc-calendar-list", inputs: ["moDataList"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
12
|
+
}
|
|
13
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: CalendarListContainerComponent, decorators: [{
|
|
14
|
+
type: Component,
|
|
15
|
+
args: [{ selector: 'bc-calendar-list-container', changeDetection: ChangeDetectionStrategy.OnPush, template: "@if (selectedDay) {\n<bc-calendar-list [moDataList]=\"selectedDay.tasks\"></bc-calendar-list>\n}\n" }]
|
|
16
|
+
}], propDecorators: { view: [{
|
|
17
|
+
type: Input
|
|
18
|
+
}], reportItemComponentName: [{
|
|
19
|
+
type: Input
|
|
20
|
+
}], showEvents: [{
|
|
21
|
+
type: Input
|
|
22
|
+
}], selectedDay: [{
|
|
23
|
+
type: Input
|
|
24
|
+
}], calendarFields: [{
|
|
25
|
+
type: Input
|
|
26
|
+
}], showEventsTap: [{
|
|
27
|
+
type: Output
|
|
28
|
+
}] } });
|
|
29
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FsZW5kYXItbGlzdC1jb250YWluZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFyc2EtY2FsZW5kYXIvc3JjL2xpYi9jYWxlbmRhci1saXN0LWNvbnRhaW5lci9jYWxlbmRhci1saXN0LWNvbnRhaW5lci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9iYXJzYS1jYWxlbmRhci9zcmMvbGliL2NhbGVuZGFyLWxpc3QtY29udGFpbmVyL2NhbGVuZGFyLWxpc3QtY29udGFpbmVyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFaEcsT0FBTyxFQUFFLGFBQWEsRUFBa0IsTUFBTSxzQkFBc0IsQ0FBQzs7O0FBUXJFLE1BQU0sT0FBTyw4QkFBK0IsU0FBUSxhQUFhO0lBTmpFOztRQVljLGtCQUFhLEdBQUcsSUFBSSxZQUFZLEVBQUUsQ0FBQztLQUNoRDs4R0FQWSw4QkFBOEI7a0dBQTlCLDhCQUE4Qiw0U0NWM0Msb0dBR0E7OzJGRE9hLDhCQUE4QjtrQkFOMUMsU0FBUzsrQkFDSSw0QkFBNEIsbUJBR3JCLHVCQUF1QixDQUFDLE1BQU07OEJBR3RDLElBQUk7c0JBQVosS0FBSztnQkFDRyx1QkFBdUI7c0JBQS9CLEtBQUs7Z0JBQ0csVUFBVTtzQkFBbEIsS0FBSztnQkFDRyxXQUFXO3NCQUFuQixLQUFLO2dCQUNHLGNBQWM7c0JBQXRCLEtBQUs7Z0JBQ0ksYUFBYTtzQkFBdEIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5cclxuaW1wb3J0IHsgQmFzZUNvbXBvbmVudCwgQ2FsZW5kYXJGaWVsZHMgfSBmcm9tICdiYXJzYS1ub3Zpbi1yYXktY29yZSc7XHJcbmltcG9ydCB7IERheSB9IGZyb20gJy4uL21vZGVscyc7XHJcbkBDb21wb25lbnQoe1xyXG4gICAgc2VsZWN0b3I6ICdiYy1jYWxlbmRhci1saXN0LWNvbnRhaW5lcicsXHJcbiAgICB0ZW1wbGF0ZVVybDogJy4vY2FsZW5kYXItbGlzdC1jb250YWluZXIuY29tcG9uZW50Lmh0bWwnLFxyXG4gICAgc3R5bGVVcmxzOiBbJy4vY2FsZW5kYXItbGlzdC1jb250YWluZXIuY29tcG9uZW50LnNjc3MnXSxcclxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBDYWxlbmRhckxpc3RDb250YWluZXJDb21wb25lbnQgZXh0ZW5kcyBCYXNlQ29tcG9uZW50IHtcclxuICAgIEBJbnB1dCgpIHZpZXc6IGFueTtcclxuICAgIEBJbnB1dCgpIHJlcG9ydEl0ZW1Db21wb25lbnROYW1lOiBzdHJpbmc7XHJcbiAgICBASW5wdXQoKSBzaG93RXZlbnRzOiBib29sZWFuO1xyXG4gICAgQElucHV0KCkgc2VsZWN0ZWREYXk6IERheTtcclxuICAgIEBJbnB1dCgpIGNhbGVuZGFyRmllbGRzOiBDYWxlbmRhckZpZWxkcztcclxuICAgIEBPdXRwdXQoKSBzaG93RXZlbnRzVGFwID0gbmV3IEV2ZW50RW1pdHRlcigpO1xyXG59XHJcbiIsIkBpZiAoc2VsZWN0ZWREYXkpIHtcbjxiYy1jYWxlbmRhci1saXN0IFttb0RhdGFMaXN0XT1cInNlbGVjdGVkRGF5LnRhc2tzXCI+PC9iYy1jYWxlbmRhci1saXN0PlxufVxuIl19
|
|
@@ -1,14 +1,14 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, Component, Input } from '@angular/core';
|
|
2
|
-
import { BaseComponent } from 'barsa-novin-ray-core';
|
|
3
|
-
import * as i0 from "@angular/core";
|
|
4
|
-
export class CalendarListItemComponent extends BaseComponent {
|
|
5
|
-
}
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
9
|
-
type: Component,
|
|
10
|
-
args: [{ selector: 'bc-calendar-list-item', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"wrapper\">\r\n <div flexShrink=\"1\" class=\"day-wrapper\">\r\n <Label [text]=\"mo.$StartTimes\"></Label>\r\n <Label class=\"ela\" [text]=\"'\u0627\u0644\u06CC'\"></Label>\r\n <Label [text]=\"mo.$EndTimes\"></Label>\r\n </div>\r\n <div class=\"color\" [style.background-color]=\"mo.$Color\"></div>\r\n <div class=\"event-wrapper\">\r\n <Label class=\"title\" [text]=\"mo.$Title\"></Label>\r\n <Label class=\"desc\" [text]=\"mo.$Notes\"></Label>\r\n </div>\r\n</div>\r\n", styles: [".wrapper{display:flex;flex-direction:row}.day-wrapper{display:flex;flex-shrink:1}.color{width:1}.event-wrapper{display:flex;flex-grow:1}\n"] }]
|
|
11
|
-
}], propDecorators: { mo: [{
|
|
12
|
-
type: Input
|
|
13
|
-
}] } });
|
|
14
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
1
|
+
import { ChangeDetectionStrategy, Component, Input } from '@angular/core';
|
|
2
|
+
import { BaseComponent } from 'barsa-novin-ray-core';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export class CalendarListItemComponent extends BaseComponent {
|
|
5
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: CalendarListItemComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
6
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.5", type: CalendarListItemComponent, selector: "bc-calendar-list-item", inputs: { mo: "mo" }, usesInheritance: true, ngImport: i0, template: "<div class=\"wrapper\">\r\n <div flexShrink=\"1\" class=\"day-wrapper\">\r\n <Label [text]=\"mo.$StartTimes\"></Label>\r\n <Label class=\"ela\" [text]=\"'\u0627\u0644\u06CC'\"></Label>\r\n <Label [text]=\"mo.$EndTimes\"></Label>\r\n </div>\r\n <div class=\"color\" [style.background-color]=\"mo.$Color\"></div>\r\n <div class=\"event-wrapper\">\r\n <Label class=\"title\" [text]=\"mo.$Title\"></Label>\r\n <Label class=\"desc\" [text]=\"mo.$Notes\"></Label>\r\n </div>\r\n</div>\r\n", styles: [".wrapper{display:flex;flex-direction:row}.day-wrapper{display:flex;flex-shrink:1}.color{width:1}.event-wrapper{display:flex;flex-grow:1}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
7
|
+
}
|
|
8
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: CalendarListItemComponent, decorators: [{
|
|
9
|
+
type: Component,
|
|
10
|
+
args: [{ selector: 'bc-calendar-list-item', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"wrapper\">\r\n <div flexShrink=\"1\" class=\"day-wrapper\">\r\n <Label [text]=\"mo.$StartTimes\"></Label>\r\n <Label class=\"ela\" [text]=\"'\u0627\u0644\u06CC'\"></Label>\r\n <Label [text]=\"mo.$EndTimes\"></Label>\r\n </div>\r\n <div class=\"color\" [style.background-color]=\"mo.$Color\"></div>\r\n <div class=\"event-wrapper\">\r\n <Label class=\"title\" [text]=\"mo.$Title\"></Label>\r\n <Label class=\"desc\" [text]=\"mo.$Notes\"></Label>\r\n </div>\r\n</div>\r\n", styles: [".wrapper{display:flex;flex-direction:row}.day-wrapper{display:flex;flex-shrink:1}.color{width:1}.event-wrapper{display:flex;flex-grow:1}\n"] }]
|
|
11
|
+
}], propDecorators: { mo: [{
|
|
12
|
+
type: Input
|
|
13
|
+
}] } });
|
|
14
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FsZW5kYXItbGlzdC1pdGVtLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2JhcnNhLWNhbGVuZGFyL3NyYy9saWIvY2FsZW5kYXItbGlzdC1pdGVtL2NhbGVuZGFyLWxpc3QtaXRlbS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9iYXJzYS1jYWxlbmRhci9zcmMvbGliL2NhbGVuZGFyLWxpc3QtaXRlbS9jYWxlbmRhci1saXN0LWl0ZW0uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFMUUsT0FBTyxFQUFFLGFBQWEsRUFBK0IsTUFBTSxzQkFBc0IsQ0FBQzs7QUFPbEYsTUFBTSxPQUFPLHlCQUEwQixTQUFRLGFBQWE7OEdBQS9DLHlCQUF5QjtrR0FBekIseUJBQXlCLDBHQ1R0QyxzaEJBWUE7OzJGREhhLHlCQUF5QjtrQkFOckMsU0FBUzsrQkFDSSx1QkFBdUIsbUJBR2hCLHVCQUF1QixDQUFDLE1BQU07OEJBR3RDLEVBQUU7c0JBQVYsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcblxyXG5pbXBvcnQgeyBCYXNlQ29tcG9uZW50LCBDYWxlbmRhck1ldGFvYmplY3REYXRhTW9kZWwgfSBmcm9tICdiYXJzYS1ub3Zpbi1yYXktY29yZSc7XHJcbkBDb21wb25lbnQoe1xyXG4gICAgc2VsZWN0b3I6ICdiYy1jYWxlbmRhci1saXN0LWl0ZW0nLFxyXG4gICAgdGVtcGxhdGVVcmw6ICcuL2NhbGVuZGFyLWxpc3QtaXRlbS5jb21wb25lbnQuaHRtbCcsXHJcbiAgICBzdHlsZVVybHM6IFsnLi9jYWxlbmRhci1saXN0LWl0ZW0uY29tcG9uZW50LnNjc3MnXSxcclxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBDYWxlbmRhckxpc3RJdGVtQ29tcG9uZW50IGV4dGVuZHMgQmFzZUNvbXBvbmVudCB7XHJcbiAgICBASW5wdXQoKSBtbzogQ2FsZW5kYXJNZXRhb2JqZWN0RGF0YU1vZGVsO1xyXG59XHJcbiIsIjxkaXYgY2xhc3M9XCJ3cmFwcGVyXCI+XHJcbiAgICA8ZGl2IGZsZXhTaHJpbms9XCIxXCIgY2xhc3M9XCJkYXktd3JhcHBlclwiPlxyXG4gICAgICAgIDxMYWJlbCBbdGV4dF09XCJtby4kU3RhcnRUaW1lc1wiPjwvTGFiZWw+XHJcbiAgICAgICAgPExhYmVsIGNsYXNzPVwiZWxhXCIgW3RleHRdPVwiJ9in2YTbjCdcIj48L0xhYmVsPlxyXG4gICAgICAgIDxMYWJlbCBbdGV4dF09XCJtby4kRW5kVGltZXNcIj48L0xhYmVsPlxyXG4gICAgPC9kaXY+XHJcbiAgICA8ZGl2IGNsYXNzPVwiY29sb3JcIiBbc3R5bGUuYmFja2dyb3VuZC1jb2xvcl09XCJtby4kQ29sb3JcIj48L2Rpdj5cclxuICAgIDxkaXYgY2xhc3M9XCJldmVudC13cmFwcGVyXCI+XHJcbiAgICAgICAgPExhYmVsIGNsYXNzPVwidGl0bGVcIiBbdGV4dF09XCJtby4kVGl0bGVcIj48L0xhYmVsPlxyXG4gICAgICAgIDxMYWJlbCBjbGFzcz1cImRlc2NcIiBbdGV4dF09XCJtby4kTm90ZXNcIj48L0xhYmVsPlxyXG4gICAgPC9kaXY+XHJcbjwvZGl2PlxyXG4iXX0=
|
|
@@ -0,0 +1,246 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
+
import { BaseComponent } from 'barsa-novin-ray-core';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "../days-in-week.pipe";
|
|
5
|
+
import * as i2 from "../services/calendar.service";
|
|
6
|
+
import * as i3 from "@angular/common";
|
|
7
|
+
import * as i4 from "barsa-novin-ray-core";
|
|
8
|
+
import * as i5 from "@fundamental-ngx/core/content-density";
|
|
9
|
+
import * as i6 from "@fundamental-ngx/core/button";
|
|
10
|
+
import * as i7 from "@fundamental-ngx/core/popover";
|
|
11
|
+
import * as i8 from "@fundamental-ngx/core/table";
|
|
12
|
+
import * as i9 from "../day-number-box/day-number-box.component";
|
|
13
|
+
import * as i10 from "../event-button/event-button.component";
|
|
14
|
+
import * as i11 from "../day-event-list/day-event-list.component";
|
|
15
|
+
import * as i12 from "../equal-date.pipe";
|
|
16
|
+
export class CalendarMonthComponent extends BaseComponent {
|
|
17
|
+
constructor(daysInWeek, _cdr, _calendarService) {
|
|
18
|
+
super();
|
|
19
|
+
this.daysInWeek = daysInWeek;
|
|
20
|
+
this._cdr = _cdr;
|
|
21
|
+
this._calendarService = _calendarService;
|
|
22
|
+
this.datePicker = false;
|
|
23
|
+
this.rangePicker = false;
|
|
24
|
+
this.canDelete = false;
|
|
25
|
+
this.canAdd = false;
|
|
26
|
+
this.canEdit = false;
|
|
27
|
+
this.editEvent = new EventEmitter();
|
|
28
|
+
this.deleteEvent = new EventEmitter();
|
|
29
|
+
this.daySelect = new EventEmitter();
|
|
30
|
+
this.dayClick = new EventEmitter();
|
|
31
|
+
this.dayMouseMove = new EventEmitter();
|
|
32
|
+
this.dayMouseUp = new EventEmitter();
|
|
33
|
+
this.dayMouseDown = new EventEmitter();
|
|
34
|
+
this.showEvent = new EventEmitter();
|
|
35
|
+
this.taskHeight = 30;
|
|
36
|
+
this._hasPopoverOpened = [];
|
|
37
|
+
}
|
|
38
|
+
ngOnChanges(changes) {
|
|
39
|
+
super.ngOnChanges(changes);
|
|
40
|
+
let needToDetectChange = false;
|
|
41
|
+
const { containerHeight, deviceSize, moDataList, days, monthWeeksCount, startSelectedDayIndex, endSelectedDayIndex } = changes;
|
|
42
|
+
if (containerHeight && !containerHeight.firstChange) {
|
|
43
|
+
this.fitToContainer(changes.containerHeight.currentValue);
|
|
44
|
+
}
|
|
45
|
+
if (deviceSize && !deviceSize.firstChange) {
|
|
46
|
+
this.prepareWeekDays(changes.deviceSize.currentValue);
|
|
47
|
+
}
|
|
48
|
+
if (moDataList && !moDataList.firstChange) {
|
|
49
|
+
this._prepareDaysTasks(changes.moDataList.currentValue);
|
|
50
|
+
needToDetectChange = true;
|
|
51
|
+
}
|
|
52
|
+
if (days && !days.firstChange) {
|
|
53
|
+
this.fitToContainer(this.containerHeight);
|
|
54
|
+
this._prepareDaysTasks(this.moDataList);
|
|
55
|
+
needToDetectChange = true;
|
|
56
|
+
}
|
|
57
|
+
if (monthWeeksCount && !monthWeeksCount.firstChange) {
|
|
58
|
+
this.fitToContainer(this.containerHeight);
|
|
59
|
+
this._prepareDaysTasks(this.moDataList);
|
|
60
|
+
needToDetectChange = true;
|
|
61
|
+
}
|
|
62
|
+
if ((startSelectedDayIndex && !startSelectedDayIndex.firstChange) ||
|
|
63
|
+
(endSelectedDayIndex && !endSelectedDayIndex.firstChange)) {
|
|
64
|
+
needToDetectChange = true;
|
|
65
|
+
}
|
|
66
|
+
if (needToDetectChange) {
|
|
67
|
+
this._cdr.detectChanges();
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
ngOnInit() {
|
|
71
|
+
super.ngOnInit();
|
|
72
|
+
this.isPickerMode = this.datePicker || this.rangePicker;
|
|
73
|
+
this.prepareWeekDays(this.deviceSize);
|
|
74
|
+
this._prepareDaysTasks(this.moDataList);
|
|
75
|
+
this.fitToContainer(this.containerHeight);
|
|
76
|
+
}
|
|
77
|
+
onDayBoxSelect(day) {
|
|
78
|
+
this._fireDaySelect(day);
|
|
79
|
+
}
|
|
80
|
+
onDaySelect(weekIndex, dayIndex) {
|
|
81
|
+
if (!this.canAdd) {
|
|
82
|
+
return;
|
|
83
|
+
}
|
|
84
|
+
const day = this.days[weekIndex * 7 + dayIndex];
|
|
85
|
+
this._fireDaySelect(day);
|
|
86
|
+
}
|
|
87
|
+
onOpenPopoverChange(isOpen) {
|
|
88
|
+
this._openPopover(isOpen);
|
|
89
|
+
}
|
|
90
|
+
onMoreButton(e, popover) {
|
|
91
|
+
this._preventEvent(e);
|
|
92
|
+
popover.open();
|
|
93
|
+
}
|
|
94
|
+
onTask(e, task) {
|
|
95
|
+
this.showEvent.emit(task);
|
|
96
|
+
}
|
|
97
|
+
onDayClick(day) {
|
|
98
|
+
this.selected = day;
|
|
99
|
+
this.dayClick.emit(day);
|
|
100
|
+
}
|
|
101
|
+
onDayMouseMove(day) {
|
|
102
|
+
this.dayMouseMove.emit(day);
|
|
103
|
+
}
|
|
104
|
+
onDayMouseDown(day) {
|
|
105
|
+
this.dayMouseDown.emit(day);
|
|
106
|
+
}
|
|
107
|
+
onDayMouseUp(day) {
|
|
108
|
+
this.dayMouseUp.emit(day);
|
|
109
|
+
}
|
|
110
|
+
_preventEvent(e) {
|
|
111
|
+
e.stopPropagation();
|
|
112
|
+
e.preventDefault();
|
|
113
|
+
}
|
|
114
|
+
_fireDaySelect(day) {
|
|
115
|
+
if (this._hasPopoverOpened.length === 0) {
|
|
116
|
+
this.daySelect.emit({
|
|
117
|
+
date: day.date
|
|
118
|
+
});
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
_openPopover(isOpen) {
|
|
122
|
+
if (isOpen) {
|
|
123
|
+
this._hasPopoverOpened.push(true);
|
|
124
|
+
}
|
|
125
|
+
else {
|
|
126
|
+
setTimeout(() => {
|
|
127
|
+
this._hasPopoverOpened = [];
|
|
128
|
+
}, 0);
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
prepareWeekDays(deviceSize) {
|
|
132
|
+
if (deviceSize !== 's' && deviceSize !== 'm') {
|
|
133
|
+
this.selectedWeekDays = this.weekDays;
|
|
134
|
+
}
|
|
135
|
+
else {
|
|
136
|
+
this.selectedWeekDays = this.weekDaysMin;
|
|
137
|
+
}
|
|
138
|
+
}
|
|
139
|
+
fitToContainer(containerHeight) {
|
|
140
|
+
let _weeksCount;
|
|
141
|
+
if (this.monthWeeksCount > 0) {
|
|
142
|
+
const weeksCount = this.monthWeeksCount;
|
|
143
|
+
_weeksCount = weeksCount;
|
|
144
|
+
}
|
|
145
|
+
else {
|
|
146
|
+
_weeksCount = this.days.length / 7;
|
|
147
|
+
}
|
|
148
|
+
this.numberOfWeek = Array.from(Array(_weeksCount).keys());
|
|
149
|
+
this.numberOfWeek = this.numberOfWeek.map((value) => value);
|
|
150
|
+
if (this.isPickerMode) {
|
|
151
|
+
this.dayHeight = 40;
|
|
152
|
+
return;
|
|
153
|
+
}
|
|
154
|
+
this.dayHeight = Math.floor(containerHeight / (_weeksCount + 1));
|
|
155
|
+
this.maxTaskCount = Math.floor((this.dayHeight - this.taskHeight) / this.taskHeight);
|
|
156
|
+
if (this.maxTaskCount > 0) {
|
|
157
|
+
this.maxRowTasks = new Array(this.maxTaskCount).fill(0).map((x, i) => i);
|
|
158
|
+
}
|
|
159
|
+
}
|
|
160
|
+
_prepareDaysTasks(calendarTasks) {
|
|
161
|
+
if (this.isPickerMode) {
|
|
162
|
+
this.weekTasksArray = {};
|
|
163
|
+
return;
|
|
164
|
+
}
|
|
165
|
+
const calendarFields = this.calendarFields;
|
|
166
|
+
// Sort all Tasks
|
|
167
|
+
const moDataList = this._calendarService.sortTasks(calendarTasks, calendarFields);
|
|
168
|
+
this.days.forEach((day) => (day.tasks = []));
|
|
169
|
+
const weekTasksArray = [];
|
|
170
|
+
for (let j = 0; j < this.days.length / 7; j++) {
|
|
171
|
+
const days = this.daysInWeek.transform(this.days, j);
|
|
172
|
+
const week = this._calendarService.createWeekTask(days, moDataList, calendarFields, 0);
|
|
173
|
+
weekTasksArray.push(week);
|
|
174
|
+
}
|
|
175
|
+
weekTasksArray.forEach((week) => {
|
|
176
|
+
const arr = Object.values(week);
|
|
177
|
+
for (let i = arr.length; i < this.maxTaskCount; i++) {
|
|
178
|
+
week[i.toString()] = [];
|
|
179
|
+
}
|
|
180
|
+
});
|
|
181
|
+
// به ازای هر ردیف تسک باید تعداد 7 ستون اضافه گردد و برای ستونی که تسکی ندارد یک جای خالی colspan 1 میگذاریم
|
|
182
|
+
weekTasksArray.forEach((week) => {
|
|
183
|
+
this._calendarService.fillWeek(week);
|
|
184
|
+
});
|
|
185
|
+
this.weekTasksArray = weekTasksArray;
|
|
186
|
+
}
|
|
187
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: CalendarMonthComponent, deps: [{ token: i1.DaysInWeekPipe }, { token: i0.ChangeDetectorRef }, { token: i2.CalendarService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
188
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.5", type: CalendarMonthComponent, selector: "bc-calendar-month", inputs: { monthWeeksCount: "monthWeeksCount", weekDays: "weekDays", weekDaysMin: "weekDaysMin", today: "today", containerHeight: "containerHeight", days: "days", calendarFields: "calendarFields", rtl: "rtl", deviceSize: "deviceSize", moDataList: "moDataList", datePicker: "datePicker", rangePicker: "rangePicker", canDelete: "canDelete", canAdd: "canAdd", canEdit: "canEdit", selectedDate: "selectedDate", startSelectedDayIndex: "startSelectedDayIndex", endSelectedDayIndex: "endSelectedDayIndex" }, outputs: { editEvent: "editEvent", deleteEvent: "deleteEvent", daySelect: "daySelect", dayClick: "dayClick", dayMouseMove: "dayMouseMove", dayMouseUp: "dayMouseUp", dayMouseDown: "dayMouseDown", showEvent: "showEvent" }, usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<table fd-table class=\"table-header\" [fdCompact] [attr.picker]=\"datePicker\">\n <thead fd-table-header>\n <tr fd-table-row>\n @for (weekDay of selectedWeekDays; track weekDay) {\n <th class=\"weekday-header\" fd-table-cell [class.noborder]=\"isPickerMode\">\n {{ weekDay | slice: 0:1 }}\n </th>\n }\n </tr>\n </thead>\n <tbody fd-table-body>\n @for (weekDay of numberOfWeek; track weekDay) {\n <tr fd-table-row>\n <td [style.height.px]=\"dayHeight\" fd-table-cell colspan=\"7\" [style.border]=\"isPickerMode ? 'none' : null\">\n <ng-container\n *ngTemplateOutlet=\"\n renderTasks;\n context: {\n $implicit: isPickerMode ? null : moDataList[weekDay],\n weekIndex: weekDay,\n days: days | daysInWeek: weekDay,\n maxRowTasks: maxRowTasks,\n weekDays: weekDays,\n calendarFields: calendarFields,\n deviceSize: deviceSize,\n rtl: rtl,\n isPickerMode: isPickerMode\n }\n \"\n ></ng-container>\n </td>\n </tr>\n }\n </tbody>\n</table>\n<ng-template\n #renderTasks\n let-task\n let-weekIndex=\"weekIndex\"\n let-weekDays=\"weekDays\"\n let-days=\"days\"\n let-maxRowTasks=\"maxRowTasks\"\n let-calendarFields=\"calendarFields\"\n let-deviceSize=\"deviceSize\"\n let-rtl=\"rtl\"\n let-isPickerMode=\"isPickerMode\"\n>\n <table fd-table-body class=\"table-content\" [compact]=\"true\">\n <tbody>\n <tr fd-table-row class=\"row-day-number\" [attr.rtl]=\"rtl\">\n @for (day of days; track day) {\n <td fd-table-cell [class.noborder]=\"isPickerMode\">\n <bc-day-number-box\n [ngClass]=\"{\n 'fd-calendar__item': isPickerMode,\n '!tw-border !tw-rounded-md tw-transition-all tw-cursor-pointer':\n isPickerMode && day.isInMonth,\n '!tw-bg-transparent tw-border-gray-100 hover:!tw-border-gray-300':\n isPickerMode && day.isInMonth && !day.isToday,\n 'fd-calendar__item--other-month': isPickerMode && !day.isInMonth,\n 'fd-calendar__item--weekend': isPickerMode && day.isWeekend,\n '!tw-bg-blue-500 hover:!tw-bg-blue-600': day.isToday\n }\"\n [isPickerMode]=\"isPickerMode\"\n [day]=\"day\"\n [isActive]=\"\n day.index === startSelectedDayIndex || day.index === endSelectedDayIndex || day.date\n | equalDate: selectedDate\n \"\n [itemInRange]=\"\n startSelectedDayIndex !== undefined &&\n endSelectedDayIndex !== undefined &&\n day.index >= startSelectedDayIndex &&\n day.index <= endSelectedDayIndex\n \"\n (dayClick)=\"onDayClick(day)\"\n (dayMouseMove)=\"onDayMouseMove(day)\"\n (dayMouseDown)=\"onDayMouseDown(day)\"\n (dayMouseUp)=\"onDayMouseUp(day)\"\n ></bc-day-number-box>\n </td>\n }\n </tr>\n @if (!isPickerMode) {\n <ng-container\n *ngTemplateOutlet=\"\n renderDayTasks;\n context: {\n $implicit: weekTasksArray[weekIndex],\n maxRowTasks: maxRowTasks,\n weekIndex: weekIndex,\n deviceSize: deviceSize,\n calendarFields: calendarFields,\n weekDays: weekDays\n }\n \"\n ></ng-container>\n <tr fd-table-row>\n @for (day of days; track day) {\n <td fd-table-cell class=\"more-fd\" (click)=\"onDayBoxSelect(day)\">\n @if (maxRowTasks?.length < day.tasks.length) {\n <button fd-button (click)=\"onMoreButton($event, popover)\" [fdType]=\"'transparent'\" [compact]=\"true\">\n {{ day.tasks?.length - maxRowTasks?.length }}\n {{ 'More' | bbbTranslate }}\n </button>\n <fd-popover\n #popover\n [mobile]=\"deviceSize === 's'\"\n placement=\"bottom\"\n [focusTrapped]=\"true\"\n [focusAutoCapture]=\"true\"\n (isOpenChange)=\"onOpenPopoverChange($event)\"\n >\n <bc-day-event-list\n [day]=\"day\"\n [calendarFields]=\"calendarFields\"\n [deviceSize]=\"deviceSize\"\n [weekDays]=\"weekDays\"\n [rtl]=\"rtl\"\n [canDelete]=\"canDelete\"\n [canEdit]=\"canEdit\"\n [popover]=\"popover\"\n (deleteEvent)=\"deleteEvent.emit($event)\"\n (editEvent)=\"editEvent.emit($event)\"\n ></bc-day-event-list>\n </fd-popover>\n }\n </td>\n }\n </tr>\n }\n </tbody>\n </table>\n</ng-template>\n\n<ng-template\n #renderDayTasks\n let-weekTasks\n let-maxRowTasks=\"maxRowTasks\"\n let-weekIndex=\"weekIndex\"\n let-deviceSize=\"deviceSize\"\n let-calendarFields=\"calendarFields\"\n let-weekDays=\"weekDays\"\n>\n @for (rowTask of maxRowTasks; track rowTask; let i = $index) {\n <tr fd-table-row>\n @if (!weekTasks[i] || weekTasks[i].length === 0) { @for (day of weekDays; track day) {\n <td fd-table-cell></td>\n } } @for (task of weekTasks[i]; track task; let dayIndex = $index) { @if (task.colSpan) {\n <td fd-table-cell [attr.colspan]=\"task.colSpan\">\n @if (task.event) {\n <bc-event-button\n [task]=\"task\"\n [calendarFields]=\"calendarFields\"\n [deviceSize]=\"deviceSize\"\n [rtl]=\"rtl\"\n [canDelete]=\"canDelete\"\n [canEdit]=\"canEdit\"\n (deleteEvent)=\"deleteEvent.emit($event)\"\n (editEvent)=\"editEvent.emit($event)\"\n (openPopoverChange)=\"onOpenPopoverChange($event)\"\n ></bc-event-button>\n } @else {\n <div style=\"width: 100%; height: 100%\" (click)=\"onDaySelect(weekIndex, dayIndex)\"></div>\n }\n </td>\n } }\n </tr>\n }\n</ng-template>\n", styles: [":host{display:block}table{table-layout:fixed}.table-header td{padding:0!important}.table-content{width:100%;height:100%;border:none;border-spacing:0}.table-content td{border:none;border-right:var(--sapList_BorderWidth, .0625rem) solid var(--sapList_BorderColor, #e5e5e5);height:1.425rem}.table-content .row-day-number[rtl=true] td:first-child{border-right:none}.table-content .row-day-number[rtl=\"fa;se\"] td:first-child{border-left:none}table td{overflow:hidden}thead tr{border-bottom:none!important}thead tr th{text-align:center!important;background-color:var(--sapList_Background, #fff)}.weekday-header,.row-day-number td{width:100%}tbody tr td{padding-top:5px}tbody tr:first-child td{padding-top:0}.fd-table__cell{padding:0 .5rem!important}.more-fd{text-align:center!important}.more-fd button{font-size:12px}.fd-calendar__item{font-size:.875rem;font-size:var(--sapFontSize, .875rem);line-height:1.4;line-height:var(--sapContent_LineHeight, 1.4);color:#32363a;color:var(--sapTextColor, #32363a);font-family:\"72\",\"72full\",Arial,Helvetica,sans-serif;font-family:var(--sapFontFamily, \"72\", \"72full\", Arial, Helvetica, sans-serif);font-weight:400;box-sizing:border-box;padding:0;overflow:hidden;position:relative;height:2.5rem;margin:.125rem;min-width:2.125rem;border-radius:.25rem;border-radius:var(--sapElement_BorderCornerRadius, .25rem);background-color:#fafafa;background-color:var(--sapLegend_WorkingBackground, #fafafa);flex:1 1 .375rem;padding:1px!important}.fd-calendar__item.fd-calendar__item--other-month{background-color:var(--sapList_Background, #fff)}.fd-calendar__item.fd-calendar__item--weekend{background-color:var(--sapLegend_NotWorkingBackground, #dedede)}.fd-calendar__item.is-active{background-color:var(--sapContent_Selected_Background, #0854a0);border:var(--fdCalendar_Active_Item_Border, none)}.fd-calendar__item.fd-calendar__item--range{border:.0625rem solid var(--sapList_SelectionBorderColor, #0854a0);background-color:var(--sapList_SelectionBackgroundColor, #e5f0fa)}table[picker=true] thead,table[picker=true] tbody{border:none}\n"], dependencies: [{ kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i4.MobileDirective, selector: "[mobile]" }, { kind: "directive", type: i5.ContentDensityDirective, selector: "[fdContentDensity]:not([fdCompact]):not([fdCondensed]):not([fdCozy]), [fdCompact]:not([fdContentDensity]):not([fdCondensed]):not([fdCozy]), [fdCondensed]:not([fdContentDensity]):not([fdCompact]):not([fdCozy]), [fdCozy]:not([fdContentDensity]):not([fdCompact]):not([fdCondensed])", inputs: ["fdContentDensity", "fdCompact", "fdCondensed", "fdCozy"], exportAs: ["fdContentDensity"] }, { kind: "component", type: i6.ButtonComponent, selector: "button[fd-button], a[fd-button]", inputs: ["class"], exportAs: ["fd-button"] }, { kind: "component", type: i7.PopoverComponent, selector: "fd-popover", inputs: ["title", "trigger", "fixedPosition", "id", "mobile", "mobileConfig", "preventSpaceKeyScroll"] }, { kind: "component", type: i8.TableComponent, selector: "table[fd-table]", inputs: ["noBorderX", "noBorderY", "noOuterBorder", "topBorder", "popIn", "responsive", "keys", "allCellsFocusable"], exportAs: ["fd-table"] }, { kind: "directive", type: i8.TableHeaderDirective, selector: "[fdTableHeader], [fd-table-header]", inputs: ["noBorderX", "noBorderY"] }, { kind: "directive", type: i8.TableBodyDirective, selector: "[fdTableBody], [fd-table-body]", inputs: ["noBorderX", "noBorderY"] }, { kind: "directive", type: i8.TableRowDirective, selector: "[fdTableRow], [fd-table-row]", inputs: ["activable", "highlightActive", "hoverable", "focusable", "main", "secondary", "active"] }, { kind: "directive", type: i8.TableCellDirective, selector: "[fdTableCell], [fd-table-cell]", inputs: ["noBorderX", "noBorderY", "activable", "focusable", "hoverable", "fitContent", "noPadding", "noData", "key"] }, { kind: "component", type: i9.DayNumberBoxComponent, selector: "bc-day-number-box", inputs: ["isWeekMode", "isSingleDay", "day", "isPickerMode", "itemInRange", "isActive"], outputs: ["dayClick", "dayMouseDown", "dayMouseUp", "dayMouseMove"] }, { kind: "component", type: i10.EventButtonComponent, selector: "bc-event-button", inputs: ["buttonTemplate", "calendarFields", "task", "rtl", "canDelete", "canEdit", "index", "deviceSize"], outputs: ["deleteEvent", "editEvent", "openPopoverChange"] }, { kind: "component", type: i11.DayEventListComponent, selector: "bc-day-event-list", inputs: ["day", "deviceSize", "weekDays", "calendarFields", "rtl", "canDelete", "canEdit", "popover"], outputs: ["deleteEvent", "editEvent", "openPopOver"] }, { kind: "pipe", type: i3.SlicePipe, name: "slice" }, { kind: "pipe", type: i4.BbbTranslatePipe, name: "bbbTranslate" }, { kind: "pipe", type: i1.DaysInWeekPipe, name: "daysInWeek" }, { kind: "pipe", type: i12.EqualDatePipe, name: "equalDate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
189
|
+
}
|
|
190
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: CalendarMonthComponent, decorators: [{
|
|
191
|
+
type: Component,
|
|
192
|
+
args: [{ selector: 'bc-calendar-month', changeDetection: ChangeDetectionStrategy.OnPush, template: "<table fd-table class=\"table-header\" [fdCompact] [attr.picker]=\"datePicker\">\n <thead fd-table-header>\n <tr fd-table-row>\n @for (weekDay of selectedWeekDays; track weekDay) {\n <th class=\"weekday-header\" fd-table-cell [class.noborder]=\"isPickerMode\">\n {{ weekDay | slice: 0:1 }}\n </th>\n }\n </tr>\n </thead>\n <tbody fd-table-body>\n @for (weekDay of numberOfWeek; track weekDay) {\n <tr fd-table-row>\n <td [style.height.px]=\"dayHeight\" fd-table-cell colspan=\"7\" [style.border]=\"isPickerMode ? 'none' : null\">\n <ng-container\n *ngTemplateOutlet=\"\n renderTasks;\n context: {\n $implicit: isPickerMode ? null : moDataList[weekDay],\n weekIndex: weekDay,\n days: days | daysInWeek: weekDay,\n maxRowTasks: maxRowTasks,\n weekDays: weekDays,\n calendarFields: calendarFields,\n deviceSize: deviceSize,\n rtl: rtl,\n isPickerMode: isPickerMode\n }\n \"\n ></ng-container>\n </td>\n </tr>\n }\n </tbody>\n</table>\n<ng-template\n #renderTasks\n let-task\n let-weekIndex=\"weekIndex\"\n let-weekDays=\"weekDays\"\n let-days=\"days\"\n let-maxRowTasks=\"maxRowTasks\"\n let-calendarFields=\"calendarFields\"\n let-deviceSize=\"deviceSize\"\n let-rtl=\"rtl\"\n let-isPickerMode=\"isPickerMode\"\n>\n <table fd-table-body class=\"table-content\" [compact]=\"true\">\n <tbody>\n <tr fd-table-row class=\"row-day-number\" [attr.rtl]=\"rtl\">\n @for (day of days; track day) {\n <td fd-table-cell [class.noborder]=\"isPickerMode\">\n <bc-day-number-box\n [ngClass]=\"{\n 'fd-calendar__item': isPickerMode,\n '!tw-border !tw-rounded-md tw-transition-all tw-cursor-pointer':\n isPickerMode && day.isInMonth,\n '!tw-bg-transparent tw-border-gray-100 hover:!tw-border-gray-300':\n isPickerMode && day.isInMonth && !day.isToday,\n 'fd-calendar__item--other-month': isPickerMode && !day.isInMonth,\n 'fd-calendar__item--weekend': isPickerMode && day.isWeekend,\n '!tw-bg-blue-500 hover:!tw-bg-blue-600': day.isToday\n }\"\n [isPickerMode]=\"isPickerMode\"\n [day]=\"day\"\n [isActive]=\"\n day.index === startSelectedDayIndex || day.index === endSelectedDayIndex || day.date\n | equalDate: selectedDate\n \"\n [itemInRange]=\"\n startSelectedDayIndex !== undefined &&\n endSelectedDayIndex !== undefined &&\n day.index >= startSelectedDayIndex &&\n day.index <= endSelectedDayIndex\n \"\n (dayClick)=\"onDayClick(day)\"\n (dayMouseMove)=\"onDayMouseMove(day)\"\n (dayMouseDown)=\"onDayMouseDown(day)\"\n (dayMouseUp)=\"onDayMouseUp(day)\"\n ></bc-day-number-box>\n </td>\n }\n </tr>\n @if (!isPickerMode) {\n <ng-container\n *ngTemplateOutlet=\"\n renderDayTasks;\n context: {\n $implicit: weekTasksArray[weekIndex],\n maxRowTasks: maxRowTasks,\n weekIndex: weekIndex,\n deviceSize: deviceSize,\n calendarFields: calendarFields,\n weekDays: weekDays\n }\n \"\n ></ng-container>\n <tr fd-table-row>\n @for (day of days; track day) {\n <td fd-table-cell class=\"more-fd\" (click)=\"onDayBoxSelect(day)\">\n @if (maxRowTasks?.length < day.tasks.length) {\n <button fd-button (click)=\"onMoreButton($event, popover)\" [fdType]=\"'transparent'\" [compact]=\"true\">\n {{ day.tasks?.length - maxRowTasks?.length }}\n {{ 'More' | bbbTranslate }}\n </button>\n <fd-popover\n #popover\n [mobile]=\"deviceSize === 's'\"\n placement=\"bottom\"\n [focusTrapped]=\"true\"\n [focusAutoCapture]=\"true\"\n (isOpenChange)=\"onOpenPopoverChange($event)\"\n >\n <bc-day-event-list\n [day]=\"day\"\n [calendarFields]=\"calendarFields\"\n [deviceSize]=\"deviceSize\"\n [weekDays]=\"weekDays\"\n [rtl]=\"rtl\"\n [canDelete]=\"canDelete\"\n [canEdit]=\"canEdit\"\n [popover]=\"popover\"\n (deleteEvent)=\"deleteEvent.emit($event)\"\n (editEvent)=\"editEvent.emit($event)\"\n ></bc-day-event-list>\n </fd-popover>\n }\n </td>\n }\n </tr>\n }\n </tbody>\n </table>\n</ng-template>\n\n<ng-template\n #renderDayTasks\n let-weekTasks\n let-maxRowTasks=\"maxRowTasks\"\n let-weekIndex=\"weekIndex\"\n let-deviceSize=\"deviceSize\"\n let-calendarFields=\"calendarFields\"\n let-weekDays=\"weekDays\"\n>\n @for (rowTask of maxRowTasks; track rowTask; let i = $index) {\n <tr fd-table-row>\n @if (!weekTasks[i] || weekTasks[i].length === 0) { @for (day of weekDays; track day) {\n <td fd-table-cell></td>\n } } @for (task of weekTasks[i]; track task; let dayIndex = $index) { @if (task.colSpan) {\n <td fd-table-cell [attr.colspan]=\"task.colSpan\">\n @if (task.event) {\n <bc-event-button\n [task]=\"task\"\n [calendarFields]=\"calendarFields\"\n [deviceSize]=\"deviceSize\"\n [rtl]=\"rtl\"\n [canDelete]=\"canDelete\"\n [canEdit]=\"canEdit\"\n (deleteEvent)=\"deleteEvent.emit($event)\"\n (editEvent)=\"editEvent.emit($event)\"\n (openPopoverChange)=\"onOpenPopoverChange($event)\"\n ></bc-event-button>\n } @else {\n <div style=\"width: 100%; height: 100%\" (click)=\"onDaySelect(weekIndex, dayIndex)\"></div>\n }\n </td>\n } }\n </tr>\n }\n</ng-template>\n", styles: [":host{display:block}table{table-layout:fixed}.table-header td{padding:0!important}.table-content{width:100%;height:100%;border:none;border-spacing:0}.table-content td{border:none;border-right:var(--sapList_BorderWidth, .0625rem) solid var(--sapList_BorderColor, #e5e5e5);height:1.425rem}.table-content .row-day-number[rtl=true] td:first-child{border-right:none}.table-content .row-day-number[rtl=\"fa;se\"] td:first-child{border-left:none}table td{overflow:hidden}thead tr{border-bottom:none!important}thead tr th{text-align:center!important;background-color:var(--sapList_Background, #fff)}.weekday-header,.row-day-number td{width:100%}tbody tr td{padding-top:5px}tbody tr:first-child td{padding-top:0}.fd-table__cell{padding:0 .5rem!important}.more-fd{text-align:center!important}.more-fd button{font-size:12px}.fd-calendar__item{font-size:.875rem;font-size:var(--sapFontSize, .875rem);line-height:1.4;line-height:var(--sapContent_LineHeight, 1.4);color:#32363a;color:var(--sapTextColor, #32363a);font-family:\"72\",\"72full\",Arial,Helvetica,sans-serif;font-family:var(--sapFontFamily, \"72\", \"72full\", Arial, Helvetica, sans-serif);font-weight:400;box-sizing:border-box;padding:0;overflow:hidden;position:relative;height:2.5rem;margin:.125rem;min-width:2.125rem;border-radius:.25rem;border-radius:var(--sapElement_BorderCornerRadius, .25rem);background-color:#fafafa;background-color:var(--sapLegend_WorkingBackground, #fafafa);flex:1 1 .375rem;padding:1px!important}.fd-calendar__item.fd-calendar__item--other-month{background-color:var(--sapList_Background, #fff)}.fd-calendar__item.fd-calendar__item--weekend{background-color:var(--sapLegend_NotWorkingBackground, #dedede)}.fd-calendar__item.is-active{background-color:var(--sapContent_Selected_Background, #0854a0);border:var(--fdCalendar_Active_Item_Border, none)}.fd-calendar__item.fd-calendar__item--range{border:.0625rem solid var(--sapList_SelectionBorderColor, #0854a0);background-color:var(--sapList_SelectionBackgroundColor, #e5f0fa)}table[picker=true] thead,table[picker=true] tbody{border:none}\n"] }]
|
|
193
|
+
}], ctorParameters: () => [{ type: i1.DaysInWeekPipe }, { type: i0.ChangeDetectorRef }, { type: i2.CalendarService }], propDecorators: { monthWeeksCount: [{
|
|
194
|
+
type: Input
|
|
195
|
+
}], weekDays: [{
|
|
196
|
+
type: Input
|
|
197
|
+
}], weekDaysMin: [{
|
|
198
|
+
type: Input
|
|
199
|
+
}], today: [{
|
|
200
|
+
type: Input
|
|
201
|
+
}], containerHeight: [{
|
|
202
|
+
type: Input
|
|
203
|
+
}], days: [{
|
|
204
|
+
type: Input
|
|
205
|
+
}], calendarFields: [{
|
|
206
|
+
type: Input
|
|
207
|
+
}], rtl: [{
|
|
208
|
+
type: Input
|
|
209
|
+
}], deviceSize: [{
|
|
210
|
+
type: Input
|
|
211
|
+
}], moDataList: [{
|
|
212
|
+
type: Input
|
|
213
|
+
}], datePicker: [{
|
|
214
|
+
type: Input
|
|
215
|
+
}], rangePicker: [{
|
|
216
|
+
type: Input
|
|
217
|
+
}], canDelete: [{
|
|
218
|
+
type: Input
|
|
219
|
+
}], canAdd: [{
|
|
220
|
+
type: Input
|
|
221
|
+
}], canEdit: [{
|
|
222
|
+
type: Input
|
|
223
|
+
}], selectedDate: [{
|
|
224
|
+
type: Input
|
|
225
|
+
}], startSelectedDayIndex: [{
|
|
226
|
+
type: Input
|
|
227
|
+
}], endSelectedDayIndex: [{
|
|
228
|
+
type: Input
|
|
229
|
+
}], editEvent: [{
|
|
230
|
+
type: Output
|
|
231
|
+
}], deleteEvent: [{
|
|
232
|
+
type: Output
|
|
233
|
+
}], daySelect: [{
|
|
234
|
+
type: Output
|
|
235
|
+
}], dayClick: [{
|
|
236
|
+
type: Output
|
|
237
|
+
}], dayMouseMove: [{
|
|
238
|
+
type: Output
|
|
239
|
+
}], dayMouseUp: [{
|
|
240
|
+
type: Output
|
|
241
|
+
}], dayMouseDown: [{
|
|
242
|
+
type: Output
|
|
243
|
+
}], showEvent: [{
|
|
244
|
+
type: Output
|
|
245
|
+
}] } });
|
|
246
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FsZW5kYXItbW9udGguY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFyc2EtY2FsZW5kYXIvc3JjL2xpYi9jYWxlbmRhci1tb250aC9jYWxlbmRhci1tb250aC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9iYXJzYS1jYWxlbmRhci9zcmMvbGliL2NhbGVuZGFyLW1vbnRoL2NhbGVuZGFyLW1vbnRoLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDSCx1QkFBdUIsRUFFdkIsU0FBUyxFQUNULFlBQVksRUFDWixLQUFLLEVBR0wsTUFBTSxFQUVULE1BQU0sZUFBZSxDQUFDO0FBRXZCLE9BQU8sRUFBRSxhQUFhLEVBQW9FLE1BQU0sc0JBQXNCLENBQUM7Ozs7Ozs7Ozs7Ozs7O0FBWXZILE1BQU0sT0FBTyxzQkFBdUIsU0FBUSxhQUFhO0lBMkNyRCxZQUNZLFVBQTBCLEVBQzFCLElBQXVCLEVBQ3ZCLGdCQUFpQztRQUV6QyxLQUFLLEVBQUUsQ0FBQztRQUpBLGVBQVUsR0FBVixVQUFVLENBQWdCO1FBQzFCLFNBQUksR0FBSixJQUFJLENBQW1CO1FBQ3ZCLHFCQUFnQixHQUFoQixnQkFBZ0IsQ0FBaUI7UUFuQ3BDLGVBQVUsR0FBRyxLQUFLLENBQUM7UUFDbkIsZ0JBQVcsR0FBRyxLQUFLLENBQUM7UUFDcEIsY0FBUyxHQUFHLEtBQUssQ0FBQztRQUNsQixXQUFNLEdBQUcsS0FBSyxDQUFDO1FBQ2YsWUFBTyxHQUFHLEtBQUssQ0FBQztRQUlmLGNBQVMsR0FBRyxJQUFJLFlBQVksRUFBdUIsQ0FBQztRQUNwRCxnQkFBVyxHQUFHLElBQUksWUFBWSxFQUF1QixDQUFDO1FBQ3RELGNBQVMsR0FBRyxJQUFJLFlBQVksRUFBTyxDQUFDO1FBQ3BDLGFBQVEsR0FBRyxJQUFJLFlBQVksRUFBTyxDQUFDO1FBQ25DLGlCQUFZLEdB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USxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ3pDLENBQUMsQ0FBQyxDQUFDO1FBQ0gsSUFBSSxDQUFDLGNBQWMsR0FBRyxjQUFjLENBQUM7SUFDekMsQ0FBQzs4R0FyTlEsc0JBQXNCO2tHQUF0QixzQkFBc0Isc3pCQ3hCbkMsc3hPQTBLQTs7MkZEbEphLHNCQUFzQjtrQkFObEMsU0FBUzsrQkFDSSxtQkFBbUIsbUJBR1osdUJBQXVCLENBQUMsTUFBTTtpSkFHdEMsZUFBZTtzQkFBdkIsS0FBSztnQkFDRyxRQUFRO3NCQUFoQixLQUFLO2dCQUNHLFdBQVc7c0JBQW5CLEtBQUs7Z0JBQ0csS0FBSztzQkFBYixLQUFLO2dCQUNHLGVBQWU7c0JBQXZCLEtBQUs7Z0JBQ0csSUFBSTtzQkFBWixLQUFLO2dCQUNHLGNBQWM7c0JBQXRCLEtBQUs7Z0JBQ0csR0FBRztzQkFBWCxLQUFLO2dCQUNHLFVBQVU7c0JBQWxCLEtBQUs7Z0JBQ0csVUFBVTtzQkFBbEIsS0FBSztnQkFDRyxVQUFVO3NCQUFsQixLQUFLO2dCQUNHLFdBQVc7c0JBQW5CLEtBQUs7Z0JBQ0csU0FBUztzQkFBakIsS0FBSztnQkFDRyxNQUFNO3NCQUFkLEtBQUs7Z0JBQ0csT0FBTztzQkFBZixLQUFLO2dCQUNHLFlBQVk7c0JBQXBCLEtBQUs7Z0JBQ0cscUJBQXFCO3NCQUE3QixLQUFLO2dCQUNHLG1CQUFtQjtzQkFBM0IsS0FBSztnQkFDSSxTQUFTO3NCQUFsQixNQUFNO2dCQUNHLFdBQVc7c0JBQXBCLE1BQU07Z0JBQ0csU0FBUztzQkFBbEIsTUFBTTtnQkFDRyxRQUFRO3NCQUFqQixNQUFNO2dCQUNHLFlBQVk7c0JBQXJCLE1BQU07Z0JBQ0csVUFBVTtzQkFBbkIsTUFBTTtnQkFDRyxZQUFZO3NCQUFyQixNQUFNO2dCQUNHLFNBQVM7c0JBQWxCLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICAgIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LFxuICAgIENoYW5nZURldGVjdG9yUmVmLFxuICAgIENvbXBvbmVudCxcbiAgICBFdmVudEVtaXR0ZXIsXG4gICAgSW5wdXQsXG4gICAgT25DaGFuZ2VzLFxuICAgIE9uSW5pdCxcbiAgICBPdXRwdXQsXG4gICAgU2ltcGxlQ2hhbmdlc1xufSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgQmFzZUNvbXBvbmVudCwgQ2FsZW5kYXJGaWVsZHMsIENhbGVuZGFyTWV0YW9iamVjdERhdGFNb2RlbCwgTWV0YW9iamVjdERhdGFNb2RlbCB9IGZyb20gJ2JhcnNhLW5vdmluLXJheS1jb3JlJztcbmltcG9ydCB7IERheSB9IGZyb20gJy4uL21vZGVscyc7XG5pbXBvcnQgeyBEYXlzSW5XZWVrUGlwZSB9IGZyb20gJy4uL2RheXMtaW4td2Vlay5waXBlJztcblxuaW1wb3J0IHsgQ2FsZW5kYXJTZXJ2aWNlIH0gZnJvbSAnLi4vc2VydmljZXMvY2FsZW5kYXIuc2VydmljZSc7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAnYmMtY2FsZW5kYXItbW9udGgnLFxuICAgIHRlbXBsYXRlVXJsOiAnLi9jYWxlbmRhci1tb250aC5jb21wb25lbnQuaHRtbCcsXG4gICAgc3R5bGVVcmxzOiBbJy4vY2FsZW5kYXItbW9udGguY29tcG9uZW50LnNjc3MnXSxcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxufSlcbmV4cG9ydCBjbGFzcyBDYWxlbmRhck1vbnRoQ29tcG9uZW50IGV4dGVuZHMgQmFzZUNvbXBvbmVudCBpbXBsZW1lbnRzIE9uQ2hhbmdlcywgT25Jbml0IHtcbiAgICBASW5wdXQoKSBtb250aFdlZWtzQ291bnQ6IG51bWJlcjtcbiAgICBASW5wdXQoKSB3ZWVrRGF5czogc3RyaW5nW107XG4gICAgQElucHV0KCkgd2Vla0RheXNNaW46IHN0cmluZ1tdO1xuICAgIEBJbnB1dCgpIHRvZGF5OiBEYXRlO1xuICAgIEBJbnB1dCgpIGNvbnRhaW5lckhlaWdodDogbnVtYmVyO1xuICAgIEBJbnB1dCgpIGRheXM6IERheVtdO1xuICAgIEBJbnB1dCgpIGNhbGVuZGFyRmllbGRzOiBDYWxlbmRhckZpZWxkcztcbiAgICBASW5wdXQoKSBydGw6IGJvb2xlYW47XG4gICAgQElucHV0KCkgZGV2aWNlU2l6ZTogc3RyaW5nO1xuICAgIEBJbnB1dCgpIG1vRGF0YUxpc3Q6IE1ldGFvYmplY3REYXRhTW9kZWxbXTtcbiAgICBASW5wdXQoKSBkYXRlUGlja2VyID0gZmFsc2U7XG4gICAgQElucHV0KCkgcmFuZ2VQaWNrZXIgPSBmYWxzZTtcbiAgICBASW5wdXQoKSBjYW5EZWxldGUgPSBmYWxzZTtcbiAgICBASW5wdXQoKSBjYW5BZGQgPSBmYWxzZTtcbiAgICBASW5wdXQoKSBjYW5FZGl0ID0gZmFsc2U7XG4gICAgQElucHV0KCkgc2VsZWN0ZWREYXRlOiBEYXRlIHwgdW5kZWZpbmVkO1xuICAgIEBJbnB1dCgpIHN0YXJ0U2VsZWN0ZWREYXlJbmRleDogbnVtYmVyIHwgdW5kZWZpbmVkO1xuICAgIEBJbnB1dCgpIGVuZFNlbGVjdGVkRGF5SW5kZXg6IG51bWJlciB8IHVuZGVmaW5lZDtcbiAgICBAT3V0cHV0KCkgZWRpdEV2ZW50ID0gbmV3IEV2ZW50RW1pdHRlcjxNZXRhb2JqZWN0RGF0YU1vZGVsPigpO1xuICAgIEBPdXRwdXQoKSBkZWxldGVFdmVudCA9IG5ldyBFdmVudEVtaXR0ZXI8TWV0YW9iamVjdERhdGFNb2RlbD4oKTtcbiAgICBAT3V0cHV0KCkgZGF5U2VsZWN0ID0gbmV3IEV2ZW50RW1pdHRlcjxhbnk+KCk7XG4gICAgQE91dHB1dCgpIGRheUNsaWNrID0gbmV3IEV2ZW50RW1pdHRlcjxEYXk+KCk7XG4gICAgQE91dHB1dCgpIGRheU1vdXNlTW92ZSA9IG5ldyBFdmVudEVtaXR0ZXI8RGF5PigpO1xuICAgIEBPdXRwdXQoKSBkYXlNb3VzZVVwID0gbmV3IEV2ZW50RW1pdHRlcjxEYXk+KCk7XG4gICAgQE91dHB1dCgpIGRheU1vdXNlRG93biA9IG5ldyBFdmVudEVtaXR0ZXI8RGF5PigpO1xuICAgIEBPdXRwdXQoKSBzaG93RXZlbnQgPSBuZXcgRXZlbnRFbWl0dGVyPENhbGVuZGFyTWV0YW9iamVjdERhdGFNb2RlbD4oKTtcblxuICAgIGRlZmF1bHRXZWVrc0NvdW50RDogbnVtYmVyO1xuICAgIGRlZmF1bHRGaXJzdFdlZWtJbmRleDogbnVtYmVyO1xuICAgIHNlbGVjdGVkV2Vla0RheXM6IHN0cmluZ1tdO1xuICAgIHNlbGVjdGVkOiBEYXk7XG4gICAgbnVtYmVyT2ZXZWVrOiBudW1iZXJbXTtcbiAgICBkYXlIZWlnaHQ6IG51bWJlcjtcbiAgICB0YXNrSGVpZ2h0ID0gMzA7XG4gICAgbWF4VGFza0NvdW50OiBudW1iZXI7XG4gICAgbWF4Um93VGFza3M6IG51bWJlcltdO1xuICAgIHdlZWtUYXNrc0FycmF5OiBhbnk7XG4gICAgZXh0cmFSb3c6IG51bWJlcltdO1xuICAgIGlzUGlja2VyTW9kZTogYm9vbGVhbjtcblxuICAgIHByaXZhdGUgX2hhc1BvcG92ZXJPcGVuZWQ6IGJvb2xlYW5bXSA9IFtdO1xuXG4gICAgY29uc3RydWN0b3IoXG4gICAgICAgIHByaXZhdGUgZGF5c0luV2VlazogRGF5c0luV2Vla1BpcGUsXG4gICAgICAgIHByaXZhdGUgX2NkcjogQ2hhbmdlRGV0ZWN0b3JSZWYsXG4gICAgICAgIHByaXZhdGUgX2NhbGVuZGFyU2VydmljZTogQ2FsZW5kYXJTZXJ2aWNlXG4gICAgKSB7XG4gICAgICAgIHN1cGVyKCk7XG4gICAgfVxuICAgIG5nT25DaGFuZ2VzKGNoYW5nZXM6IFNpbXBsZUNoYW5nZXMpOiB2b2lkIHtcbiAgICAgICAgc3VwZXIubmdPbkNoYW5nZXMoY2hhbmdlcyk7XG4gICAgICAgIGxldCBuZWVkVG9EZXRlY3RDaGFuZ2UgPSBmYWxzZTtcbiAgICAgICAgY29uc3Qge1xuICAgICAgICAgICAgY29udGFpbmVySGVpZ2h0LFxuICAgICAgICAgICAgZGV2aWNlU2l6ZSxcbiAgICAgICAgICAgIG1vRGF0YUxpc3QsXG4gICAgICAgICAgICBkYXlzLFxuICAgICAgICAgICAgbW9udGhXZWVrc0NvdW50LFxuICAgICAgICAgICAgc3RhcnRTZWxlY3RlZERheUluZGV4LFxuICAgICAgICAgICAgZW5kU2VsZWN0ZWREYXlJbmRleFxuICAgICAgICB9ID0gY2hhbmdlcztcbiAgICAgICAgaWYgKGNvbnRhaW5lckhlaWdodCAmJiAhY29udGFpbmVySGVpZ2h0LmZpcnN0Q2hhbmdlKSB7XG4gICAgICAgICAgICB0aGlzLmZpdFRvQ29udGFpbmVyKGNoYW5nZXMuY29udGFpbmVySGVpZ2h0LmN1cnJlbnRWYWx1ZSk7XG4gICAgICAgIH1cbiAgICAgICAgaWYgKGRldmljZVNpemUgJiYgIWRldmljZVNpemUuZmlyc3RDaGFuZ2UpIHtcbiAgICAgICAgICAgIHRoaXMucHJlcGFyZVdlZWtEYXlzKGNoYW5nZXMuZGV2aWNlU2l6ZS5jdXJyZW50VmFsdWUpO1xuICAgICAgICB9XG4gICAgICAgIGlmIChtb0RhdGFMaXN0ICYmICFtb0RhdGFMaXN0LmZpcnN0Q2hhbmdlKSB7XG4gICAgICAgICAgICB0aGlzLl9wcmVwYXJlRGF5c1Rhc2tzKGNoYW5nZXMubW9EYXRhTGlzdC5jdXJyZW50VmFsdWUpO1xuICAgICAgICAgICAgbmVlZFRvRGV0ZWN0Q2hhbmdlID0gdHJ1ZTtcbiAgICAgICAgfVxuICAgICAgICBpZiAoZGF5cyAmJiAhZGF5cy5maXJzdENoYW5nZSkge1xuICAgICAgICAgICAgdGhpcy5maXRUb0NvbnRhaW5lcih0aGlzLmNvbnRhaW5lckhlaWdodCk7XG4gICAgICAgICAgICB0aGlzLl9wcmVwYXJlRGF5c1Rhc2tzKHRoaXMubW9EYXRhTGlzdCk7XG4gICAgICAgICAgICBuZWVkVG9EZXRlY3RDaGFuZ2UgPSB0cnVlO1xuICAgICAgICB9XG4gICAgICAgIGlmIChtb250aFdlZWtzQ291bnQgJiYgIW1vbnRoV2Vla3NDb3VudC5maXJzdENoYW5nZSkge1xuICAgICAgICAgICAgdGhpcy5maXRUb0NvbnRhaW5lcih0aGlzLmNvbnRhaW5lckhlaWdodCk7XG4gICAgICAgICAgICB0aGlzLl9wcmVwYXJlRGF5c1Rhc2tzKHRoaXMubW9EYXRhTGlzdCk7XG4gICAgICAgICAgICBuZWVkVG9EZXRlY3RDaGFuZ2UgPSB0cnVlO1xuICAgICAgICB9XG4gICAgICAgIGlmIChcbiAgICAgICAgICAgIChzdGFydFNlbGVjdGVkRGF5SW5kZXggJiYgIXN0YXJ0U2VsZWN0ZWREYXlJbmRleC5maXJzdENoYW5nZSkgfHxcbiAgICAgICAgICAgIChlbmRTZWxlY3RlZERheUluZGV4ICYmICFlbmRTZWxlY3RlZERheUluZGV4LmZpcnN0Q2hhbmdlKVxuICAgICAgICApIHtcbiAgICAgICAgICAgIG5lZWRUb0RldGVjdENoYW5nZSA9IHRydWU7XG4gICAgICAgIH1cbiAgICAgICAgaWYgKG5lZWRUb0RldGVjdENoYW5nZSkge1xuICAgICAgICAgICAgdGhpcy5fY2RyLmRldGVjdENoYW5nZXMoKTtcbiAgICAgICAgfVxuICAgIH1cblxuICAgIG5nT25Jbml0KCk6IHZvaWQge1xuICAgICAgICBzdXBlci5uZ09uSW5pdCgpO1xuICAgICAgICB0aGlzLmlzUGlja2VyTW9kZSA9IHRoaXMuZGF0ZVBpY2tlciB8fCB0aGlzLnJhbmdlUGlja2VyO1xuICAgICAgICB0aGlzLnByZXBhcmVXZWVrRGF5cyh0aGlzLmRldmljZVNpemUpO1xuICAgICAgICB0aGlzLl9wcmVwYXJlRGF5c1Rhc2tzKHRoaXMubW9EYXRhTGlzdCk7XG4gICAgICAgIHRoaXMuZml0VG9Db250YWluZXIodGhpcy5jb250YWluZXJIZWlnaHQpO1xuICAgIH1cblxuICAgIG9uRGF5Qm94U2VsZWN0KGRheTogRGF5KTogdm9pZCB7XG4gICAgICAgIHRoaXMuX2ZpcmVEYXlTZWxlY3QoZGF5KTtcbiAgICB9XG4gICAgb25EYXlTZWxlY3Qod2Vla0luZGV4OiBudW1iZXIsIGRheUluZGV4OiBudW1iZXIpOiB2b2lkIHtcbiAgICAgICAgaWYgKCF0aGlzLmNhbkFkZCkge1xuICAgICAgICAgICAgcmV0dXJuO1xuICAgICAgICB9XG4gICAgICAgIGNvbnN0IGRheSA9IHRoaXMuZGF5c1t3ZWVrSW5kZXggKiA3ICsgZGF5SW5kZXhdO1xuICAgICAgICB0aGlzLl9maXJlRGF5U2VsZWN0KGRheSk7XG4gICAgfVxuXG4gICAgb25PcGVuUG9wb3ZlckNoYW5nZShpc09wZW46IGJvb2xlYW4pOiB2b2lkIHtcbiAgICAgICAgdGhpcy5fb3BlblBvcG92ZXIoaXNPcGVuKTtcbiAgICB9XG4gICAgb25Nb3JlQnV0dG9uKGUsIHBvcG92ZXIpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5fcHJldmVudEV2ZW50KGUpO1xuICAgICAgICBwb3BvdmVyLm9wZW4oKTtcbiAgICB9XG4gICAgb25UYXNrKGUsIHRhc2s6IENhbGVuZGFyTWV0YW9iamVjdERhdGFNb2RlbCk6IHZvaWQge1xuICAgICAgICB0aGlzLnNob3dFdmVudC5lbWl0KHRhc2spO1xuICAgIH1cbiAgICBvbkRheUNsaWNrKGRheTogRGF5KTogdm9pZCB7XG4gICAgICAgIHRoaXMuc2VsZWN0ZWQgPSBkYXk7XG4gICAgICAgIHRoaXMuZGF5Q2xpY2suZW1pdChkYXkpO1xuICAgIH1cbiAgICBvbkRheU1vdXNlTW92ZShkYXk6IERheSk6IHZvaWQge1xuICAgICAgICB0aGlzLmRheU1vdXNlTW92ZS5lbWl0KGRheSk7XG4gICAgfVxuICAgIG9uRGF5TW91c2VEb3duKGRheTogRGF5KTogdm9pZCB7XG4gICAgICAgIHRoaXMuZGF5TW91c2VEb3duLmVtaXQoZGF5KTtcbiAgICB9XG4gICAgb25EYXlNb3VzZVVwKGRheTogRGF5KTogdm9pZCB7XG4gICAgICAgIHRoaXMuZGF5TW91c2VVcC5lbWl0KGRheSk7XG4gICAgfVxuICAgIHByaXZhdGUgX3ByZXZlbnRFdmVudChlKTogdm9pZCB7XG4gICAgICAgIGUuc3RvcFByb3BhZ2F0aW9uKCk7XG4gICAgICAgIGUucHJldmVudERlZmF1bHQoKTtcbiAgICB9XG4gICAgcHJpdmF0ZSBfZmlyZURheVNlbGVjdChkYXk6IERheSk6IHZvaWQge1xuICAgICAgICBpZiAodGhpcy5faGFzUG9wb3Zlck9wZW5lZC5sZW5ndGggPT09IDApIHtcbiAgICAgICAgICAgIHRoaXMuZGF5U2VsZWN0LmVtaXQoe1xuICAgICAgICAgICAgICAgIGRhdGU6IGRheS5kYXRlXG4gICAgICAgICAgICB9KTtcbiAgICAgICAgfVxuICAgIH1cbiAgICBwcml2YXRlIF9vcGVuUG9wb3Zlcihpc09wZW46IGJvb2xlYW4pOiB2b2lkIHtcbiAgICAgICAgaWYgKGlzT3Blbikge1xuICAgICAgICAgICAgdGhpcy5faGFzUG9wb3Zlck9wZW5lZC5wdXNoKHRydWUpO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgc2V0VGltZW91dCgoKSA9PiB7XG4gICAgICAgICAgICAgICAgdGhpcy5faGFzUG9wb3Zlck9wZW5lZCA9IFtdO1xuICAgICAgICAgICAgfSwgMCk7XG4gICAgICAgIH1cbiAgICB9XG4gICAgcHJpdmF0ZSBwcmVwYXJlV2Vla0RheXMoZGV2aWNlU2l6ZTogc3RyaW5nKTogdm9pZCB7XG4gICAgICAgIGlmIChkZXZpY2VTaXplICE9PSAncycgJiYgZGV2aWNlU2l6ZSAhPT0gJ20nKSB7XG4gICAgICAgICAgICB0aGlzLnNlbGVjdGVkV2Vla0RheXMgPSB0aGlzLndlZWtEYXlzO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgdGhpcy5zZWxlY3RlZFdlZWtEYXlzID0gdGhpcy53ZWVrRGF5c01pbjtcbiAgICAgICAgfVxuICAgIH1cbiAgICBwcml2YXRlIGZpdFRvQ29udGFpbmVyKGNvbnRhaW5lckhlaWdodCk6IHZvaWQge1xuICAgICAgICBsZXQgX3dlZWtzQ291bnQ7XG5cbiAgICAgICAgaWYgKHRoaXMubW9udGhXZWVrc0NvdW50ID4gMCkge1xuICAgICAgICAgICAgY29uc3Qgd2Vla3NDb3VudCA9IHRoaXMubW9udGhXZWVrc0NvdW50O1xuICAgICAgICAgICAgX3dlZWtzQ291bnQgPSB3ZWVrc0NvdW50O1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgX3dlZWtzQ291bnQgPSB0aGlzLmRheXMubGVuZ3RoIC8gNztcbiAgICAgICAgfVxuICAgICAgICB0aGlzLm51bWJlck9mV2VlayA9IEFycmF5LmZyb20oQXJyYXkoX3dlZWtzQ291bnQpLmtleXMoKSk7XG4gICAgICAgIHRoaXMubnVtYmVyT2ZXZWVrID0gdGhpcy5udW1iZXJPZldlZWsubWFwKCh2YWx1ZSkgPT4gdmFsdWUpO1xuICAgICAgICBpZiAodGhpcy5pc1BpY2tlck1vZGUpIHtcbiAgICAgICAgICAgIHRoaXMuZGF5SGVpZ2h0ID0gNDA7XG4gICAgICAgICAgICByZXR1cm47XG4gICAgICAgIH1cbiAgICAgICAgdGhpcy5kYXlIZWlnaHQgPSBNYXRoLmZsb29yKGNvbnRhaW5lckhlaWdodCAvIChfd2Vla3NDb3VudCArIDEpKTtcblxuICAgICAgICB0aGlzLm1heFRhc2tDb3VudCA9IE1hdGguZmxvb3IoKHRoaXMuZGF5SGVpZ2h0IC0gdGhpcy50YXNrSGVpZ2h0KSAvIHRoaXMudGFza0hlaWdodCk7XG4gICAgICAgIGlmICh0aGlzLm1heFRhc2tDb3VudCA+IDApIHtcbiAgICAgICAgICAgIHRoaXMubWF4Um93VGFza3MgPSBuZXcgQXJyYXkodGhpcy5tYXhUYXNrQ291bnQpLmZpbGwoMCkubWFwKCh4LCBpKSA9PiBpKTtcbiAgICAgICAgfVxuICAgIH1cbiAgICBwcml2YXRlIF9wcmVwYXJlRGF5c1Rhc2tzKGNhbGVuZGFyVGFza3MpOiB2b2lkIHtcbiAgICAgICAgaWYgKHRoaXMuaXNQaWNrZXJNb2RlKSB7XG4gICAgICAgICAgICB0aGlzLndlZWtUYXNrc0FycmF5ID0ge307XG4gICAgICAgICAgICByZXR1cm47XG4gICAgICAgIH1cblxuICAgICAgICBjb25zdCBjYWxlbmRhckZpZWxkcyA9IHRoaXMuY2FsZW5kYXJGaWVsZHM7XG5cbiAgICAgICAgLy8gU29ydCBhbGwgVGFza3NcbiAgICAgICAgY29uc3QgbW9EYXRhTGlzdCA9IHRoaXMuX2NhbGVuZGFyU2VydmljZS5zb3J0VGFza3MoY2FsZW5kYXJUYXNrcywgY2FsZW5kYXJGaWVsZHMpO1xuICAgICAgICB0aGlzLmRheXMuZm9yRWFjaCgoZGF5KSA9PiAoZGF5LnRhc2tzID0gW10pKTtcbiAgICAgICAgY29uc3Qgd2Vla1Rhc2tzQXJyYXk6IGFueSA9IFtdO1xuICAgICAgICBmb3IgKGxldCBqID0gMDsgaiA8IHRoaXMuZGF5cy5sZW5ndGggLyA3OyBqKyspIHtcbiAgICAgICAgICAgIGNvbnN0IGRheXMgPSB0aGlzLmRheXNJbldlZWsudHJhbnNmb3JtKHRoaXMuZGF5cywgaik7XG4gICAgICAgICAgICBjb25zdCB3ZWVrID0gdGhpcy5fY2FsZW5kYXJTZXJ2aWNlLmNyZWF0ZVdlZWtUYXNrKGRheXMsIG1vRGF0YUxpc3QsIGNhbGVuZGFyRmllbGRzLCAwKTtcbiAgICAgICAgICAgIHdlZWtUYXNrc0FycmF5LnB1c2god2Vlayk7XG4gICAgICAgIH1cblxuICAgICAgICB3ZWVrVGFza3NBcnJheS5mb3JFYWNoKCh3ZWVrKSA9PiB7XG4gICAgICAgICAgICBjb25zdCBhcnI6IGFueVtdID0gT2JqZWN0LnZhbHVlcyh3ZWVrKTtcbiAgICAgICAgICAgIGZvciAobGV0IGkgPSBhcnIubGVuZ3RoOyBpIDwgdGhpcy5tYXhUYXNrQ291bnQ7IGkrKykge1xuICAgICAgICAgICAgICAgIHdlZWtbaS50b1N0cmluZygpXSA9IFtdO1xuICAgICAgICAgICAgfVxuICAgICAgICB9KTtcbiAgICAgICAgLy8g2KjZhyDYp9iy2KfbjCDZh9ixINix2K/bjNmBINiq2LPaqSDYqNin24zYryDYqti52K/Yp9ivIDcg2LPYqtmI2YYg2KfYttin2YHZhyDar9ix2K/YryDZiCDYqNix2KfbjCDYs9iq2YjZhtuMINqp2Ycg2KrYs9qp24wg2YbYr9in2LHYryDbjNqpINis2KfbjCDYrtin2YTbjCBjb2xzcGFuIDEg2YXbjNqv2LDYp9ix24zZhVxuICAgICAgICB3ZWVrVGFza3NBcnJheS5mb3JFYWNoKCh3ZWVrKSA9PiB7XG4gICAgICAgICAgICB0aGlzLl9jYWxlbmRhclNlcnZpY2UuZmlsbFdlZWsod2Vlayk7XG4gICAgICAgIH0pO1xuICAgICAgICB0aGlzLndlZWtUYXNrc0FycmF5ID0gd2Vla1Rhc2tzQXJyYXk7XG4gICAgfVxufVxuIiwiPHRhYmxlIGZkLXRhYmxlIGNsYXNzPVwidGFibGUtaGVhZGVyXCIgW2ZkQ29tcGFjdF0gW2F0dHIucGlja2VyXT1cImRhdGVQaWNrZXJcIj5cbiAgICA8dGhlYWQgZmQtdGFibGUtaGVhZGVyPlxuICAgICAgICA8dHIgZmQtdGFibGUtcm93PlxuICAgICAgICAgICAgQGZvciAod2Vla0RheSBvZiBzZWxlY3RlZFdlZWtEYXlzOyB0cmFjayB3ZWVrRGF5KSB7XG4gICAgICAgICAgICA8dGggY2xhc3M9XCJ3ZWVrZGF5LWhlYWRlclwiIGZkLXRhYmxlLWNlbGwgW2NsYXNzLm5vYm9yZGVyXT1cImlzUGlja2VyTW9kZVwiPlxuICAgICAgICAgICAgICAgIHt7IHdlZWtEYXkgfCBzbGljZTogMDoxIH19XG4gICAgICAgICAgICA8L3RoPlxuICAgICAgICAgICAgfVxuICAgICAgICA8L3RyPlxuICAgIDwvdGhlYWQ+XG4gICAgPHRib2R5IGZkLXRhYmxlLWJvZHk+XG4gICAgICAgIEBmb3IgKHdlZWtEYXkgb2YgbnVtYmVyT2ZXZWVrOyB0cmFjayB3ZWVrRGF5KSB7XG4gICAgICAgIDx0ciBmZC10YWJsZS1yb3c+XG4gICAgICAgICAgICA8dGQgW3N0eWxlLmhlaWdodC5weF09XCJkYXlIZWlnaHRcIiBmZC10YWJsZS1jZWxsIGNvbHNwYW49XCI3XCIgW3N0eWxlLmJvcmRlcl09XCJpc1BpY2tlck1vZGUgPyAnbm9uZScgOiBudWxsXCI+XG4gICAgICAgICAgICAgICAgPG5nLWNvbnRhaW5lclxuICAgICAgICAgICAgICAgICAgICAqbmdUZW1wbGF0ZU91dGxldD1cIlxuICAgICAgICAgICAgICAgICAgICAgICAgcmVuZGVyVGFza3M7XG4gICAgICAgICAgICAgICAgICAgICAgICBjb250ZXh0OiB7XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgJGltcGxpY2l0OiBpc1BpY2tlck1vZGUgPyBudWxsIDogbW9EYXRhTGlzdFt3ZWVrRGF5XSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICB3ZWVrSW5kZXg6IHdlZWtEYXksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgZGF5czogZGF5cyB8IGRheXNJbldlZWs6IHdlZWtEYXksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgbWF4Um93VGFza3M6IG1heFJvd1Rhc2tzLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIHdlZWtEYXlzOiB3ZWVrRGF5cyxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBjYWxlbmRhckZpZWxkczogY2FsZW5kYXJGaWVsZHMsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgZGV2aWNlU2l6ZTogZGV2aWNlU2l6ZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBydGw6IHJ0bCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBpc1BpY2tlck1vZGU6IGlzUGlja2VyTW9kZVxuICAgICAgICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgICAgICBcIlxuICAgICAgICAgICAgICAgID48L25nLWNvbnRhaW5lcj5cbiAgICAgICAgICAgIDwvdGQ+XG4gICAgICAgIDwvdHI+XG4gICAgICAgIH1cbiAgICA8L3Rib2R5PlxuPC90YWJsZT5cbjxuZy10ZW1wbGF0ZVxuICAgICNyZW5kZXJUYXNrc1xuICAgIGxldC10YXNrXG4gICAgbGV0LXdlZWtJbmRleD1cIndlZWtJbmRleFwiXG4gICAgbGV0LXdlZWtEYXlzPVwid2Vla0RheXNcIlxuICAgIGxldC1kYXlzPVwiZGF5c1wiXG4gICAgbGV0LW1heFJvd1Rhc2tzPVwibWF4Um93VGFza3NcIlxuICAgIGxldC1jYWxlbmRhckZpZWxkcz1cImNhbGVuZGFyRmllbGRzXCJcbiAgICBsZXQtZGV2aWNlU2l6ZT1cImRldmljZVNpemVcIlxuICAgIGxldC1ydGw9XCJydGxcIlxuICAgIGxldC1pc1BpY2tlck1vZGU9XCJpc1BpY2tlck1vZGVcIlxuPlxuICAgIDx0YWJsZSBmZC10YWJsZS1ib2R5IGNsYXNzPVwidGFibGUtY29udGVudFwiIFtjb21wYWN0XT1cInRydWVcIj5cbiAgICAgICAgPHRib2R5PlxuICAgICAgICAgICAgPHRyIGZkLXRhYmxlLXJvdyBjbGFzcz1cInJvdy1kYXktbnVtYmVyXCIgW2F0dHIucnRsXT1cInJ0bFwiPlxuICAgICAgICAgICAgICAgIEBmb3IgKGRheSBvZiBkYXlzOyB0cmFjayBkYXkpIHtcbiAgICAgICAgICAgICAgICA8dGQgZmQtdGFibGUtY2VsbCBbY2xhc3Mubm9ib3JkZXJdPVwiaXNQaWNrZXJNb2RlXCI+XG4gICAgICAgICAgICAgICAgICAgIDxiYy1kYXktbnVtYmVyLWJveFxuICAgICAgICAgICAgICAgICAgICAgICAgW25nQ2xhc3NdPVwie1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgICdmZC1jYWxlbmRhcl9faXRlbSc6IGlzUGlja2VyTW9kZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAnIXR3LWJvcmRlciAhdHctcm91bmRlZC1tZCB0dy10cmFuc2l0aW9uLWFsbCB0dy1jdXJzb3ItcG9pbnRlcic6XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlzUGlja2VyTW9kZSAmJiBkYXkuaXNJbk1vbnRoLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICchdHctYmctdHJhbnNwYXJlbnQgdHctYm9yZGVyLWdyYXktMTAwIGhvdmVyOiF0dy1ib3JkZXItZ3JheS0zMDAnOlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpc1BpY2tlck1vZGUgJiYgZGF5LmlzSW5Nb250aCAmJiAhZGF5LmlzVG9kYXksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgJ2ZkLWNhbGVuZGFyX19pdGVtLS1vdGhlci1tb250aCc6IGlzUGlja2VyTW9kZSAmJiAhZGF5LmlzSW5Nb250aCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAnZmQtY2FsZW5kYXJfX2l0ZW0tLXdlZWtlbmQnOiBpc1BpY2tlck1vZGUgJiYgZGF5LmlzV2Vla2VuZCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAnIXR3LWJnLWJsdWUtNTAwIGhvdmVyOiF0dy1iZy1ibHVlLTYwMCc6IGRheS5pc1RvZGF5XG4gICAgICAgICAgICAgICAgICAgICAgICB9XCJcbiAgICAgICAgICAgICAgICAgICAgICAgIFtpc1BpY2tlck1vZGVdPVwiaXNQaWNrZXJNb2RlXCJcbiAgICAgICAgICAgICAgICAgICAgICAgIFtkYXldPVwiZGF5XCJcbiAgICAgICAgICAgICAgICAgICAgICAgIFtpc0FjdGl2ZV09XCJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBkYXkuaW5kZXggPT09IHN0YXJ0U2VsZWN0ZWREYXlJbmRleCB8fCBkYXkuaW5kZXggPT09IGVuZFNlbGVjdGVkRGF5SW5kZXggfHwgZGF5LmRhdGVcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgfCBlcXVhbERhdGU6IHNlbGVjdGVkRGF0ZVxuICAgICAgICAgICAgICAgICAgICAgICAgXCJcbiAgICAgICAgICAgICAgICAgICAgICAgIFtpdGVtSW5SYW5nZV09XCJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBzdGFydFNlbGVjdGVkRGF5SW5kZXggIT09IHVuZGVmaW5lZCAmJlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIGVuZFNlbGVjdGVkRGF5SW5kZXggIT09IHVuZGVmaW5lZCAmJlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIGRheS5pbmRleCA+PSBzdGFydFNlbGVjdGVkRGF5SW5kZXggJiZcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBkYXkuaW5kZXggPD0gZW5kU2VsZWN0ZWREYXlJbmRleFxuICAgICAgICAgICAgICAgICAgICAgICAgXCJcbiAgICAgICAgICAgICAgICAgICAgICAgIChkYXlDbGljayk9XCJvbkRheUNsaWNrKGRheSlcIlxuICAgICAgICAgICAgICAgICAgICAgICAgKGRheU1vdXNlTW92ZSk9XCJvbkRheU1vdXNlTW92ZShkYXkpXCJcbiAgICAgICAgICAgICAgICAgICAgICAgIChkYXlNb3VzZURvd24pPVwib25EYXlNb3VzZURvd24oZGF5KVwiXG4gICAgICAgICAgICAgICAgICAgICAgICAoZGF5TW91c2VVcCk9XCJvbkRheU1vdXNlVXAoZGF5KVwiXG4gICAgICAgICAgICAgICAgICAgID48L2JjLWRheS1udW1iZXItYm94PlxuICAgICAgICAgICAgICAgIDwvdGQ+XG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgPC90cj5cbiAgICAgICAgICAgIEBpZiAoIWlzUGlja2VyTW9kZSkge1xuICAgICAgICAgICAgPG5nLWNvbnRhaW5lclxuICAgICAgICAgICAgICAgICpuZ1RlbXBsYXRlT3V0bGV0PVwiXG4gICAgICAgICAgICAgICAgICAgIHJlbmRlckRheVRhc2tzO1xuICAgICAgICAgICAgICAgICAgICBjb250ZXh0OiB7XG4gICAgICAgICAgICAgICAgICAgICAgICAkaW1wbGljaXQ6IHdlZWtUYXNrc0FycmF5W3dlZWtJbmRleF0sXG4gICAgICAgICAgICAgICAgICAgICAgICBtYXhSb3dUYXNrczogbWF4Um93VGFza3MsXG4gICAgICAgICAgICAgICAgICAgICAgICB3ZWVrSW5kZXg6IHdlZWtJbmRleCxcbiAgICAgICAgICAgICAgICAgICAgICAgIGRldmljZVNpemU6IGRldmljZVNpemUsXG4gICAgICAgICAgICAgICAgICAgICAgICBjYWxlbmRhckZpZWxkczogY2FsZW5kYXJGaWVsZHMsXG4gICAgICAgICAgICAgICAgICAgICAgICB3ZWVrRGF5czogd2Vla0RheXNcbiAgICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgIFwiXG4gICAgICAgICAgICA+PC9uZy1jb250YWluZXI+XG4gICAgICAgICAgICA8dHIgZmQtdGFibGUtcm93PlxuICAgICAgICAgICAgICAgIEBmb3IgKGRheSBvZiBkYXlzOyB0cmFjayBkYXkpIHtcbiAgICAgICAgICAgICAgICA8dGQgZmQtdGFibGUtY2VsbCBjbGFzcz1cIm1vcmUtZmRcIiAoY2xpY2spPVwib25EYXlCb3hTZWxlY3QoZGF5KVwiPlxuICAgICAgICAgICAgICAgICAgICBAaWYgKG1heFJvd1Rhc2tzPy5sZW5ndGggPCBkYXkudGFza3MubGVuZ3RoKSB7XG4gICAgICAgICAgICAgICAgICAgIDxidXR0b24gZmQtYnV0dG9uIChjbGljayk9XCJvbk1vcmVCdXR0b24oJGV2ZW50LCBwb3BvdmVyKVwiIFtmZFR5cGVdPVwiJ3RyYW5zcGFyZW50J1wiIFtjb21wYWN0XT1cInRydWVcIj5cbiAgICAgICAgICAgICAgICAgICAgICAgIHt7IGRheS50YXNrcz8ubGVuZ3RoIC0gbWF4Um93VGFza3M/Lmxlbmd0aCB9fVxuICAgICAgICAgICAgICAgICAgICAgICAge3sgJ01vcmUnIHwgYmJiVHJhbnNsYXRlIH19XG4gICAgICAgICAgICAgICAgICAgIDwvYnV0dG9uPlxuICAgICAgICAgICAgICAgICAgICA8ZmQtcG9wb3ZlclxuICAgICAgICAgICAgICAgICAgICAgICAgI3BvcG92ZXJcbiAgICAgICAgICAgICAgICAgICAgICAgIFttb2JpbGVdPVwiZGV2aWNlU2l6ZSA9PT0gJ3MnXCJcbiAgICAgICAgICAgICAgICAgICAgICAgIHBsYWNlbWVudD1cImJvdHRvbVwiXG4gICAgICAgICAgICAgICAgICAgICAgICBbZm9jdXNUcmFwcGVkXT1cInRydWVcIlxuICAgICAgICAgICAgICAgICAgICAgICAgW2ZvY3VzQXV0b0NhcHR1cmVdPVwidHJ1ZVwiXG4gICAgICAgICAgICAgICAgICAgICAgICAoaXNPcGVuQ2hhbmdlKT1cIm9uT3BlblBvcG92ZXJDaGFuZ2UoJGV2ZW50KVwiXG4gICAgICAgICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICAgICAgICAgIDxiYy1kYXktZXZlbnQtbGlzdFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIFtkYXldPVwiZGF5XCJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBbY2FsZW5kYXJGaWVsZHNdPVwiY2FsZW5kYXJGaWVsZHNcIlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIFtkZXZpY2VTaXplXT1cImRldmljZVNpemVcIlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIFt3ZWVrRGF5c109XCJ3ZWVrRGF5c1wiXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgW3J0bF09XCJydGxcIlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIFtjYW5EZWxldGVdPVwiY2FuRGVsZXRlXCJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBbY2FuRWRpdF09XCJjYW5FZGl0XCJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBbcG9wb3Zlcl09XCJwb3BvdmVyXCJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAoZGVsZXRlRXZlbnQpPVwiZGVsZXRlRXZlbnQuZW1pdCgkZXZlbnQpXCJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAoZWRpdEV2ZW50KT1cImVkaXRFdmVudC5lbWl0KCRldmVudClcIlxuICAgICAgICAgICAgICAgICAgICAgICAgPjwvYmMtZGF5LWV2ZW50LWxpc3Q+XG4gICAgICAgICAgICAgICAgICAgIDwvZmQtcG9wb3Zlcj5cbiAgICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgIDwvdGQ+XG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgPC90cj5cbiAgICAgICAgICAgIH1cbiAgICAgICAgPC90Ym9keT5cbiAgICA8L3RhYmxlPlxuPC9uZy10ZW1wbGF0ZT5cblxuPG5nLXRlbXBsYXRlXG4gICAgI3JlbmRlckRheVRhc2tzXG4gICAgbGV0LXdlZWtUYXNrc1xuICAgIGxldC1tYXhSb3dUYXNrcz1cIm1heFJvd1Rhc2tzXCJcbiAgICBsZXQtd2Vla0luZGV4PVwid2Vla0luZGV4XCJcbiAgICBsZXQtZGV2aWNlU2l6ZT1cImRldmljZVNpemVcIlxuICAgIGxldC1jYWxlbmRhckZpZWxkcz1cImNhbGVuZGFyRmllbGRzXCJcbiAgICBsZXQtd2Vla0RheXM9XCJ3ZWVrRGF5c1wiXG4+XG4gICAgQGZvciAocm93VGFzayBvZiBtYXhSb3dUYXNrczsgdHJhY2sgcm93VGFzazsgbGV0IGkgPSAkaW5kZXgpIHtcbiAgICA8dHIgZmQtdGFibGUtcm93PlxuICAgICAgICBAaWYgKCF3ZWVrVGFza3NbaV0gfHwgd2Vla1Rhc2tzW2ldLmxlbmd0aCA9PT0gMCkgeyBAZm9yIChkYXkgb2Ygd2Vla0RheXM7IHRyYWNrIGRheSkge1xuICAgICAgICA8dGQgZmQtdGFibGUtY2VsbD48L3RkPlxuICAgICAgICB9IH0gQGZvciAodGFzayBvZiB3ZWVrVGFza3NbaV07IHRyYWNrIHRhc2s7IGxldCBkYXlJbmRleCA9ICRpbmRleCkgeyBAaWYgKHRhc2suY29sU3Bhbikge1xuICAgICAgICA8dGQgZmQtdGFibGUtY2VsbCBbYXR0ci5jb2xzcGFuXT1cInRhc2suY29sU3BhblwiPlxuICAgICAgICAgICAgQGlmICh0YXNrLmV2ZW50KSB7XG4gICAgICAgICAgICA8YmMtZXZlbnQtYnV0dG9uXG4gICAgICAgICAgICAgICAgW3Rhc2tdPVwidGFza1wiXG4gICAgICAgICAgICAgICAgW2NhbGVuZGFyRmllbGRzXT1cImNhbGVuZGFyRmllbGRzXCJcbiAgICAgICAgICAgICAgICBbZGV2aWNlU2l6ZV09XCJkZXZpY2VTaXplXCJcbiAgICAgICAgICAgICAgICBbcnRsXT1cInJ0bFwiXG4gICAgICAgICAgICAgICAgW2NhbkRlbGV0ZV09XCJjYW5EZWxldGVcIlxuICAgICAgICAgICAgICAgIFtjYW5FZGl0XT1cImNhbkVkaXRcIlxuICAgICAgICAgICAgICAgIChkZWxldGVFdmVudCk9XCJkZWxldGVFdmVudC5lbWl0KCRldmVudClcIlxuICAgICAgICAgICAgICAgIChlZGl0RXZlbnQpPVwiZWRpdEV2ZW50LmVtaXQoJGV2ZW50KVwiXG4gICAgICAgICAgICAgICAgKG9wZW5Qb3BvdmVyQ2hhbmdlKT1cIm9uT3BlblBvcG92ZXJDaGFuZ2UoJGV2ZW50KVwiXG4gICAgICAgICAgICA+PC9iYy1ldmVudC1idXR0b24+XG4gICAgICAgICAgICB9IEBlbHNlIHtcbiAgICAgICAgICAgIDxkaXYgc3R5bGU9XCJ3aWR0aDogMTAwJTsgaGVpZ2h0OiAxMDAlXCIgKGNsaWNrKT1cIm9uRGF5U2VsZWN0KHdlZWtJbmRleCwgZGF5SW5kZXgpXCI+PC9kaXY+XG4gICAgICAgICAgICB9XG4gICAgICAgIDwvdGQ+XG4gICAgICAgIH0gfVxuICAgIDwvdHI+XG4gICAgfVxuPC9uZy10ZW1wbGF0ZT5cbiJdfQ==
|