barsa-calendar 2.2.72 → 2.2.74

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 (36) hide show
  1. package/fesm2022/barsa-calendar.mjs +87 -87
  2. package/fesm2022/barsa-calendar.mjs.map +1 -1
  3. package/lib/calendar-container/calendar-container.component.d.ts +1 -1
  4. package/lib/calendar-list/calendar-list.component.d.ts +1 -1
  5. package/lib/calendar-month/calendar-month.component.d.ts +1 -1
  6. package/lib/calendar-week/calendar-week.component.d.ts +3 -3
  7. package/lib/month-days/month-days.component.d.ts +1 -1
  8. package/lib/services/calendar.service.d.ts +1 -1
  9. package/package.json +3 -5
  10. package/esm2022/barsa-calendar.mjs +0 -5
  11. package/esm2022/lib/barsa-calendar.module.mjs +0 -117
  12. package/esm2022/lib/calendar-container/calendar-container.component.mjs +0 -221
  13. package/esm2022/lib/calendar-header/calendar-header.component.mjs +0 -66
  14. package/esm2022/lib/calendar-list/calendar-list.component.mjs +0 -18
  15. package/esm2022/lib/calendar-list-container/calendar-list-container.component.mjs +0 -29
  16. package/esm2022/lib/calendar-list-item/calendar-list-item.component.mjs +0 -14
  17. package/esm2022/lib/calendar-month/calendar-month.component.mjs +0 -249
  18. package/esm2022/lib/calendar-selection-days/calendar-selection-days.component.mjs +0 -196
  19. package/esm2022/lib/calendar-week/calendar-week.component.mjs +0 -255
  20. package/esm2022/lib/constants.mjs +0 -4
  21. package/esm2022/lib/date-time-picker/date-time-picker.component.mjs +0 -457
  22. package/esm2022/lib/day-event-list/day-event-list.component.mjs +0 -58
  23. package/esm2022/lib/day-number-box/day-number-box.component.mjs +0 -105
  24. package/esm2022/lib/days-in-week.pipe.mjs +0 -18
  25. package/esm2022/lib/equal-date.pipe.mjs +0 -24
  26. package/esm2022/lib/event-button/event-button.component.mjs +0 -100
  27. package/esm2022/lib/event-button-end-arrow/event-button-end-arrow.component.mjs +0 -29
  28. package/esm2022/lib/event-button-start-arrow/event-button-start-arrow.component.mjs +0 -29
  29. package/esm2022/lib/event-date.pipe.mjs +0 -25
  30. package/esm2022/lib/event-preview/event-preview.component.mjs +0 -81
  31. package/esm2022/lib/event-time.pipe.mjs +0 -23
  32. package/esm2022/lib/from-to-time.pipe.mjs +0 -24
  33. package/esm2022/lib/models.mjs +0 -14
  34. package/esm2022/lib/month-days/month-days.component.mjs +0 -222
  35. package/esm2022/lib/services/calendar.service.mjs +0 -645
  36. package/esm2022/public-api.mjs +0 -23
@@ -1,66 +0,0 @@
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 "barsa-novin-ray-core";
5
- import * as i2 from "@fundamental-ngx/core/button";
6
- import * as i3 from "@fundamental-ngx/core/menu";
7
- import * as i4 from "@fundamental-ngx/core/title";
8
- import * as i5 from "@fundamental-ngx/core/split-button";
9
- import * as i6 from "@fundamental-ngx/core/toolbar";
10
- import * as i7 from "../calendar-selection-days/calendar-selection-days.component";
11
- export class CalendarHeaderComponent extends BaseComponent {
12
- constructor() {
13
- super(...arguments);
14
- this.hideMode = false;
15
- this.prevTap = new EventEmitter();
16
- this.nextTap = new EventEmitter();
17
- this.modeChange = new EventEmitter();
18
- this.rangeChange = new EventEmitter();
19
- this.today = new EventEmitter();
20
- this.monthName = '';
21
- }
22
- /**
23
- *
24
- */
25
- onModeChange(menu, mode) {
26
- menu.close();
27
- this.modeChange.emit(mode);
28
- }
29
- onRangeChange(range) {
30
- this.rangeChange.emit(range);
31
- }
32
- onPrint() { }
33
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CalendarHeaderComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
34
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: CalendarHeaderComponent, selector: "bc-calendar-header", inputs: { monthInfo: "monthInfo", weekModeDays: "weekModeDays", hideMode: "hideMode", modeTitle: "modeTitle", title: "title", deviceSize: "deviceSize", rtl: "rtl", mode: "mode" }, outputs: { prevTap: "prevTap", nextTap: "nextTap", modeChange: "modeChange", rangeChange: "rangeChange", today: "today" }, usesInheritance: true, ngImport: i0, template: "<fd-toolbar [shouldOverflow]=\"true\" [fdType]=\"'transparent'\" [class.rtl]=\"rtl\">\r\n <button fd-button fd-toolbar-item [label]=\"'DateR_Today' | bbbTranslate\" (click)=\"today.emit()\"></button>\r\n <button\r\n fd-button\r\n fdType=\"transparent\"\r\n fd-toolbar-item\r\n [glyph]=\"rtl ? 'navigation-right-arrow' : 'navigation-left-arrow'\"\r\n (click)=\"prevTap.emit()\"\r\n ></button>\r\n <button\r\n fd-button\r\n fdType=\"transparent\"\r\n fd-toolbar-item\r\n [glyph]=\"rtl ? 'navigation-left-arrow' : 'navigation-right-arrow'\"\r\n (click)=\"nextTap.emit()\"\r\n ></button>\r\n <h3 fd-title fd-toolbar-item>{{ title }}</h3>\r\n <fd-toolbar-spacer></fd-toolbar-spacer>\r\n <!-- <button fd-button fd-toolbar-item glyph=\"print\" (click)=\"onPrint()\" fdType=\"transparent\"></button> -->\r\n @if (deviceSize === 's' || deviceSize === 'm') {\r\n <bc-calendar-selection-days\r\n fd-toolbar-item\r\n [monthInfo]=\"monthInfo\"\r\n (rangeChange)=\"onRangeChange($event)\"\r\n ></bc-calendar-selection-days>\r\n } @if (!hideMode) {\r\n <fd-split-button\r\n fd-toolbar-item\r\n [fixedWidth]=\"false\"\r\n [mainAction]=\"{\r\n mainActionTitle: modeTitle,\r\n keepMainAction: true\r\n }\"\r\n >\r\n <fd-menu #menu>\r\n <li fd-menu-item (click)=\"onModeChange(menu, 'day')\" bodyClick>\r\n <div fd-menu-interactive>\r\n <span fd-menu-title>{{ 'Day' | bbbTranslate }}</span>\r\n </div>\r\n </li>\r\n <li fd-menu-item (click)=\"onModeChange(menu, 'week')\" bodyClick>\r\n <div fd-menu-interactive>\r\n <span fd-menu-title>{{ 'Week' | bbbTranslate }} </span>\r\n </div>\r\n </li>\r\n <li fd-menu-item (click)=\"onModeChange(menu, 'month')\" bodyClick>\r\n <div fd-menu-interactive>\r\n <span fd-menu-title>{{ 'Month' | bbbTranslate }}</span>\r\n </div>\r\n </li>\r\n <!-- <li fd-menu-item (click)=\"onModeChange('year')\">\r\n <div fd-menu-interactive>\r\n <span fd-menu-title>{{ \"Year\" | bbbTranslate }}</span>\r\n </div>\r\n </li> -->\r\n </fd-menu>\r\n </fd-split-button>\r\n }\r\n</fd-toolbar>\r\n", styles: [":host{display:block;background-color:var(--sapList_Background, #fff)}:host ::ng-deep span.fd-toolbar__spacer{display:none}:host ::ng-deep fd-toolbar .fd-toolbar{border:none;border-left:1px solid var(--sapList_BorderColor, #e5e5e5)}:host ::ng-deep fd-toolbar.rtl .fd-toolbar{border-left:none;border-right:1px solid var(--sapList_BorderColor, #e5e5e5)}\n"], dependencies: [{ kind: "directive", type: i1.BodyClickDirective, selector: "[bodyClick]", inputs: ["disableBodyClick"] }, { kind: "component", type: i2.ButtonComponent, selector: "button[fd-button], a[fd-button], span[fd-button]", inputs: ["class"], exportAs: ["fd-button"] }, { kind: "component", type: i3.MenuComponent, selector: "fd-menu", inputs: ["mobile", "disabled", "focusTrapped", "focusAutoCapture", "openOnHoverTime", "mobileConfig", "ariaLabel", "ariaLabelledby", "id"], outputs: ["activePath"] }, { kind: "component", type: i3.MenuItemComponent, selector: "li[fd-menu-item]", inputs: ["disabled", "itemId", "submenu", "parentSubmenu", "hasSeparator"], outputs: ["onSelect"], exportAs: ["fd-menu-item"] }, { kind: "component", type: i3.MenuInteractiveComponent, selector: "[fd-menu-interactive]" }, { kind: "directive", type: i3.MenuTitleDirective, selector: "[fd-menu-title]" }, { kind: "component", type: i4.TitleComponent, selector: "[fd-title], [fdTitle]", inputs: ["headerSize", "wrap"], exportAs: ["fd-title"] }, { kind: "component", type: i5.SplitButtonComponent, selector: "fd-split-button", inputs: ["glyph", "glyphFont", "disabled", "fdType", "expandButtonTitle", "selected", "fixedWidth", "mainAction", "arialLabel"], outputs: ["primaryButtonClicked"] }, { kind: "component", type: i6.ToolbarComponent, selector: "fd-toolbar", inputs: ["titleId", "class", "shouldOverflow", "fdType", "title", "active", "clearBorder", "forceOverflow", "tabindex", "headingLevel", "ariaLabel", "ariaLabelledBy"] }, { kind: "directive", type: i6.ToolbarItemDirective, selector: "[fd-toolbar-item], [fdOverflowGroup], [fdOverflowPriority]", inputs: ["fdOverflowPriority", "fdOverflowGroup"] }, { kind: "directive", type: i6.ToolbarSpacerDirective, selector: "fd-toolbar-spacer", inputs: ["width", "class", "fixed"] }, { kind: "component", type: i7.CalendarSelectionDaysComponent, selector: "bc-calendar-selection-days", inputs: ["startSelectedDayIndex", "endSelectedDayIndex", "monthInfo", "inline"], outputs: ["rangeChange"] }, { kind: "pipe", type: i1.BbbTranslatePipe, name: "bbbTranslate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
35
- }
36
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CalendarHeaderComponent, decorators: [{
37
- type: Component,
38
- args: [{ selector: 'bc-calendar-header', changeDetection: ChangeDetectionStrategy.OnPush, standalone: false, template: "<fd-toolbar [shouldOverflow]=\"true\" [fdType]=\"'transparent'\" [class.rtl]=\"rtl\">\r\n <button fd-button fd-toolbar-item [label]=\"'DateR_Today' | bbbTranslate\" (click)=\"today.emit()\"></button>\r\n <button\r\n fd-button\r\n fdType=\"transparent\"\r\n fd-toolbar-item\r\n [glyph]=\"rtl ? 'navigation-right-arrow' : 'navigation-left-arrow'\"\r\n (click)=\"prevTap.emit()\"\r\n ></button>\r\n <button\r\n fd-button\r\n fdType=\"transparent\"\r\n fd-toolbar-item\r\n [glyph]=\"rtl ? 'navigation-left-arrow' : 'navigation-right-arrow'\"\r\n (click)=\"nextTap.emit()\"\r\n ></button>\r\n <h3 fd-title fd-toolbar-item>{{ title }}</h3>\r\n <fd-toolbar-spacer></fd-toolbar-spacer>\r\n <!-- <button fd-button fd-toolbar-item glyph=\"print\" (click)=\"onPrint()\" fdType=\"transparent\"></button> -->\r\n @if (deviceSize === 's' || deviceSize === 'm') {\r\n <bc-calendar-selection-days\r\n fd-toolbar-item\r\n [monthInfo]=\"monthInfo\"\r\n (rangeChange)=\"onRangeChange($event)\"\r\n ></bc-calendar-selection-days>\r\n } @if (!hideMode) {\r\n <fd-split-button\r\n fd-toolbar-item\r\n [fixedWidth]=\"false\"\r\n [mainAction]=\"{\r\n mainActionTitle: modeTitle,\r\n keepMainAction: true\r\n }\"\r\n >\r\n <fd-menu #menu>\r\n <li fd-menu-item (click)=\"onModeChange(menu, 'day')\" bodyClick>\r\n <div fd-menu-interactive>\r\n <span fd-menu-title>{{ 'Day' | bbbTranslate }}</span>\r\n </div>\r\n </li>\r\n <li fd-menu-item (click)=\"onModeChange(menu, 'week')\" bodyClick>\r\n <div fd-menu-interactive>\r\n <span fd-menu-title>{{ 'Week' | bbbTranslate }} </span>\r\n </div>\r\n </li>\r\n <li fd-menu-item (click)=\"onModeChange(menu, 'month')\" bodyClick>\r\n <div fd-menu-interactive>\r\n <span fd-menu-title>{{ 'Month' | bbbTranslate }}</span>\r\n </div>\r\n </li>\r\n <!-- <li fd-menu-item (click)=\"onModeChange('year')\">\r\n <div fd-menu-interactive>\r\n <span fd-menu-title>{{ \"Year\" | bbbTranslate }}</span>\r\n </div>\r\n </li> -->\r\n </fd-menu>\r\n </fd-split-button>\r\n }\r\n</fd-toolbar>\r\n", styles: [":host{display:block;background-color:var(--sapList_Background, #fff)}:host ::ng-deep span.fd-toolbar__spacer{display:none}:host ::ng-deep fd-toolbar .fd-toolbar{border:none;border-left:1px solid var(--sapList_BorderColor, #e5e5e5)}:host ::ng-deep fd-toolbar.rtl .fd-toolbar{border-left:none;border-right:1px solid var(--sapList_BorderColor, #e5e5e5)}\n"] }]
39
- }], propDecorators: { monthInfo: [{
40
- type: Input
41
- }], weekModeDays: [{
42
- type: Input
43
- }], hideMode: [{
44
- type: Input
45
- }], modeTitle: [{
46
- type: Input
47
- }], title: [{
48
- type: Input
49
- }], deviceSize: [{
50
- type: Input
51
- }], rtl: [{
52
- type: Input
53
- }], mode: [{
54
- type: Input
55
- }], prevTap: [{
56
- type: Output
57
- }], nextTap: [{
58
- type: Output
59
- }], modeChange: [{
60
- type: Output
61
- }], rangeChange: [{
62
- type: Output
63
- }], today: [{
64
- type: Output
65
- }] } });
66
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FsZW5kYXItaGVhZGVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2JhcnNhLWNhbGVuZGFyL3NyYy9saWIvY2FsZW5kYXItaGVhZGVyL2NhbGVuZGFyLWhlYWRlci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9iYXJzYS1jYWxlbmRhci9zcmMvbGliL2NhbGVuZGFyLWhlYWRlci9jYWxlbmRhci1oZWFkZXIuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUVoRyxPQUFPLEVBQUUsYUFBYSxFQUF5QixNQUFNLHNCQUFzQixDQUFDOzs7Ozs7Ozs7QUFRNUUsTUFBTSxPQUFPLHVCQUF3QixTQUFRLGFBQWE7SUFQMUQ7O1FBVWEsYUFBUSxHQUFHLEtBQUssQ0FBQztRQU1oQixZQUFPLEdBQUcsSUFBSSxZQUFZLEVBQUUsQ0FBQztRQUM3QixZQUFPLEdBQUcsSUFBSSxZQUFZLEVBQUUsQ0FBQztRQUM3QixlQUFVLEdBQUcsSUFBSSxZQUFZLEVBQWdCLENBQUM7UUFDOUMsZ0JBQVcsR0FBRyxJQUFJLFlBQVksRUFJcEMsQ0FBQztRQUNLLFVBQUssR0FBRyxJQUFJLFlBQVksRUFBRSxDQUFDO1FBRXJDLGNBQVMsR0FBRyxFQUFFLENBQUM7S0FjbEI7SUFaRzs7T0FFRztJQUVILFlBQVksQ0FBQyxJQUFJLEVBQUUsSUFBa0I7UUFDakMsSUFBSSxDQUFDLEtBQUssRUFBRSxDQUFDO1FBQ2IsSUFBSSxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDL0IsQ0FBQztJQUNELGFBQWEsQ0FBQyxLQUFLO1FBQ2YsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDakMsQ0FBQztJQUNELE9BQU8sS0FBVSxDQUFDOytHQWhDVCx1QkFBdUI7bUdBQXZCLHVCQUF1QixnWUNWcEMsdTVFQTJEQTs7NEZEakRhLHVCQUF1QjtrQkFQbkMsU0FBUzsrQkFDSSxvQkFBb0IsbUJBR2IsdUJBQXVCLENBQUMsTUFBTSxjQUNuQyxLQUFLOzhCQUdSLFNBQVM7c0JBQWpCLEtBQUs7Z0JBQ0csWUFBWTtzQkFBcEIsS0FBSztnQkFDRyxRQUFRO3NCQUFoQixLQUFLO2dCQUNHLFNBQVM7c0JBQWpCLEtBQUs7Z0JBQ0csS0FBSztzQkFBYixLQUFLO2dCQUNHLFVBQVU7c0JBQWxCLEtBQUs7Z0JBQ0csR0FBRztzQkFBWCxLQUFLO2dCQUNHLElBQUk7c0JBQVosS0FBSztnQkFDSSxPQUFPO3NCQUFoQixNQUFNO2dCQUNHLE9BQU87c0JBQWhCLE1BQU07Z0JBQ0csVUFBVTtzQkFBbkIsTUFBTTtnQkFDRyxXQUFXO3NCQUFwQixNQUFNO2dCQUtHLEtBQUs7c0JBQWQsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBDYWxlbmRhck1vZGUsIENhbGVuZGFyTW9udGhJbmZvLCBEYXkgfSBmcm9tICcuLi9tb2RlbHMnO1xyXG5pbXBvcnQgeyBCYXNlQ29tcG9uZW50LCBBYmJyZXZhdGlvbkRldmljZVNpemUgfSBmcm9tICdiYXJzYS1ub3Zpbi1yYXktY29yZSc7XHJcbkBDb21wb25lbnQoe1xyXG4gICAgc2VsZWN0b3I6ICdiYy1jYWxlbmRhci1oZWFkZXInLFxyXG4gICAgdGVtcGxhdGVVcmw6ICcuL2NhbGVuZGFyLWhlYWRlci5jb21wb25lbnQuaHRtbCcsXHJcbiAgICBzdHlsZVVybHM6IFsnLi9jYWxlbmRhci1oZWFkZXIuY29tcG9uZW50LnNjc3MnXSxcclxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxyXG4gICAgc3RhbmRhbG9uZTogZmFsc2VcclxufSlcclxuZXhwb3J0IGNsYXNzIENhbGVuZGFySGVhZGVyQ29tcG9uZW50IGV4dGVuZHMgQmFzZUNvbXBvbmVudCB7XHJcbiAgICBASW5wdXQoKSBtb250aEluZm86IENhbGVuZGFyTW9udGhJbmZvO1xyXG4gICAgQElucHV0KCkgd2Vla01vZGVEYXlzOiBEYXlbXTtcclxuICAgIEBJbnB1dCgpIGhpZGVNb2RlID0gZmFsc2U7XHJcbiAgICBASW5wdXQoKSBtb2RlVGl0bGU6IHN0cmluZztcclxuICAgIEBJbnB1dCgpIHRpdGxlOiBzdHJpbmc7XHJcbiAgICBASW5wdXQoKSBkZXZpY2VTaXplOiBBYmJyZXZhdGlvbkRldmljZVNpemU7XHJcbiAgICBASW5wdXQoKSBydGw6IGJvb2xlYW47XHJcbiAgICBASW5wdXQoKSBtb2RlOiBDYWxlbmRhck1vZGU7XHJcbiAgICBAT3V0cHV0KCkgcHJldlRhcCA9IG5ldyBFdmVudEVtaXR0ZXIoKTtcclxuICAgIEBPdXRwdXQoKSBuZXh0VGFwID0gbmV3IEV2ZW50RW1pdHRlcigpO1xyXG4gICAgQE91dHB1dCgpIG1vZGVDaGFuZ2UgPSBuZXcgRXZlbnRFbWl0dGVyPENhbGVuZGFyTW9kZT4oKTtcclxuICAgIEBPdXRwdXQoKSByYW5nZUNoYW5nZSA9IG5ldyBFdmVudEVtaXR0ZXI8e1xyXG4gICAgICAgIHN0YXJ0RGF5OiBEYXk7XHJcbiAgICAgICAgZW5kRGF5OiBEYXk7XHJcbiAgICAgICAgbW9udGhJbmZvOiBDYWxlbmRhck1vbnRoSW5mbztcclxuICAgIH0+KCk7XHJcbiAgICBAT3V0cHV0KCkgdG9kYXkgPSBuZXcgRXZlbnRFbWl0dGVyKCk7XHJcbiAgICB5ZWFyOiBzdHJpbmc7XHJcbiAgICBtb250aE5hbWUgPSAnJztcclxuXHJcbiAgICAvKipcclxuICAgICAqXHJcbiAgICAgKi9cclxuXHJcbiAgICBvbk1vZGVDaGFuZ2UobWVudSwgbW9kZTogQ2FsZW5kYXJNb2RlKTogdm9pZCB7XHJcbiAgICAgICAgbWVudS5jbG9zZSgpO1xyXG4gICAgICAgIHRoaXMubW9kZUNoYW5nZS5lbWl0KG1vZGUpO1xyXG4gICAgfVxyXG4gICAgb25SYW5nZUNoYW5nZShyYW5nZSk6IHZvaWQge1xyXG4gICAgICAgIHRoaXMucmFuZ2VDaGFuZ2UuZW1pdChyYW5nZSk7XHJcbiAgICB9XHJcbiAgICBvblByaW50KCk6IHZvaWQge31cclxufVxyXG4iLCI8ZmQtdG9vbGJhciBbc2hvdWxkT3ZlcmZsb3ddPVwidHJ1ZVwiIFtmZFR5cGVdPVwiJ3RyYW5zcGFyZW50J1wiIFtjbGFzcy5ydGxdPVwicnRsXCI+XHJcbiAgICA8YnV0dG9uIGZkLWJ1dHRvbiBmZC10b29sYmFyLWl0ZW0gW2xhYmVsXT1cIidEYXRlUl9Ub2RheScgfCBiYmJUcmFuc2xhdGVcIiAoY2xpY2spPVwidG9kYXkuZW1pdCgpXCI+PC9idXR0b24+XHJcbiAgICA8YnV0dG9uXHJcbiAgICAgICAgZmQtYnV0dG9uXHJcbiAgICAgICAgZmRUeXBlPVwidHJhbnNwYXJlbnRcIlxyXG4gICAgICAgIGZkLXRvb2xiYXItaXRlbVxyXG4gICAgICAgIFtnbHlwaF09XCJydGwgPyAnbmF2aWdhdGlvbi1yaWdodC1hcnJvdycgOiAnbmF2aWdhdGlvbi1sZWZ0LWFycm93J1wiXHJcbiAgICAgICAgKGNsaWNrKT1cInByZXZUYXAuZW1pdCgpXCJcclxuICAgID48L2J1dHRvbj5cclxuICAgIDxidXR0b25cclxuICAgICAgICBmZC1idXR0b25cclxuICAgICAgICBmZFR5cGU9XCJ0cmFuc3BhcmVudFwiXHJcbiAgICAgICAgZmQtdG9vbGJhci1pdGVtXHJcbiAgICAgICAgW2dseXBoXT1cInJ0bCA/ICduYXZpZ2F0aW9uLWxlZnQtYXJyb3cnIDogJ25hdmlnYXRpb24tcmlnaHQtYXJyb3cnXCJcclxuICAgICAgICAoY2xpY2spPVwibmV4dFRhcC5lbWl0KClcIlxyXG4gICAgPjwvYnV0dG9uPlxyXG4gICAgPGgzIGZkLXRpdGxlIGZkLXRvb2xiYXItaXRlbT57eyB0aXRsZSB9fTwvaDM+XHJcbiAgICA8ZmQtdG9vbGJhci1zcGFjZXI+PC9mZC10b29sYmFyLXNwYWNlcj5cclxuICAgIDwhLS0gPGJ1dHRvbiBmZC1idXR0b24gZmQtdG9vbGJhci1pdGVtIGdseXBoPVwicHJpbnRcIiAoY2xpY2spPVwib25QcmludCgpXCIgZmRUeXBlPVwidHJhbnNwYXJlbnRcIj48L2J1dHRvbj4gLS0+XHJcbiAgICBAaWYgKGRldmljZVNpemUgPT09ICdzJyB8fCBkZXZpY2VTaXplID09PSAnbScpIHtcclxuICAgIDxiYy1jYWxlbmRhci1zZWxlY3Rpb24tZGF5c1xyXG4gICAgICAgIGZkLXRvb2xiYXItaXRlbVxyXG4gICAgICAgIFttb250aEluZm9dPVwibW9udGhJbmZvXCJcclxuICAgICAgICAocmFuZ2VDaGFuZ2UpPVwib25SYW5nZUNoYW5nZSgkZXZlbnQpXCJcclxuICAgID48L2JjLWNhbGVuZGFyLXNlbGVjdGlvbi1kYXlzPlxyXG4gICAgfSBAaWYgKCFoaWRlTW9kZSkge1xyXG4gICAgPGZkLXNwbGl0LWJ1dHRvblxyXG4gICAgICAgIGZkLXRvb2xiYXItaXRlbVxyXG4gICAgICAgIFtmaXhlZFdpZHRoXT1cImZhbHNlXCJcclxuICAgICAgICBbbWFpbkFjdGlvbl09XCJ7XHJcbiAgICAgICAgICAgIG1haW5BY3Rpb25UaXRsZTogbW9kZVRpdGxlLFxyXG4gICAgICAgICAgICBrZWVwTWFpbkFjdGlvbjogdHJ1ZVxyXG4gICAgICAgIH1cIlxyXG4gICAgPlxyXG4gICAgICAgIDxmZC1tZW51ICNtZW51PlxyXG4gICAgICAgICAgICA8bGkgZmQtbWVudS1pdGVtIChjbGljayk9XCJvbk1vZGVDaGFuZ2UobWVudSwgJ2RheScpXCIgYm9keUNsaWNrPlxyXG4gICAgICAgICAgICAgICAgPGRpdiBmZC1tZW51LWludGVyYWN0aXZlPlxyXG4gICAgICAgICAgICAgICAgICAgIDxzcGFuIGZkLW1lbnUtdGl0bGU+e3sgJ0RheScgfCBiYmJUcmFuc2xhdGUgfX08L3NwYW4+XHJcbiAgICAgICAgICAgICAgICA8L2Rpdj5cclxuICAgICAgICAgICAgPC9saT5cclxuICAgICAgICAgICAgPGxpIGZkLW1lbnUtaXRlbSAoY2xpY2spPVwib25Nb2RlQ2hhbmdlKG1lbnUsICd3ZWVrJylcIiBib2R5Q2xpY2s+XHJcbiAgICAgICAgICAgICAgICA8ZGl2IGZkLW1lbnUtaW50ZXJhY3RpdmU+XHJcbiAgICAgICAgICAgICAgICAgICAgPHNwYW4gZmQtbWVudS10aXRsZT57eyAnV2VlaycgfCBiYmJUcmFuc2xhdGUgfX0gPC9zcGFuPlxyXG4gICAgICAgICAgICAgICAgPC9kaXY+XHJcbiAgICAgICAgICAgIDwvbGk+XHJcbiAgICAgICAgICAgIDxsaSBmZC1tZW51LWl0ZW0gKGNsaWNrKT1cIm9uTW9kZUNoYW5nZShtZW51LCAnbW9udGgnKVwiIGJvZHlDbGljaz5cclxuICAgICAgICAgICAgICAgIDxkaXYgZmQtbWVudS1pbnRlcmFjdGl2ZT5cclxuICAgICAgICAgICAgICAgICAgICA8c3BhbiBmZC1tZW51LXRpdGxlPnt7ICdNb250aCcgfCBiYmJUcmFuc2xhdGUgfX08L3NwYW4+XHJcbiAgICAgICAgICAgICAgICA8L2Rpdj5cclxuICAgICAgICAgICAgPC9saT5cclxuICAgICAgICAgICAgPCEtLSA8bGkgZmQtbWVudS1pdGVtIChjbGljayk9XCJvbk1vZGVDaGFuZ2UoJ3llYXInKVwiPlxyXG4gICAgICAgIDxkaXYgZmQtbWVudS1pbnRlcmFjdGl2ZT5cclxuICAgICAgICAgIDxzcGFuIGZkLW1lbnUtdGl0bGU+e3sgXCJZZWFyXCIgfCBiYmJUcmFuc2xhdGUgfX08L3NwYW4+XHJcbiAgICAgICAgPC9kaXY+XHJcbiAgICAgIDwvbGk+IC0tPlxyXG4gICAgICAgIDwvZmQtbWVudT5cclxuICAgIDwvZmQtc3BsaXQtYnV0dG9uPlxyXG4gICAgfVxyXG48L2ZkLXRvb2xiYXI+XHJcbiJdfQ==
@@ -1,18 +0,0 @@
1
- import { ChangeDetectionStrategy, Component, Input } 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-item/calendar-list-item.component";
5
- export class CalendarListComponent extends BaseComponent {
6
- trackById(index, item) {
7
- return item.Id;
8
- }
9
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CalendarListComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
10
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: CalendarListComponent, selector: "bc-calendar-list", inputs: { moDataList: "moDataList" }, usesInheritance: true, ngImport: i0, template: "@for (item of moDataList; track trackById($index, item)) {\r\n<bc-calendar-list-item [mo]=\"item\"> </bc-calendar-list-item>\r\n}\r\n", styles: [""], dependencies: [{ kind: "component", type: i1.CalendarListItemComponent, selector: "bc-calendar-list-item", inputs: ["mo"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
11
- }
12
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CalendarListComponent, decorators: [{
13
- type: Component,
14
- args: [{ selector: 'bc-calendar-list', changeDetection: ChangeDetectionStrategy.OnPush, standalone: false, template: "@for (item of moDataList; track trackById($index, item)) {\r\n<bc-calendar-list-item [mo]=\"item\"> </bc-calendar-list-item>\r\n}\r\n" }]
15
- }], propDecorators: { moDataList: [{
16
- type: Input
17
- }] } });
18
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FsZW5kYXItbGlzdC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9iYXJzYS1jYWxlbmRhci9zcmMvbGliL2NhbGVuZGFyLWxpc3QvY2FsZW5kYXItbGlzdC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9iYXJzYS1jYWxlbmRhci9zcmMvbGliL2NhbGVuZGFyLWxpc3QvY2FsZW5kYXItbGlzdC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUUxRSxPQUFPLEVBQUUsYUFBYSxFQUFvRCxNQUFNLHNCQUFzQixDQUFDOzs7QUFRdkcsTUFBTSxPQUFPLHFCQUFzQixTQUFRLGFBQWE7SUFFN0MsU0FBUyxDQUFDLEtBQWEsRUFBRSxJQUF5QjtRQUNyRCxPQUFPLElBQUksQ0FBQyxFQUFFLENBQUM7SUFDbkIsQ0FBQzsrR0FKUSxxQkFBcUI7bUdBQXJCLHFCQUFxQixxSENWbEMsdUlBR0E7OzRGRE9hLHFCQUFxQjtrQkFQakMsU0FBUzsrQkFDSSxrQkFBa0IsbUJBR1gsdUJBQXVCLENBQUMsTUFBTSxjQUNuQyxLQUFLOzhCQUdSLFVBQVU7c0JBQWxCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5cclxuaW1wb3J0IHsgQmFzZUNvbXBvbmVudCwgTWV0YW9iamVjdERhdGFNb2RlbCwgQ2FsZW5kYXJNZXRhb2JqZWN0RGF0YU1vZGVsIH0gZnJvbSAnYmFyc2Etbm92aW4tcmF5LWNvcmUnO1xyXG5AQ29tcG9uZW50KHtcclxuICAgIHNlbGVjdG9yOiAnYmMtY2FsZW5kYXItbGlzdCcsXHJcbiAgICB0ZW1wbGF0ZVVybDogJy4vY2FsZW5kYXItbGlzdC5jb21wb25lbnQuaHRtbCcsXHJcbiAgICBzdHlsZVVybHM6IFsnLi9jYWxlbmRhci1saXN0LmNvbXBvbmVudC5zY3NzJ10sXHJcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcclxuICAgIHN0YW5kYWxvbmU6IGZhbHNlXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBDYWxlbmRhckxpc3RDb21wb25lbnQgZXh0ZW5kcyBCYXNlQ29tcG9uZW50IHtcclxuICAgIEBJbnB1dCgpIG1vRGF0YUxpc3Q6IENhbGVuZGFyTWV0YW9iamVjdERhdGFNb2RlbFtdO1xyXG4gICAgcHVibGljIHRyYWNrQnlJZChpbmRleDogbnVtYmVyLCBpdGVtOiBNZXRhb2JqZWN0RGF0YU1vZGVsKTogc3RyaW5nIHtcclxuICAgICAgICByZXR1cm4gaXRlbS5JZDtcclxuICAgIH1cclxufVxyXG4iLCJAZm9yIChpdGVtIG9mIG1vRGF0YUxpc3Q7IHRyYWNrIHRyYWNrQnlJZCgkaW5kZXgsIGl0ZW0pKSB7XHJcbjxiYy1jYWxlbmRhci1saXN0LWl0ZW0gW21vXT1cIml0ZW1cIj4gPC9iYy1jYWxlbmRhci1saXN0LWl0ZW0+XHJcbn1cclxuIl19
@@ -1,29 +0,0 @@
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: "18.2.13", ngImport: i0, type: CalendarListContainerComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
11
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", 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) {\r\n<bc-calendar-list [moDataList]=\"selectedDay.tasks\"></bc-calendar-list>\r\n}\r\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: "18.2.13", ngImport: i0, type: CalendarListContainerComponent, decorators: [{
14
- type: Component,
15
- args: [{ selector: 'bc-calendar-list-container', changeDetection: ChangeDetectionStrategy.OnPush, standalone: false, template: "@if (selectedDay) {\r\n<bc-calendar-list [moDataList]=\"selectedDay.tasks\"></bc-calendar-list>\r\n}\r\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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FsZW5kYXItbGlzdC1jb250YWluZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFyc2EtY2FsZW5kYXIvc3JjL2xpYi9jYWxlbmRhci1saXN0LWNvbnRhaW5lci9jYWxlbmRhci1saXN0LWNvbnRhaW5lci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9iYXJzYS1jYWxlbmRhci9zcmMvbGliL2NhbGVuZGFyLWxpc3QtY29udGFpbmVyL2NhbGVuZGFyLWxpc3QtY29udGFpbmVyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFaEcsT0FBTyxFQUFFLGFBQWEsRUFBa0IsTUFBTSxzQkFBc0IsQ0FBQzs7O0FBU3JFLE1BQU0sT0FBTyw4QkFBK0IsU0FBUSxhQUFhO0lBUGpFOztRQWFjLGtCQUFhLEdBQUcsSUFBSSxZQUFZLEVBQUUsQ0FBQztLQUNoRDsrR0FQWSw4QkFBOEI7bUdBQTlCLDhCQUE4Qiw0U0NYM0MsMEdBR0E7OzRGRFFhLDhCQUE4QjtrQkFQMUMsU0FBUzsrQkFDSSw0QkFBNEIsbUJBR3JCLHVCQUF1QixDQUFDLE1BQU0sY0FDbkMsS0FBSzs4QkFHUixJQUFJO3NCQUFaLEtBQUs7Z0JBQ0csdUJBQXVCO3NCQUEvQixLQUFLO2dCQUNHLFVBQVU7c0JBQWxCLEtBQUs7Z0JBQ0csV0FBVztzQkFBbkIsS0FBSztnQkFDRyxjQUFjO3NCQUF0QixLQUFLO2dCQUNJLGFBQWE7c0JBQXRCLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIElucHV0LCBPdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbmltcG9ydCB7IEJhc2VDb21wb25lbnQsIENhbGVuZGFyRmllbGRzIH0gZnJvbSAnYmFyc2Etbm92aW4tcmF5LWNvcmUnO1xyXG5pbXBvcnQgeyBEYXkgfSBmcm9tICcuLi9tb2RlbHMnO1xyXG5AQ29tcG9uZW50KHtcclxuICAgIHNlbGVjdG9yOiAnYmMtY2FsZW5kYXItbGlzdC1jb250YWluZXInLFxyXG4gICAgdGVtcGxhdGVVcmw6ICcuL2NhbGVuZGFyLWxpc3QtY29udGFpbmVyLmNvbXBvbmVudC5odG1sJyxcclxuICAgIHN0eWxlVXJsczogWycuL2NhbGVuZGFyLWxpc3QtY29udGFpbmVyLmNvbXBvbmVudC5zY3NzJ10sXHJcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcclxuICAgIHN0YW5kYWxvbmU6IGZhbHNlXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBDYWxlbmRhckxpc3RDb250YWluZXJDb21wb25lbnQgZXh0ZW5kcyBCYXNlQ29tcG9uZW50IHtcclxuICAgIEBJbnB1dCgpIHZpZXc6IGFueTtcclxuICAgIEBJbnB1dCgpIHJlcG9ydEl0ZW1Db21wb25lbnROYW1lOiBzdHJpbmc7XHJcbiAgICBASW5wdXQoKSBzaG93RXZlbnRzOiBib29sZWFuO1xyXG4gICAgQElucHV0KCkgc2VsZWN0ZWREYXk6IERheTtcclxuICAgIEBJbnB1dCgpIGNhbGVuZGFyRmllbGRzOiBDYWxlbmRhckZpZWxkcztcclxuICAgIEBPdXRwdXQoKSBzaG93RXZlbnRzVGFwID0gbmV3IEV2ZW50RW1pdHRlcigpO1xyXG59XHJcbiIsIkBpZiAoc2VsZWN0ZWREYXkpIHtcclxuPGJjLWNhbGVuZGFyLWxpc3QgW21vRGF0YUxpc3RdPVwic2VsZWN0ZWREYXkudGFza3NcIj48L2JjLWNhbGVuZGFyLWxpc3Q+XHJcbn1cclxuIl19
@@ -1,14 +0,0 @@
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: "18.2.13", ngImport: i0, type: CalendarListItemComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
6
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", 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: "18.2.13", ngImport: i0, type: CalendarListItemComponent, decorators: [{
9
- type: Component,
10
- args: [{ selector: 'bc-calendar-list-item', changeDetection: ChangeDetectionStrategy.OnPush, standalone: false, 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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FsZW5kYXItbGlzdC1pdGVtLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2JhcnNhLWNhbGVuZGFyL3NyYy9saWIvY2FsZW5kYXItbGlzdC1pdGVtL2NhbGVuZGFyLWxpc3QtaXRlbS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9iYXJzYS1jYWxlbmRhci9zcmMvbGliL2NhbGVuZGFyLWxpc3QtaXRlbS9jYWxlbmRhci1saXN0LWl0ZW0uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFMUUsT0FBTyxFQUFFLGFBQWEsRUFBK0IsTUFBTSxzQkFBc0IsQ0FBQzs7QUFRbEYsTUFBTSxPQUFPLHlCQUEwQixTQUFRLGFBQWE7K0dBQS9DLHlCQUF5QjttR0FBekIseUJBQXlCLDBHQ1Z0QyxzaEJBWUE7OzRGREZhLHlCQUF5QjtrQkFQckMsU0FBUzsrQkFDSSx1QkFBdUIsbUJBR2hCLHVCQUF1QixDQUFDLE1BQU0sY0FDbkMsS0FBSzs4QkFHUixFQUFFO3NCQUFWLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5cclxuaW1wb3J0IHsgQmFzZUNvbXBvbmVudCwgQ2FsZW5kYXJNZXRhb2JqZWN0RGF0YU1vZGVsIH0gZnJvbSAnYmFyc2Etbm92aW4tcmF5LWNvcmUnO1xyXG5AQ29tcG9uZW50KHtcclxuICAgIHNlbGVjdG9yOiAnYmMtY2FsZW5kYXItbGlzdC1pdGVtJyxcclxuICAgIHRlbXBsYXRlVXJsOiAnLi9jYWxlbmRhci1saXN0LWl0ZW0uY29tcG9uZW50Lmh0bWwnLFxyXG4gICAgc3R5bGVVcmxzOiBbJy4vY2FsZW5kYXItbGlzdC1pdGVtLmNvbXBvbmVudC5zY3NzJ10sXHJcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcclxuICAgIHN0YW5kYWxvbmU6IGZhbHNlXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBDYWxlbmRhckxpc3RJdGVtQ29tcG9uZW50IGV4dGVuZHMgQmFzZUNvbXBvbmVudCB7XHJcbiAgICBASW5wdXQoKSBtbzogQ2FsZW5kYXJNZXRhb2JqZWN0RGF0YU1vZGVsO1xyXG59XHJcbiIsIjxkaXYgY2xhc3M9XCJ3cmFwcGVyXCI+XHJcbiAgICA8ZGl2IGZsZXhTaHJpbms9XCIxXCIgY2xhc3M9XCJkYXktd3JhcHBlclwiPlxyXG4gICAgICAgIDxMYWJlbCBbdGV4dF09XCJtby4kU3RhcnRUaW1lc1wiPjwvTGFiZWw+XHJcbiAgICAgICAgPExhYmVsIGNsYXNzPVwiZWxhXCIgW3RleHRdPVwiJ9in2YTbjCdcIj48L0xhYmVsPlxyXG4gICAgICAgIDxMYWJlbCBbdGV4dF09XCJtby4kRW5kVGltZXNcIj48L0xhYmVsPlxyXG4gICAgPC9kaXY+XHJcbiAgICA8ZGl2IGNsYXNzPVwiY29sb3JcIiBbc3R5bGUuYmFja2dyb3VuZC1jb2xvcl09XCJtby4kQ29sb3JcIj48L2Rpdj5cclxuICAgIDxkaXYgY2xhc3M9XCJldmVudC13cmFwcGVyXCI+XHJcbiAgICAgICAgPExhYmVsIGNsYXNzPVwidGl0bGVcIiBbdGV4dF09XCJtby4kVGl0bGVcIj48L0xhYmVsPlxyXG4gICAgICAgIDxMYWJlbCBjbGFzcz1cImRlc2NcIiBbdGV4dF09XCJtby4kTm90ZXNcIj48L0xhYmVsPlxyXG4gICAgPC9kaXY+XHJcbjwvZGl2PlxyXG4iXX0=
@@ -1,249 +0,0 @@
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.canView = false;
28
- this.editEvent = new EventEmitter();
29
- this.deleteEvent = new EventEmitter();
30
- this.daySelect = new EventEmitter();
31
- this.dayClick = new EventEmitter();
32
- this.dayMouseMove = new EventEmitter();
33
- this.dayMouseUp = new EventEmitter();
34
- this.dayMouseDown = new EventEmitter();
35
- this.showEvent = new EventEmitter();
36
- this.taskHeight = 30;
37
- this._hasPopoverOpened = [];
38
- }
39
- ngOnChanges(changes) {
40
- super.ngOnChanges(changes);
41
- let needToDetectChange = false;
42
- const { containerHeight, deviceSize, moDataList, days, monthWeeksCount, startSelectedDayIndex, endSelectedDayIndex } = changes;
43
- if (containerHeight && !containerHeight.firstChange) {
44
- this.fitToContainer(changes.containerHeight.currentValue);
45
- }
46
- if (deviceSize && !deviceSize.firstChange) {
47
- this.prepareWeekDays(changes.deviceSize.currentValue);
48
- }
49
- if (moDataList && !moDataList.firstChange) {
50
- this._prepareDaysTasks(changes.moDataList.currentValue);
51
- needToDetectChange = true;
52
- }
53
- if (days && !days.firstChange) {
54
- this.fitToContainer(this.containerHeight);
55
- this._prepareDaysTasks(this.moDataList);
56
- needToDetectChange = true;
57
- }
58
- if (monthWeeksCount && !monthWeeksCount.firstChange) {
59
- this.fitToContainer(this.containerHeight);
60
- this._prepareDaysTasks(this.moDataList);
61
- needToDetectChange = true;
62
- }
63
- if ((startSelectedDayIndex && !startSelectedDayIndex.firstChange) ||
64
- (endSelectedDayIndex && !endSelectedDayIndex.firstChange)) {
65
- needToDetectChange = true;
66
- }
67
- if (needToDetectChange) {
68
- this._cdr.detectChanges();
69
- }
70
- }
71
- ngOnInit() {
72
- super.ngOnInit();
73
- this.isPickerMode = this.datePicker || this.rangePicker;
74
- this.prepareWeekDays(this.deviceSize);
75
- this._prepareDaysTasks(this.moDataList);
76
- this.fitToContainer(this.containerHeight);
77
- }
78
- onDayBoxSelect(day) {
79
- this._fireDaySelect(day);
80
- }
81
- onDaySelect(weekIndex, dayIndex) {
82
- if (!this.canAdd) {
83
- return;
84
- }
85
- const day = this.days[weekIndex * 7 + dayIndex];
86
- this._fireDaySelect(day);
87
- }
88
- onOpenPopoverChange(isOpen) {
89
- this._openPopover(isOpen);
90
- }
91
- onMoreButton(e, popover) {
92
- this._preventEvent(e);
93
- popover.open();
94
- }
95
- onTask(e, task) {
96
- this.showEvent.emit(task);
97
- }
98
- onDayClick(day) {
99
- this.selected = day;
100
- this.dayClick.emit(day);
101
- }
102
- onDayMouseMove(day) {
103
- this.dayMouseMove.emit(day);
104
- }
105
- onDayMouseDown(day) {
106
- this.dayMouseDown.emit(day);
107
- }
108
- onDayMouseUp(day) {
109
- this.dayMouseUp.emit(day);
110
- }
111
- _preventEvent(e) {
112
- e.stopPropagation();
113
- e.preventDefault();
114
- }
115
- _fireDaySelect(day) {
116
- if (this._hasPopoverOpened.length === 0) {
117
- this.daySelect.emit({
118
- date: day.date
119
- });
120
- }
121
- }
122
- _openPopover(isOpen) {
123
- if (isOpen) {
124
- this._hasPopoverOpened.push(true);
125
- }
126
- else {
127
- setTimeout(() => {
128
- this._hasPopoverOpened = [];
129
- }, 0);
130
- }
131
- }
132
- prepareWeekDays(deviceSize) {
133
- if (deviceSize !== 's' && deviceSize !== 'm') {
134
- this.selectedWeekDays = this.weekDays;
135
- }
136
- else {
137
- this.selectedWeekDays = this.weekDaysMin;
138
- }
139
- }
140
- fitToContainer(containerHeight) {
141
- let _weeksCount;
142
- if (this.monthWeeksCount > 0) {
143
- const weeksCount = this.monthWeeksCount;
144
- _weeksCount = weeksCount;
145
- }
146
- else {
147
- _weeksCount = this.days.length / 7;
148
- }
149
- this.numberOfWeek = Array.from(Array(_weeksCount).keys());
150
- this.numberOfWeek = this.numberOfWeek.map((value) => value);
151
- if (this.isPickerMode) {
152
- this.dayHeight = 40;
153
- return;
154
- }
155
- this.dayHeight = Math.floor(containerHeight / (_weeksCount + 1));
156
- this.maxTaskCount = Math.floor((this.dayHeight - this.taskHeight) / this.taskHeight);
157
- if (this.maxTaskCount > 0) {
158
- this.maxRowTasks = new Array(this.maxTaskCount).fill(0).map((x, i) => i);
159
- }
160
- }
161
- _prepareDaysTasks(calendarTasks) {
162
- if (this.isPickerMode) {
163
- this.weekTasksArray = {};
164
- return;
165
- }
166
- const calendarFields = this.calendarFields;
167
- // Sort all Tasks
168
- const moDataList = this._calendarService.sortTasks(calendarTasks, calendarFields);
169
- this.days.forEach((day) => (day.tasks = []));
170
- const weekTasksArray = [];
171
- for (let j = 0; j < this.days.length / 7; j++) {
172
- const days = this.daysInWeek.transform(this.days, j);
173
- const week = this._calendarService.createWeekTask(days, moDataList, calendarFields, 0);
174
- weekTasksArray.push(week);
175
- }
176
- weekTasksArray.forEach((week) => {
177
- const arr = Object.values(week);
178
- for (let i = arr.length; i < this.maxTaskCount; i++) {
179
- week[i.toString()] = [];
180
- }
181
- });
182
- // به ازای هر ردیف تسک باید تعداد 7 ستون اضافه گردد و برای ستونی که تسکی ندارد یک جای خالی colspan 1 میگذاریم
183
- weekTasksArray.forEach((week) => {
184
- this._calendarService.fillWeek(week);
185
- });
186
- this.weekTasksArray = weekTasksArray;
187
- }
188
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CalendarMonthComponent, deps: [{ token: i1.DaysInWeekPipe }, { token: i0.ChangeDetectorRef }, { token: i2.CalendarService }], target: i0.ɵɵFactoryTarget.Component }); }
189
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", 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", canView: "canView", 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\">\r\n <thead fd-table-header>\r\n <tr fd-table-row>\r\n @for (weekDay of selectedWeekDays; track weekDay) {\r\n <th class=\"weekday-header\" fd-table-cell [class.noborder]=\"isPickerMode\">\r\n {{ weekDay | slice: 0:1 }}\r\n </th>\r\n }\r\n </tr>\r\n </thead>\r\n <tbody fd-table-body>\r\n @for (weekDay of numberOfWeek; track weekDay) {\r\n <tr fd-table-row>\r\n <td [style.height.px]=\"dayHeight\" fd-table-cell colspan=\"7\" [style.border]=\"isPickerMode ? 'none' : null\">\r\n <ng-container\r\n *ngTemplateOutlet=\"\r\n renderTasks;\r\n context: {\r\n $implicit: isPickerMode ? null : moDataList[weekDay],\r\n weekIndex: weekDay,\r\n days: days | daysInWeek: weekDay,\r\n maxRowTasks: maxRowTasks,\r\n weekDays: weekDays,\r\n calendarFields: calendarFields,\r\n deviceSize: deviceSize,\r\n rtl: rtl,\r\n isPickerMode: isPickerMode\r\n }\r\n \"\r\n ></ng-container>\r\n </td>\r\n </tr>\r\n }\r\n </tbody>\r\n</table>\r\n<ng-template\r\n #renderTasks\r\n let-task\r\n let-weekIndex=\"weekIndex\"\r\n let-weekDays=\"weekDays\"\r\n let-days=\"days\"\r\n let-maxRowTasks=\"maxRowTasks\"\r\n let-calendarFields=\"calendarFields\"\r\n let-deviceSize=\"deviceSize\"\r\n let-rtl=\"rtl\"\r\n let-isPickerMode=\"isPickerMode\"\r\n>\r\n <table fd-table-body class=\"table-content\" [compact]=\"true\">\r\n <tbody>\r\n <tr fd-table-row class=\"row-day-number\" [attr.rtl]=\"rtl\">\r\n @for (day of days; track day) {\r\n <td fd-table-cell [class.noborder]=\"isPickerMode\">\r\n <bc-day-number-box\r\n [ngClass]=\"{\r\n 'fd-calendar__item': isPickerMode,\r\n '!tw-border !tw-rounded-md tw-transition-all tw-cursor-pointer':\r\n isPickerMode && day.isInMonth,\r\n '!tw-bg-transparent tw-border-gray-100 hover:!tw-border-gray-300':\r\n isPickerMode && day.isInMonth && !day.isToday,\r\n 'fd-calendar__item--other-month': isPickerMode && !day.isInMonth,\r\n 'fd-calendar__item--weekend': isPickerMode && day.isWeekend,\r\n '!tw-bg-blue-500 hover:!tw-bg-blue-600': day.isToday\r\n }\"\r\n [isPickerMode]=\"isPickerMode\"\r\n [day]=\"day\"\r\n [isActive]=\"\r\n day.index === startSelectedDayIndex || day.index === endSelectedDayIndex || day.date\r\n | equalDate: selectedDate\r\n \"\r\n [itemInRange]=\"\r\n startSelectedDayIndex !== undefined &&\r\n endSelectedDayIndex !== undefined &&\r\n day.index >= startSelectedDayIndex &&\r\n day.index <= endSelectedDayIndex\r\n \"\r\n (dayClick)=\"onDayClick(day)\"\r\n (dayMouseMove)=\"onDayMouseMove(day)\"\r\n (dayMouseDown)=\"onDayMouseDown(day)\"\r\n (dayMouseUp)=\"onDayMouseUp(day)\"\r\n ></bc-day-number-box>\r\n </td>\r\n }\r\n </tr>\r\n @if (!isPickerMode) {\r\n <ng-container\r\n *ngTemplateOutlet=\"\r\n renderDayTasks;\r\n context: {\r\n $implicit: weekTasksArray[weekIndex],\r\n maxRowTasks: maxRowTasks,\r\n weekIndex: weekIndex,\r\n deviceSize: deviceSize,\r\n calendarFields: calendarFields,\r\n weekDays: weekDays\r\n }\r\n \"\r\n ></ng-container>\r\n <tr fd-table-row>\r\n @for (day of days; track day) {\r\n <td fd-table-cell class=\"more-fd\" (click)=\"onDayBoxSelect(day)\">\r\n @if (maxRowTasks?.length < day.tasks.length) {\r\n <button fd-button (click)=\"onMoreButton($event, popover)\" [fdType]=\"'transparent'\" [compact]=\"true\">\r\n {{ day.tasks?.length - maxRowTasks?.length }}\r\n {{ 'More' | bbbTranslate }}\r\n </button>\r\n <fd-popover\r\n #popover\r\n [mobile]=\"deviceSize === 's'\"\r\n placement=\"bottom\"\r\n [focusTrapped]=\"true\"\r\n [focusAutoCapture]=\"true\"\r\n (isOpenChange)=\"onOpenPopoverChange($event)\"\r\n >\r\n <bc-day-event-list\r\n [day]=\"day\"\r\n [calendarFields]=\"calendarFields\"\r\n [deviceSize]=\"deviceSize\"\r\n [weekDays]=\"weekDays\"\r\n [rtl]=\"rtl\"\r\n [canDelete]=\"canDelete\"\r\n [canEdit]=\"canEdit\"\r\n [canView]=\"canView\"\r\n [popover]=\"popover\"\r\n (deleteEvent)=\"deleteEvent.emit($event)\"\r\n (editEvent)=\"editEvent.emit($event)\"\r\n ></bc-day-event-list>\r\n </fd-popover>\r\n }\r\n </td>\r\n }\r\n </tr>\r\n }\r\n </tbody>\r\n </table>\r\n</ng-template>\r\n\r\n<ng-template\r\n #renderDayTasks\r\n let-weekTasks\r\n let-maxRowTasks=\"maxRowTasks\"\r\n let-weekIndex=\"weekIndex\"\r\n let-deviceSize=\"deviceSize\"\r\n let-calendarFields=\"calendarFields\"\r\n let-weekDays=\"weekDays\"\r\n>\r\n @for (rowTask of maxRowTasks; track rowTask; let i = $index) {\r\n <tr fd-table-row>\r\n @if (!weekTasks[i] || weekTasks[i].length === 0) { @for (day of weekDays; track day) {\r\n <td fd-table-cell></td>\r\n } } @for (task of weekTasks[i]; track task; let dayIndex = $index) { @if (task.colSpan) {\r\n <td fd-table-cell [attr.colspan]=\"task.colSpan\">\r\n @if (task.event) {\r\n <bc-event-button\r\n [task]=\"task\"\r\n [calendarFields]=\"calendarFields\"\r\n [deviceSize]=\"deviceSize\"\r\n [rtl]=\"rtl\"\r\n [canDelete]=\"canDelete\"\r\n [canEdit]=\"canEdit\"\r\n [canView]=\"canView\"\r\n (deleteEvent)=\"deleteEvent.emit($event)\"\r\n (editEvent)=\"editEvent.emit($event)\"\r\n (openPopoverChange)=\"onOpenPopoverChange($event)\"\r\n ></bc-event-button>\r\n } @else {\r\n <div style=\"width: 100%; height: 100%\" (click)=\"onDaySelect(weekIndex, dayIndex)\"></div>\r\n }\r\n </td>\r\n } }\r\n </tr>\r\n }\r\n</ng-template>\r\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], span[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", "nonInteractive"] }, { 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", "nonInteractive", "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", "canView", "index", "deviceSize"], outputs: ["deleteEvent", "editEvent", "openPopoverChange"] }, { kind: "component", type: i11.DayEventListComponent, selector: "bc-day-event-list", inputs: ["day", "deviceSize", "weekDays", "calendarFields", "rtl", "canDelete", "canEdit", "canView", "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 }); }
190
- }
191
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CalendarMonthComponent, decorators: [{
192
- type: Component,
193
- args: [{ selector: 'bc-calendar-month', changeDetection: ChangeDetectionStrategy.OnPush, standalone: false, template: "<table fd-table class=\"table-header\" [fdCompact] [attr.picker]=\"datePicker\">\r\n <thead fd-table-header>\r\n <tr fd-table-row>\r\n @for (weekDay of selectedWeekDays; track weekDay) {\r\n <th class=\"weekday-header\" fd-table-cell [class.noborder]=\"isPickerMode\">\r\n {{ weekDay | slice: 0:1 }}\r\n </th>\r\n }\r\n </tr>\r\n </thead>\r\n <tbody fd-table-body>\r\n @for (weekDay of numberOfWeek; track weekDay) {\r\n <tr fd-table-row>\r\n <td [style.height.px]=\"dayHeight\" fd-table-cell colspan=\"7\" [style.border]=\"isPickerMode ? 'none' : null\">\r\n <ng-container\r\n *ngTemplateOutlet=\"\r\n renderTasks;\r\n context: {\r\n $implicit: isPickerMode ? null : moDataList[weekDay],\r\n weekIndex: weekDay,\r\n days: days | daysInWeek: weekDay,\r\n maxRowTasks: maxRowTasks,\r\n weekDays: weekDays,\r\n calendarFields: calendarFields,\r\n deviceSize: deviceSize,\r\n rtl: rtl,\r\n isPickerMode: isPickerMode\r\n }\r\n \"\r\n ></ng-container>\r\n </td>\r\n </tr>\r\n }\r\n </tbody>\r\n</table>\r\n<ng-template\r\n #renderTasks\r\n let-task\r\n let-weekIndex=\"weekIndex\"\r\n let-weekDays=\"weekDays\"\r\n let-days=\"days\"\r\n let-maxRowTasks=\"maxRowTasks\"\r\n let-calendarFields=\"calendarFields\"\r\n let-deviceSize=\"deviceSize\"\r\n let-rtl=\"rtl\"\r\n let-isPickerMode=\"isPickerMode\"\r\n>\r\n <table fd-table-body class=\"table-content\" [compact]=\"true\">\r\n <tbody>\r\n <tr fd-table-row class=\"row-day-number\" [attr.rtl]=\"rtl\">\r\n @for (day of days; track day) {\r\n <td fd-table-cell [class.noborder]=\"isPickerMode\">\r\n <bc-day-number-box\r\n [ngClass]=\"{\r\n 'fd-calendar__item': isPickerMode,\r\n '!tw-border !tw-rounded-md tw-transition-all tw-cursor-pointer':\r\n isPickerMode && day.isInMonth,\r\n '!tw-bg-transparent tw-border-gray-100 hover:!tw-border-gray-300':\r\n isPickerMode && day.isInMonth && !day.isToday,\r\n 'fd-calendar__item--other-month': isPickerMode && !day.isInMonth,\r\n 'fd-calendar__item--weekend': isPickerMode && day.isWeekend,\r\n '!tw-bg-blue-500 hover:!tw-bg-blue-600': day.isToday\r\n }\"\r\n [isPickerMode]=\"isPickerMode\"\r\n [day]=\"day\"\r\n [isActive]=\"\r\n day.index === startSelectedDayIndex || day.index === endSelectedDayIndex || day.date\r\n | equalDate: selectedDate\r\n \"\r\n [itemInRange]=\"\r\n startSelectedDayIndex !== undefined &&\r\n endSelectedDayIndex !== undefined &&\r\n day.index >= startSelectedDayIndex &&\r\n day.index <= endSelectedDayIndex\r\n \"\r\n (dayClick)=\"onDayClick(day)\"\r\n (dayMouseMove)=\"onDayMouseMove(day)\"\r\n (dayMouseDown)=\"onDayMouseDown(day)\"\r\n (dayMouseUp)=\"onDayMouseUp(day)\"\r\n ></bc-day-number-box>\r\n </td>\r\n }\r\n </tr>\r\n @if (!isPickerMode) {\r\n <ng-container\r\n *ngTemplateOutlet=\"\r\n renderDayTasks;\r\n context: {\r\n $implicit: weekTasksArray[weekIndex],\r\n maxRowTasks: maxRowTasks,\r\n weekIndex: weekIndex,\r\n deviceSize: deviceSize,\r\n calendarFields: calendarFields,\r\n weekDays: weekDays\r\n }\r\n \"\r\n ></ng-container>\r\n <tr fd-table-row>\r\n @for (day of days; track day) {\r\n <td fd-table-cell class=\"more-fd\" (click)=\"onDayBoxSelect(day)\">\r\n @if (maxRowTasks?.length < day.tasks.length) {\r\n <button fd-button (click)=\"onMoreButton($event, popover)\" [fdType]=\"'transparent'\" [compact]=\"true\">\r\n {{ day.tasks?.length - maxRowTasks?.length }}\r\n {{ 'More' | bbbTranslate }}\r\n </button>\r\n <fd-popover\r\n #popover\r\n [mobile]=\"deviceSize === 's'\"\r\n placement=\"bottom\"\r\n [focusTrapped]=\"true\"\r\n [focusAutoCapture]=\"true\"\r\n (isOpenChange)=\"onOpenPopoverChange($event)\"\r\n >\r\n <bc-day-event-list\r\n [day]=\"day\"\r\n [calendarFields]=\"calendarFields\"\r\n [deviceSize]=\"deviceSize\"\r\n [weekDays]=\"weekDays\"\r\n [rtl]=\"rtl\"\r\n [canDelete]=\"canDelete\"\r\n [canEdit]=\"canEdit\"\r\n [canView]=\"canView\"\r\n [popover]=\"popover\"\r\n (deleteEvent)=\"deleteEvent.emit($event)\"\r\n (editEvent)=\"editEvent.emit($event)\"\r\n ></bc-day-event-list>\r\n </fd-popover>\r\n }\r\n </td>\r\n }\r\n </tr>\r\n }\r\n </tbody>\r\n </table>\r\n</ng-template>\r\n\r\n<ng-template\r\n #renderDayTasks\r\n let-weekTasks\r\n let-maxRowTasks=\"maxRowTasks\"\r\n let-weekIndex=\"weekIndex\"\r\n let-deviceSize=\"deviceSize\"\r\n let-calendarFields=\"calendarFields\"\r\n let-weekDays=\"weekDays\"\r\n>\r\n @for (rowTask of maxRowTasks; track rowTask; let i = $index) {\r\n <tr fd-table-row>\r\n @if (!weekTasks[i] || weekTasks[i].length === 0) { @for (day of weekDays; track day) {\r\n <td fd-table-cell></td>\r\n } } @for (task of weekTasks[i]; track task; let dayIndex = $index) { @if (task.colSpan) {\r\n <td fd-table-cell [attr.colspan]=\"task.colSpan\">\r\n @if (task.event) {\r\n <bc-event-button\r\n [task]=\"task\"\r\n [calendarFields]=\"calendarFields\"\r\n [deviceSize]=\"deviceSize\"\r\n [rtl]=\"rtl\"\r\n [canDelete]=\"canDelete\"\r\n [canEdit]=\"canEdit\"\r\n [canView]=\"canView\"\r\n (deleteEvent)=\"deleteEvent.emit($event)\"\r\n (editEvent)=\"editEvent.emit($event)\"\r\n (openPopoverChange)=\"onOpenPopoverChange($event)\"\r\n ></bc-event-button>\r\n } @else {\r\n <div style=\"width: 100%; height: 100%\" (click)=\"onDaySelect(weekIndex, dayIndex)\"></div>\r\n }\r\n </td>\r\n } }\r\n </tr>\r\n }\r\n</ng-template>\r\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"] }]
194
- }], ctorParameters: () => [{ type: i1.DaysInWeekPipe }, { type: i0.ChangeDetectorRef }, { type: i2.CalendarService }], propDecorators: { monthWeeksCount: [{
195
- type: Input
196
- }], weekDays: [{
197
- type: Input
198
- }], weekDaysMin: [{
199
- type: Input
200
- }], today: [{
201
- type: Input
202
- }], containerHeight: [{
203
- type: Input
204
- }], days: [{
205
- type: Input
206
- }], calendarFields: [{
207
- type: Input
208
- }], rtl: [{
209
- type: Input
210
- }], deviceSize: [{
211
- type: Input
212
- }], moDataList: [{
213
- type: Input
214
- }], datePicker: [{
215
- type: Input
216
- }], rangePicker: [{
217
- type: Input
218
- }], canDelete: [{
219
- type: Input
220
- }], canAdd: [{
221
- type: Input
222
- }], canEdit: [{
223
- type: Input
224
- }], canView: [{
225
- type: Input
226
- }], selectedDate: [{
227
- type: Input
228
- }], startSelectedDayIndex: [{
229
- type: Input
230
- }], endSelectedDayIndex: [{
231
- type: Input
232
- }], editEvent: [{
233
- type: Output
234
- }], deleteEvent: [{
235
- type: Output
236
- }], daySelect: [{
237
- type: Output
238
- }], dayClick: [{
239
- type: Output
240
- }], dayMouseMove: [{
241
- type: Output
242
- }], dayMouseUp: [{
243
- type: Output
244
- }], dayMouseDown: [{
245
- type: Output
246
- }], showEvent: [{
247
- type: Output
248
- }] } });
249
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FsZW5kYXItbW9udGguY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFyc2EtY2FsZW5kYXIvc3JjL2xpYi9jYWxlbmRhci1tb250aC9jYWxlbmRhci1tb250aC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9iYXJzYS1jYWxlbmRhci9zcmMvbGliL2NhbGVuZGFyLW1vbnRoL2NhbGVuZGFyLW1vbnRoLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDSCx1QkFBdUIsRUFFdkIsU0FBUyxFQUNULFlBQVksRUFDWixLQUFLLEVBR0wsTUFBTSxFQUVULE1BQU0sZUFBZSxDQUFDO0FBRXZCLE9BQU8sRUFBRSxhQUFhLEVBQW9FLE1BQU0sc0JBQXNCLENBQUM7Ozs7Ozs7Ozs7Ozs7O0FBYXZILE1BQU0sT0FBTyxzQkFBdUIsU0FBUSxhQUFhO0lBNENyRCxZQUNZLFVBQTBCLEVBQzFCLElBQXVCLEVBQ3ZCLGdCQUFpQztRQUV6QyxLQUFLLEVBQUUsQ0FBQztRQUpBLGVBQVUsR0FBVixVQUFVLENBQWdCO1FBQzFCLFNBQUksR0FBSixJQUFJLENBQW1CO1FBQ3ZCLHFCQUFnQixHQUFoQixnQkFBZ0IsQ0FBaUI7UUFwQ3BDLGVBQVUsR0FBRyxLQUFLLENBQUM7UUFDbkIsZ0JBQVcsR0FBRyxLQUFLLENBQUM7UUFDcEIsY0FBUyxHQUFHLEtBQUssQ0FBQztRQUNsQixXQUFNLEdBQUcsS0FBSyxDQUFDO1FBQ2YsWUFBTyxHQUFHLEtBQUssQ0FBQztRQUNoQixZQUFPLEdBQUcsS0FBSyxDQUFDO1FBSWYsY0FBUyxHQUFHLElBQUksWUFBWSxFQUF1QixDQUFDO1FBQ3BELGdCQUFXLEdBQUcsSUFBSSxZQUFZLEVBQXVCLENBQUM7UUFDdEQsY0FBUyxHQUFHLElBQUksWUFBWSxFQUFPLENBQUM7UUFDcEMsYUFBUSxHQUFHLElBQUksWUFB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dGlvblN0cmF0ZWd5LFxyXG4gICAgQ2hhbmdlRGV0ZWN0b3JSZWYsXHJcbiAgICBDb21wb25lbnQsXHJcbiAgICBFdmVudEVtaXR0ZXIsXHJcbiAgICBJbnB1dCxcclxuICAgIE9uQ2hhbmdlcyxcclxuICAgIE9uSW5pdCxcclxuICAgIE91dHB1dCxcclxuICAgIFNpbXBsZUNoYW5nZXNcclxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbmltcG9ydCB7IEJhc2VDb21wb25lbnQsIENhbGVuZGFyRmllbGRzLCBDYWxlbmRhck1ldGFvYmplY3REYXRhTW9kZWwsIE1ldGFvYmplY3REYXRhTW9kZWwgfSBmcm9tICdiYXJzYS1ub3Zpbi1yYXktY29yZSc7XHJcbmltcG9ydCB7IERheSB9IGZyb20gJy4uL21vZGVscyc7XHJcbmltcG9ydCB7IERheXNJbldlZWtQaXBlIH0gZnJvbSAnLi4vZGF5cy1pbi13ZWVrLnBpcGUnO1xyXG5cclxuaW1wb3J0IHsgQ2FsZW5kYXJTZXJ2aWNlIH0gZnJvbSAnLi4vc2VydmljZXMvY2FsZW5kYXIuc2VydmljZSc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICAgIHNlbGVjdG9yOiAnYmMtY2FsZW5kYXItbW9udGgnLFxyXG4gICAgdGVtcGxhdGVVcmw6ICcuL2NhbGVuZGFyLW1vbnRoLmNvbXBvbmVudC5odG1sJyxcclxuICAgIHN0eWxlVXJsczogWycuL2NhbGVuZGFyLW1vbnRoLmNvbXBvbmVudC5zY3NzJ10sXHJcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcclxuICAgIHN0YW5kYWxvbmU6IGZhbHNlXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBDYWxlbmRhck1vbnRoQ29tcG9uZW50IGV4dGVuZHMgQmFzZUNvbXBvbmVudCBpbXBsZW1lbnRzIE9uQ2hhbmdlcywgT25Jbml0IHtcclxuICAgIEBJbnB1dCgpIG1vbnRoV2Vla3NDb3VudDogbnVtYmVyO1xyXG4gICAgQElucHV0KCkgd2Vla0RheXM6IHN0cmluZ1tdO1xyXG4gICAgQElucHV0KCkgd2Vla0RheXNNaW46IHN0cmluZ1tdO1xyXG4gICAgQElucHV0KCkgdG9kYXk6IERhdGU7XHJcbiAgICBASW5wdXQoKSBjb250YWluZXJIZWlnaHQ6IG51bWJlcjtcclxuICAgIEBJbnB1dCgpIGRheXM6IERheVtdO1xyXG4gICAgQElucHV0KCkgY2FsZW5kYXJGaWVsZHM6IENhbGVuZGFyRmllbGRzO1xyXG4gICAgQElucHV0KCkgcnRsOiBib29sZWFuO1xyXG4gICAgQElucHV0KCkgZGV2aWNlU2l6ZTogc3RyaW5nO1xyXG4gICAgQElucHV0KCkgbW9EYXRhTGlzdDogTWV0YW9iamVjdERhdGFNb2RlbFtdO1xyXG4gICAgQElucHV0KCkgZGF0ZVBpY2tlciA9IGZhbHNlO1xyXG4gICAgQElucHV0KCkgcmFuZ2VQaWNrZXIgPSBmYWxzZTtcclxuICAgIEBJbnB1dCgpIGNhbkRlbGV0ZSA9IGZhbHNlO1xyXG4gICAgQElucHV0KCkgY2FuQWRkID0gZmFsc2U7XHJcbiAgICBASW5wdXQoKSBjYW5FZGl0ID0gZmFsc2U7XHJcbiAgICBASW5wdXQoKSBjYW5WaWV3ID0gZmFsc2U7XHJcbiAgICBASW5wdXQoKSBzZWxlY3RlZERhdGU6IERhdGUgfCB1bmRlZmluZWQ7XHJcbiAgICBASW5wdXQoKSBzdGFydFNlbGVjdGVkRGF5SW5kZXg6IG51bWJlciB8IHVuZGVmaW5lZDtcclxuICAgIEBJbnB1dCgpIGVuZFNlbGVjdGVkRGF5SW5kZXg6IG51bWJlciB8IHVuZGVmaW5lZDtcclxuICAgIEBPdXRwdXQoKSBlZGl0RXZlbnQgPSBuZXcgRXZlbnRFbWl0dGVyPE1ldGFvYmplY3REYXRhTW9kZWw+KCk7XHJcbiAgICBAT3V0cHV0KCkgZGVsZXRlRXZlbnQgPSBuZXcgRXZlbnRFbWl0dGVyPE1ldGFvYmplY3REYXRhTW9kZWw+KCk7XHJcbiAgICBAT3V0cHV0KCkgZGF5U2VsZWN0ID0gbmV3IEV2ZW50RW1pdHRlcjxhbnk+KCk7XHJcbiAgICBAT3V0cHV0KCkgZGF5Q2xpY2sgPSBuZXcgRXZlbnRFbWl0dGVyPERheT4oKTtcclxuICAgIEBPdXRwdXQoKSBkYXlNb3VzZU1vdmUgPSBuZXcgRXZlbnRFbWl0dGVyPERheT4oKTtcclxuICAgIEBPdXRwdXQoKSBkYXlNb3VzZVVwID0gbmV3IEV2ZW50RW1pdHRlcjxEYXk+KCk7XHJcbiAgICBAT3V0cHV0KCkgZGF5TW91c2VEb3duID0gbmV3IEV2ZW50RW1pdHRlcjxEYXk+KCk7XHJcbiAgICBAT3V0cHV0KCkgc2hvd0V2ZW50ID0gbmV3IEV2ZW50RW1pdHRlcjxDYWxlbmRhck1ldGFvYmplY3REYXRhTW9kZWw+KCk7XHJcblxyXG4gICAgZGVmYXVsdFdlZWtzQ291bnREOiBudW1iZXI7XHJcbiAgICBkZWZhdWx0Rmlyc3RXZWVrSW5kZXg6IG51bWJlcjtcclxuICAgIHNlbGVjdGVkV2Vla0RheXM6IHN0cmluZ1tdO1xyXG4gICAgc2VsZWN0ZWQ6IERheTtcclxuICAgIG51bWJlck9mV2VlazogbnVtYmVyW107XHJcbiAgICBkYXlIZWlnaHQ6IG51bWJlcjtcclxuICAgIHRhc2tIZWlnaHQgPSAzMDtcclxuICAgIG1heFRhc2tDb3VudDogbnVtYmVyO1xyXG4gICAgbWF4Um93VGFza3M6IG51bWJlcltdO1xyXG4gICAgd2Vla1Rhc2tzQXJyYXk6IGFueTtcclxuICAgIGV4dHJhUm93OiBudW1iZXJbXTtcclxuICAgIGlzUGlja2VyTW9kZTogYm9vbGVhbjtcclxuXHJcbiAgICBwcml2YXRlIF9oYXNQb3BvdmVyT3BlbmVkOiBib29sZWFuW10gPSBbXTtcclxuXHJcbiAgICBjb25zdHJ1Y3RvcihcclxuICAgICAgICBwcml2YXRlIGRheXNJbldlZWs6IERheXNJbldlZWtQaXBlLFxyXG4gICAgICAgIHByaXZhdGUgX2NkcjogQ2hhbmdlRGV0ZWN0b3JSZWYsXHJcbiAgICAgICAgcHJpdmF0ZSBfY2FsZW5kYXJTZXJ2aWNlOiBDYWxlbmRhclNlcnZpY2VcclxuICAgICkge1xyXG4gICAgICAgIHN1cGVyKCk7XHJcbiAgICB9XHJcbiAgICBuZ09uQ2hhbmdlcyhjaGFuZ2VzOiBTaW1wbGVDaGFuZ2VzKTogdm9pZCB7XHJcbiAgICAgICAgc3VwZXIubmdPbkNoYW5nZXMoY2hhbmdlcyk7XHJcbiAgICAgICAgbGV0IG5lZWRUb0RldGVjdENoYW5nZSA9IGZhbHNlO1xyXG4gICAgICAgIGNvbnN0IHtcclxuICAgICAgICAgICAgY29udGFpbmVySGVpZ2h0LFxyXG4gICAgICAgICAgICBkZXZpY2VTaXplLFxyXG4gICAgICAgICAgICBtb0RhdGFMaXN0LFxyXG4gICAgICAgICAgICBkYXlzLFxyXG4gICAgICAgICAgICBtb250aFdlZWtzQ291bnQsXHJcbiAgICAgICAgICAgIHN0YXJ0U2VsZWN0ZWREYXlJbmRleCxcclxuICAgICAgICAgICAgZW5kU2VsZWN0ZWREYXlJbmRleFxyXG4gICAgICAgIH0gPSBjaGFuZ2VzO1xyXG4gICAgICAgIGlmIChjb250YWluZXJIZWlnaHQgJiYgIWNvbnRhaW5lckhlaWdodC5maXJzdENoYW5nZSkge1xyXG4gICAgICAgICAgICB0aGlzLmZpdFRvQ29udGFpbmVyKGNoYW5nZXMuY29udGFpbmVySGVpZ2h0LmN1cnJlbnRWYWx1ZSk7XHJcbiAgICAgICAgfVxyXG4gICAgICAgIGlmIChkZXZpY2VTaXplICYmICFkZXZpY2VTaXplLmZpcnN0Q2hhbmdlKSB7XHJcbiAgICAgICAgICAgIHRoaXMucHJlcGFyZVdlZWtEYXlzKGNoYW5nZXMuZGV2aWNlU2l6ZS5jdXJyZW50VmFsdWUpO1xyXG4gICAgICAgIH1cclxuICAgICAgICBpZiAobW9EYXRhTGlzdCAmJiAhbW9EYXRhTGlzdC5maXJzdENoYW5nZSkge1xyXG4gICAgICAgICAgICB0aGlzLl9wcmVwYXJlRGF5c1Rhc2tzKGNoYW5nZXMubW9EYXRhTGlzdC5jdXJyZW50VmFsdWUpO1xyXG4gICAgICAgICAgICBuZWVkVG9EZXRlY3RDaGFuZ2UgPSB0cnVlO1xyXG4gICAgICAgIH1cclxuICAgICAgICBpZiAoZGF5cyAmJiAhZGF5cy5maXJzdENoYW5nZSkge1xyXG4gICAgICAgICAgICB0aGlzLmZpdFRvQ29udGFpbmVyKHRoaXMuY29udGFpbmVySGVpZ2h0KTtcclxuICAgICAgICAgICAgdGhpcy5fcHJlcGFyZURheXNUYXNrcyh0aGlzLm1vRGF0YUxpc3QpO1xyXG4gICAgICAgICAgICBuZWVkVG9EZXRlY3RDaGFuZ2UgPSB0cnVlO1xyXG4gICAgICAgIH1cclxuICAgICAgICBpZiAobW9udGhXZWVrc0NvdW50ICYmICFtb250aFdlZWtzQ291bnQuZmlyc3RDaGFuZ2UpIHtcclxuICAgICAgICAgICAgdGhpcy5maXRUb0NvbnRhaW5lcih0aGlzLmNvbnRhaW5lckhlaWdodCk7XHJcbiAgICAgICAgICAgIHRoaXMuX3ByZXBhcmVEYXlzVGFza3ModGhpcy5tb0RhdGFMaXN0KTtcclxuICAgICAgICAgICAgbmVlZFRvRGV0ZWN0Q2hhbmdlID0gdHJ1ZTtcclxuICAgICAgICB9XHJcbiAgICAgICAgaWYgKFxyXG4gICAgICAgICAgICAoc3RhcnRTZWxlY3RlZERheUluZGV4ICYmICFzdGFydFNlbGVjdGVkRGF5SW5kZXguZmlyc3RDaGFuZ2UpIHx8XHJcbiAgICAgICAgICAgIChlbmRTZWxlY3RlZERheUluZGV4ICYmICFlbmRTZWxlY3RlZERheUluZGV4LmZpcnN0Q2hhbmdlKVxyXG4gICAgICAgICkge1xyXG4gICAgICAgICAgICBuZWVkVG9EZXRlY3RDaGFuZ2UgPSB0cnVlO1xyXG4gICAgICAgIH1cclxuICAgICAgICBpZiAobmVlZFRvRGV0ZWN0Q2hhbmdlKSB7XHJcbiAgICAgICAgICAgIHRoaXMuX2Nkci5kZXRlY3RDaGFuZ2VzKCk7XHJcbiAgICAgICAgfVxyXG4gICAgfVxyXG5cclxuICAgIG5nT25Jbml0KCk6IHZvaWQge1xyXG4gICAgICAgIHN1cGVyLm5nT25Jbml0KCk7XHJcbiAgICAgICAgdGhpcy5pc1BpY2tlck1vZGUgPSB0aGlzLmRhdGVQaWNrZXIgfHwgdGhpcy5yYW5nZVBpY2tlcjtcclxuICAgICAgICB0aGlzLnByZXBhcmVXZWVrRGF5cyh0aGlzLmRldmljZVNpemUpO1xyXG4gICAgICAgIHRoaXMuX3ByZXBhcmVEYXlzVGFza3ModGhpcy5tb0RhdGFMaXN0KTtcclxuICAgICAgICB0aGlzLmZpdFRvQ29udGFpbmVyKHRoaXMuY29udGFpbmVySGVpZ2h0KTtcclxuICAgIH1cclxuXHJcbiAgICBvbkRheUJveFNlbGVjdChkYXk6IERheSk6IHZvaWQge1xyXG4gICAgICAgIHRoaXMuX2ZpcmVEYXlTZWxlY3QoZGF5KTtcclxuICAgIH1cclxuICAgIG9uRGF5U2VsZWN0KHdlZWtJbmRleDogbnVtYmVyLCBkYXlJbmRleDogbnVtYmVyKTogdm9pZCB7XHJcbiAgICAgICAgaWYgKCF0aGlzLmNhbkFkZCkge1xyXG4gICAgICAgICAgICByZXR1cm47XHJcbiAgICAgICAgfVxyXG4gICAgICAgIGNvbnN0IGRheSA9IHRoaXMuZGF5c1t3ZWVrSW5kZXggKiA3ICsgZGF5SW5kZXhdO1xyXG4gICAgICAgIHRoaXMuX2ZpcmVEYXlTZWxlY3QoZGF5KTtcclxuICAgIH1cclxuXHJcbiAgICBvbk9wZW5Qb3BvdmVyQ2hhbmdlKGlzT3BlbjogYm9vbGVhbik6IHZvaWQge1xyXG4gICAgICAgIHRoaXMuX29wZW5Qb3BvdmVyKGlzT3Blbik7XHJcbiAgICB9XHJcbiAgICBvbk1vcmVCdXR0b24oZSwgcG9wb3Zlcik6IHZvaWQge1xyXG4gICAgICAgIHRoaXMuX3ByZXZlbnRFdmVudChlKTtcclxuICAgICAgICBwb3BvdmVyLm9wZW4oKTtcclxuICAgIH1cclxuICAgIG9uVGFzayhlLCB0YXNrOiBDYWxlbmRhck1ldGFvYmplY3REYXRhTW9kZWwpOiB2b2lkIHtcclxuICAgICAgICB0aGlzLnNob3dFdmVudC5lbWl0KHRhc2spO1xyXG4gICAgfVxyXG4gICAgb25EYXlDbGljayhkYXk6IERheSk6IHZvaWQge1xyXG4gICAgICAgIHRoaXMuc2VsZWN0ZWQgPSBkYXk7XHJcbiAgICAgICAgdGhpcy5kYXlDbGljay5lbWl0KGRheSk7XHJcbiAgICB9XHJcbiAgICBvbkRheU1vdXNlTW92ZShkYXk6IERheSk6IHZvaWQge1xyXG4gICAgICAgIHRoaXMuZGF5TW91c2VNb3ZlLmVtaXQoZGF5KTtcclxuICAgIH1cclxuICAgIG9uRGF5TW91c2VEb3duKGRheTogRGF5KTogdm9pZCB7XHJcbiAgICAgICAgdGhpcy5kYXlNb3VzZURvd24uZW1pdChkYXkpO1xyXG4gICAgfVxyXG4gICAgb25EYXlNb3VzZVVwKGRheTogRGF5KTogdm9pZCB7XHJcbiAgICAgICAgdGhpcy5kYXlNb3VzZVVwLmVtaXQoZGF5KTtcclxuICAgIH1cclxuICAgIHByaXZhdGUgX3ByZXZlbnRFdmVudChlKTogdm9pZCB7XHJcbiAgICAgICAgZS5zdG9wUHJvcGFnYXRpb24oKTtcclxuICAgICAgICBlLnByZXZlbnREZWZhdWx0KCk7XHJcbiAgICB9XHJcbiAgICBwcml2YXRlIF9maXJlRGF5U2VsZWN0KGRheTogRGF5KTogdm9pZCB7XHJcbiAgICAgICAgaWYgKHRoaXMuX2hhc1BvcG92ZXJPcGVuZWQubGVuZ3RoID09PSAwKSB7XHJcbiAgICAgICAgICAgIHRoaXMuZGF5U2VsZWN0LmVtaXQoe1xyXG4gICAgICAgICAgICAgICAgZGF0ZTogZGF5LmRhdGVcclxuICAgICAgICAgICAgfSk7XHJcbiAgICAgICAgfVxyXG4gICAgfVxyXG4gICAgcHJpdmF0ZSBfb3BlblBvcG92ZXIoaXNPcGVuOiBib29sZWFuKTogdm9pZCB7XHJcbiAgICAgICAgaWYgKGlzT3Blbikge1xyXG4gICAgICAgICAgICB0aGlzLl9oYXNQb3BvdmVyT3BlbmVkLnB1c2godHJ1ZSk7XHJcbiAgICAgICAgfSBlbHNlIHtcclxuICAgICAgICAgICAgc2V0VGltZW91dCgoKSA9PiB7XHJcbiAgICAgICAgICAgICAgICB0aGlzLl9oYXNQb3BvdmVyT3BlbmVkID0gW107XHJcbiAgICAgICAgICAgIH0sIDApO1xyXG4gICAgICAgIH1cclxuICAgIH1cclxuICAgIHByaXZhdGUgcHJlcGFyZVdlZWtEYXlzKGRldmljZVNpemU6IHN0cmluZyk6IHZvaWQge1xyXG4gICAgICAgIGlmIChkZXZpY2VTaXplICE9PSAncycgJiYgZGV2aWNlU2l6ZSAhPT0gJ20nKSB7XHJcbiAgICAgICAgICAgIHRoaXMuc2VsZWN0ZWRXZWVrRGF5cyA9IHRoaXMud2Vla0RheXM7XHJcbiAgICAgICAgfSBlbHNlIHtcclxuICAgICAgICAgICAgdGhpcy5zZWxlY3RlZFdlZWtEYXlzID0gdGhpcy53ZWVrRGF5c01pbjtcclxuICAgICAgICB9XHJcbiAgICB9XHJcbiAgICBwcml2YXRlIGZpdFRvQ29udGFpbmVyKGNvbnRhaW5lckhlaWdodCk6IHZvaWQge1xyXG4gICAgICAgIGxldCBfd2Vla3NDb3VudDtcclxuXHJcbiAgICAgICAgaWYgKHRoaXMubW9udGhXZWVrc0NvdW50ID4gMCkge1xyXG4gICAgICAgICAgICBjb25zdCB3ZWVrc0NvdW50ID0gdGhpcy5tb250aFdlZWtzQ291bnQ7XHJcbiAgICAgICAgICAgIF93ZWVrc0NvdW50ID0gd2Vla3NDb3VudDtcclxuICAgICAgICB9IGVsc2Uge1xyXG4gICAgICAgICAgICBfd2Vla3NDb3VudCA9IHRoaXMuZGF5cy5sZW5ndGggLyA3O1xyXG4gICAgICAgIH1cclxuICAgICAgICB0aGlzLm51bWJlck9mV2VlayA9IEFycmF5LmZyb20oQXJyYXkoX3dlZWtzQ291bnQpLmtleXMoKSk7XHJcbiAgICAgICAgdGhpcy5udW1iZXJPZldlZWsgPSB0aGlzLm51bWJlck9mV2Vlay5tYXAoKHZhbHVlKSA9PiB2YWx1ZSk7XHJcbiAgICAgICAgaWYgKHRoaXMuaXNQaWNrZXJNb2RlKSB7XHJcbiAgICAgICAgICAgIHRoaXMuZGF5SGVpZ2h0ID0gNDA7XHJcbiAgICAgICAgICAgIHJldHVybjtcclxuICAgICAgICB9XHJcbiAgICAgICAgdGhpcy5kYXlIZWlnaHQgPSBNYXRoLmZsb29yKGNvbnRhaW5lckhlaWdodCAvIChfd2Vla3NDb3VudCArIDEpKTtcclxuXHJcbiAgICAgICAgdGhpcy5tYXhUYXNrQ291bnQgPSBNYXRoLmZsb29yKCh0aGlzLmRheUhlaWdodCAtIHRoaXMudGFza0hlaWdodCkgLyB0aGlzLnRhc2tIZWlnaHQpO1xyXG4gICAgICAgIGlmICh0aGlzLm1heFRhc2tDb3VudCA+IDApIHtcclxuICAgICAgICAgICAgdGhpcy5tYXhSb3dUYXNrcyA9IG5ldyBBcnJheSh0aGlzLm1heFRhc2tDb3VudCkuZmlsbCgwKS5tYXAoKHgsIGkpID0+IGkpO1xyXG4gICAgICAgIH1cclxuICAgIH1cclxuICAgIHByaXZhdGUgX3ByZXBhcmVEYXlzVGFza3MoY2FsZW5kYXJUYXNrcyk6IHZvaWQge1xyXG4gICAgICAgIGlmICh0aGlzLmlzUGlja2VyTW9kZSkge1xyXG4gICAgICAgICAgICB0aGlzLndlZWtUYXNrc0FycmF5ID0ge307XHJcbiAgICAgICAgICAgIHJldHVybjtcclxuICAgICAgICB9XHJcblxyXG4gICAgICAgIGNvbnN0IGNhbGVuZGFyRmllbGRzID0gdGhpcy5jYWxlbmRhckZpZWxkcztcclxuXHJcbiAgICAgICAgLy8gU29ydCBhbGwgVGFza3NcclxuICAgICAgICBjb25zdCBtb0RhdGFMaXN0ID0gdGhpcy5fY2FsZW5kYXJTZXJ2aWNlLnNvcnRUYXNrcyhjYWxlbmRhclRhc2tzLCBjYWxlbmRhckZpZWxkcyk7XHJcbiAgICAgICAgdGhpcy5kYXlzLmZvckVhY2goKGRheSkgPT4gKGRheS50YXNrcyA9IFtdKSk7XHJcbiAgICAgICAgY29uc3Qgd2Vla1Rhc2tzQXJyYXk6IGFueSA9IFtdO1xyXG4gICAgICAgIGZvciAobGV0IGogPSAwOyBqIDwgdGhpcy5kYXlzLmxlbmd0aCAvIDc7IGorKykge1xyXG4gICAgICAgICAgICBjb25zdCBkYXlzID0gdGhpcy5kYXlzSW5XZWVrLnRyYW5zZm9ybSh0aGlzLmRheXMsIGopO1xyXG4gICAgICAgICAgICBjb25zdCB3ZWVrID0gdGhpcy5fY2FsZW5kYXJTZXJ2aWNlLmNyZWF0ZVdlZWtUYXNrKGRheXMsIG1vRGF0YUxpc3QsIGNhbGVuZGFyRmllbGRzLCAwKTtcclxuICAgICAgICAgICAgd2Vla1Rhc2tzQXJyYXkucHVzaCh3ZWVrKTtcclxuICAgICAgICB9XHJcblxyXG4gICAgICAgIHdlZWtUYXNrc0FycmF5LmZvckVhY2goKHdlZWspID0+IHtcclxuICAgICAgICAgICAgY29uc3QgYXJyOiBhbnlbXSA9IE9iamVjdC52YWx1ZXMod2Vlayk7XHJcbiAgICAgICAgICAgIGZvciAobGV0IGkgPSBhcnIubGVuZ3RoOyBpIDwgdGhpcy5tYXhUYXNrQ291bnQ7IGkrKykge1xyXG4gICAgICAgICAgICAgICAgd2Vla1tpLnRvU3RyaW5nKCldID0gW107XHJcbiAgICAgICAgICAgIH1cclxuICAgICAgICB9KTtcclxuICAgICAgICAvLyDYqNmHINin2LLYp9uMINmH2LEg2LHYr9uM2YEg2KrYs9qpINio2KfbjNivINiq2LnYr9in2K8gNyDYs9iq2YjZhiDYp9i22KfZgdmHINqv2LHYr9ivINmIINio2LHYp9uMINiz2KrZiNmG24wg2qnZhyDYqtiz2qnbjCDZhtiv2KfYsdivINuM2qkg2KzYp9uMINiu2KfZhNuMIGNvbHNwYW4gMSDZhduM2q/YsNin2LHbjNmFXHJcbiAgICAgICAgd2Vla1Rhc2tzQXJyYXkuZm9yRWFjaCgod2VlaykgPT4ge1xyXG4gICAgICAgICAgICB0aGlzLl9jYWxlbmRhclNlcnZpY2UuZmlsbFdlZWsod2Vlayk7XHJcbiAgICAgICAgfSk7XHJcbiAgICAgICAgdGhpcy53ZWVrVGFza3NBcnJheSA9IHdlZWtUYXNrc0FycmF5O1xyXG4gICAgfVxyXG59XHJcbiIsIjx0YWJsZSBmZC10YWJsZSBjbGFzcz1cInRhYmxlLWhlYWRlclwiIFtmZENvbXBhY3RdIFthdHRyLnBpY2tlcl09XCJkYXRlUGlja2VyXCI+XHJcbiAgICA8dGhlYWQgZmQtdGFibGUtaGVhZGVyPlxyXG4gICAgICAgIDx0ciBmZC10YWJsZS1yb3c+XHJcbiAgICAgICAgICAgIEBmb3IgKHdlZWtEYXkgb2Ygc2VsZWN0ZWRXZWVrRGF5czsgdHJhY2sgd2Vla0RheSkge1xyXG4gICAgICAgICAgICA8dGggY2xhc3M9XCJ3ZWVrZGF5LWhlYWRlclwiIGZkLXRhYmxlLWNlbGwgW2NsYXNzLm5vYm9yZGVyXT1cImlzUGlja2VyTW9kZVwiPlxyXG4gICAgICAgICAgICAgICAge3sgd2Vla0RheSB8IHNsaWNlOiAwOjEgfX1cclxuICAgICAgICAgICAgPC90aD5cclxuICAgICAgICAgICAgfVxyXG4gICAgICAgIDwvdHI+XHJcbiAgICA8L3RoZWFkPlxyXG4gICAgPHRib2R5IGZkLXRhYmxlLWJvZHk+XHJcbiAgICAgICAgQGZvciAod2Vla0RheSBvZiBudW1iZXJPZldlZWs7IHRyYWNrIHdlZWtEYXkpIHtcclxuICAgICAgICA8dHIgZmQtdGFibGUtcm93PlxyXG4gICAgICAgICAgICA8dGQgW3N0eWxlLmhlaWdodC5weF09XCJkYXlIZWlnaHRcIiBmZC10YWJsZS1jZWxsIGNvbHNwYW49XCI3XCIgW3N0eWxlLmJvcmRlcl09XCJpc1BpY2tlck1vZGUgPyAnbm9uZScgOiBudWxsXCI+XHJcbiAgICAgICAgICAgICAgICA8bmctY29udGFpbmVyXHJcbiAgICAgICAgICAgICAgICAgICAgKm5nVGVtcGxhdGVPdXRsZXQ9XCJcclxuICAgICAgICAgICAgICAgICAgICAgICAgcmVuZGVyVGFza3M7XHJcbiAgICAgICAgICAgICAgICAgICAgICAgIGNvbnRleHQ6IHtcclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICRpbXBsaWNpdDogaXNQaWNrZXJNb2RlID8gbnVsbCA6IG1vRGF0YUxpc3Rbd2Vla0RheV0sXHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICB3ZWVrSW5kZXg6IHdlZWtEYXksXHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBkYXlzOiBkYXlzIHwgZGF5c0luV2Vlazogd2Vla0RheSxcclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIG1heFJvd1Rhc2tzOiBtYXhSb3dUYXNrcyxcclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIHdlZWtEYXlzOiB3ZWVrRGF5cyxcclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIGNhbGVuZGFyRmllbGRzOiBjYWxlbmRhckZpZWxkcyxcclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIGRldmljZVNpemU6IGRldmljZVNpemUsXHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBydGw6IHJ0bCxcclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlzUGlja2VyTW9kZTogaXNQaWNrZXJNb2RlXHJcbiAgICAgICAgICAgICAgICAgICAgICAgIH1cclxuICAgICAgICAgICAgICAgICAgICBcIlxyXG4gICAgICAgICAgICAgICAgPjwvbmctY29udGFpbmVyPlxyXG4gICAgICAgICAgICA8L3RkPlxyXG4gICAgICAgIDwvdHI+XHJcbiAgICAgICAgfVxyXG4gICAgPC90Ym9keT5cclxuPC90YWJsZT5cclxuPG5nLXRlbXBsYXRlXHJcbiAgICAjcmVuZGVyVGFza3NcclxuICAgIGxldC10YXNrXHJcbiAgICBsZXQtd2Vla0luZGV4PVwid2Vla0luZGV4XCJcclxuICAgIGxldC13ZWVrRGF5cz1cIndlZWtEYXlzXCJcclxuICAgIGxldC1kYXlzPVwiZGF5c1wiXHJcbiAgICBsZXQtbWF4Um93VGFza3M9XCJtYXhSb3dUYXNrc1wiXHJcbiAgICBsZXQtY2FsZW5kYXJGaWVsZHM9XCJjYWxlbmRhckZpZWxkc1wiXHJcbiAgICBsZXQtZGV2aWNlU2l6ZT1cImRldmljZVNpemVcIlxyXG4gICAgbGV0LXJ0bD1cInJ0bFwiXHJcbiAgICBsZXQtaXNQaWNrZXJNb2RlPVwiaXNQaWNrZXJNb2RlXCJcclxuPlxyXG4gICAgPHRhYmxlIGZkLXRhYmxlLWJvZHkgY2xhc3M9XCJ0YWJsZS1jb250ZW50XCIgW2NvbXBhY3RdPVwidHJ1ZVwiPlxyXG4gICAgICAgIDx0Ym9keT5cclxuICAgICAgICAgICAgPHRyIGZkLXRhYmxlLXJvdyBjbGFzcz1cInJvdy1kYXktbnVtYmVyXCIgW2F0dHIucnRsXT1cInJ0bFwiPlxyXG4gICAgICAgICAgICAgICAgQGZvciAoZGF5IG9mIGRheXM7IHRyYWNrIGRheSkge1xyXG4gICAgICAgICAgICAgICAgPHRkIGZkLXRhYmxlLWNlbGwgW2NsYXNzLm5vYm9yZGVyXT1cImlzUGlja2VyTW9kZVwiPlxyXG4gICAgICAgICAgICAgICAgICAgIDxiYy1kYXktbnVtYmVyLWJveFxyXG4gICAgICAgICAgICAgICAgICAgICAgICBbbmdDbGFzc109XCJ7XHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAnZmQtY2FsZW5kYXJfX2l0ZW0nOiBpc1BpY2tlck1vZGUsXHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAnIXR3LWJvcmRlciAhdHctcm91bmRlZC1tZCB0dy10cmFuc2l0aW9uLWFsbCB0dy1jdXJzb3ItcG9pbnRlcic6XHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaXNQaWNrZXJNb2RlICYmIGRheS5pc0luTW9udGgsXHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAnIXR3LWJnLXRyYW5zcGFyZW50IHR3LWJvcmRlci1ncmF5LTEwMCBob3ZlcjohdHctYm9yZGVyLWdyYXktMzAwJzpcclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpc1BpY2tlck1vZGUgJiYgZGF5LmlzSW5Nb250aCAmJiAhZGF5LmlzVG9kYXksXHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAnZmQtY2FsZW5kYXJfX2l0ZW0tLW90aGVyLW1vbnRoJzogaXNQaWNrZXJNb2RlICYmICFkYXkuaXNJbk1vbnRoLFxyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgJ2ZkLWNhbGVuZGFyX19pdGVtLS13ZWVrZW5kJzogaXNQaWNrZXJNb2RlICYmIGRheS5pc1dlZWtlbmQsXHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAnIXR3LWJnLWJsdWUtNTAwIGhvdmVyOiF0dy1iZy1ibHVlLTYwMCc6IGRheS5pc1RvZGF5XHJcbiAgICAgICAgICAgICAgICAgICAgICAgIH1cIlxyXG4gICAgICAgICAgICAgICAgICAgICAgICBbaXNQaWNrZXJNb2RlXT1cImlzUGlja2VyTW9kZVwiXHJcbiAgICAgICAgICAgICAgICAgICAgICAgIFtkYXldPVwiZGF5XCJcclxuICAgICAgICAgICAgICAgICAgICAgICAgW2lzQWN0aXZlXT1cIlxyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgZGF5LmluZGV4ID09PSBzdGFydFNlbGVjdGVkRGF5SW5kZXggfHwgZGF5LmluZGV4ID09PSBlbmRTZWxlY3RlZERheUluZGV4IHx8IGRheS5kYXRlXHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgfCBlcXVhbERhdGU6IHNlbGVjdGVkRGF0ZVxyXG4gICAgICAgICAgICAgICAgICAgICAgICBcIlxyXG4gICAgICAgICAgICAgICAgICAgICAgICBbaXRlbUluUmFuZ2VdPVwiXHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBzdGFydFNlbGVjdGVkRGF5SW5kZXggIT09IHVuZGVmaW5lZCAmJlxyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgZW5kU2VsZWN0ZWREYXlJbmRleCAhPT0gdW5kZWZpbmVkICYmXHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBkYXkuaW5kZXggPj0gc3RhcnRTZWxlY3RlZERheUluZGV4ICYmXHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBkYXkuaW5kZXggPD0gZW5kU2VsZWN0ZWREYXlJbmRleFxyXG4gICAgICAgICAgICAgICAgICAgICAgICBcIlxyXG4gICAgICAgICAgICAgICAgICAgICAgICAoZGF5Q2xpY2spPVwib25EYXlDbGljayhkYXkpXCJcclxuICAgICAgICAgICAgICAgICAgICAgICAgKGRheU1vdXNlTW92ZSk9XCJvbkRheU1vdXNlTW92ZShkYXkpXCJcclxuICAgICAgICAgICAgICAgICAgICAgICAgKGRheU1vdXNlRG93bik9XCJvbkRheU1vdXNlRG93bihkYXkpXCJcclxuICAgICAgICAgICAgICAgICAgICAgICAgKGRheU1vdXNlVXApPVwib25EYXlNb3VzZVVwKGRheSlcIlxyXG4gICAgICAgICAgICAgICAgICAgID48L2JjLWRheS1udW1iZXItYm94PlxyXG4gICAgICAgICAgICAgICAgPC90ZD5cclxuICAgICAgICAgICAgICAgIH1cclxuICAgICAgICAgICAgPC90cj5cclxuICAgICAgICAgICAgQGlmICghaXNQaWNrZXJNb2RlKSB7XHJcbiAgICAgICAgICAgIDxuZy1jb250YWluZXJcclxuICAgICAgICAgICAgICAgICpuZ1RlbXBsYXRlT3V0bGV0PVwiXHJcbiAgICAgICAgICAgICAgICAgICAgcmVuZGVyRGF5VGFza3M7XHJcbiAgICAgICAgICAgICAgICAgICAgY29udGV4dDoge1xyXG4gICAgICAgICAgICAgICAgICAgICAgICAkaW1wbGljaXQ6IHdlZWtUYXNrc0FycmF5W3dlZWtJbmRleF0sXHJcbiAgICAgICAgICAgICAgICAgICAgICAgIG1heFJvd1Rhc2tzOiBtYXhSb3dUYXNrcyxcclxuICAgICAgICAgICAgICAgICAgICAgICAgd2Vla0luZGV4OiB3ZWVrSW5kZXgsXHJcbiAgICAgICAgICAgICAgICAgICAgICAgIGRldmljZVNpemU6IGRldmljZVNpemUsXHJcbiAgICAgICAgICAgICAgICAgICAgICAgIGNhbGVuZGFyRmllbGRzOiBjYWxlbmRhckZpZWxkcyxcclxuICAgICAgICAgICAgICAgICAgICAgICAgd2Vla0RheXM6IHdlZWtEYXlzXHJcbiAgICAgICAgICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICAgICAgXCJcclxuICAgICAgICAgICAgPjwvbmctY29udGFpbmVyPlxyXG4gICAgICAgICAgICA8dHIgZmQtdGFibGUtcm93PlxyXG4gICAgICAgICAgICAgICAgQGZvciAoZGF5IG9mIGRheXM7IHRyYWNrIGRheSkge1xyXG4gICAgICAgICAgICAgICAgPHRkIGZkLXRhYmxlLWNlbGwgY2xhc3M9XCJtb3JlLWZkXCIgKGNsaWNrKT1cIm9uRGF5Qm94U2VsZWN0KGRheSlcIj5cclxuICAgICAgICAgICAgICAgICAgICBAaWYgKG1heFJvd1Rhc2tzPy5sZW5ndGggPCBkYXkudGFza3MubGVuZ3RoKSB7XHJcbiAgICAgICAgICAgICAgICAgICAgPGJ1dHRvbiBmZC1idXR0b24gKGNsaWNrKT1cIm9uTW9yZUJ1dHRvbigkZXZlbnQsIHBvcG92ZXIpXCIgW2ZkVHlwZV09XCIndHJhbnNwYXJlbnQnXCIgW2NvbXBhY3RdPVwidHJ1ZVwiPlxyXG4gICAgICAgICAgICAgICAgICAgICAgICB7eyBkYXkudGFza3M/Lmxlbmd0aCAtIG1heFJvd1Rhc2tzPy5sZW5ndGggfX1cclxuICAgICAgICAgICAgICAgICAgICAgICAge3sgJ01vcmUnIHwgYmJiVHJhbnNsYXRlIH19XHJcbiAgICAgICAgICAgICAgICAgICAgPC9idXR0b24+XHJcbiAgICAgICAgICAgICAgICAgICAgPGZkLXBvcG92ZXJcclxuICAgICAgICAgICAgICAgICAgICAgICAgI3BvcG92ZXJcclxuICAgICAgICAgICAgICAgICAgICAgICAgW21vYmlsZV09XCJkZXZpY2VTaXplID09PSAncydcIlxyXG4gICAgICAgICAgICAgICAgICAgICAgICBwbGFjZW1lbnQ9XCJib3R0b21cIlxyXG4gICAgICAgICAgICAgICAgICAgICAgICBbZm9jdXNUcmFwcGVkXT1cInRydWVcIlxyXG4gICAgICAgICAgICAgICAgICAgICAgICBbZm9jdXNBdXRvQ2FwdHVyZV09XCJ0cnVlXCJcclxuICAgICAgICAgICAgICAgICAgICAgICAgKGlzT3BlbkNoYW5nZSk9XCJvbk9wZW5Qb3BvdmVyQ2hhbmdlKCRldmVudClcIlxyXG4gICAgICAgICAgICAgICAgICAgID5cclxuICAgICAgICAgICAgICAgICAgICAgICAgPGJjLWRheS1ldmVudC1saXN0XHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBbZGF5XT1cImRheVwiXHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBbY2FsZW5kYXJGaWVsZHNdPVwiY2FsZW5kYXJGaWVsZHNcIlxyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgW2RldmljZVNpemVdPVwiZGV2aWNlU2l6ZVwiXHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBbd2Vla0RheXNdPVwid2Vla0RheXNcIlxyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgW3J0bF09XCJydGxcIlxyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgW2NhbkRlbGV0ZV09XCJjYW5EZWxldGVcIlxyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgW2NhbkVkaXRdPVwiY2FuRWRpdFwiXHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBbY2FuVmlld109XCJjYW5WaWV3XCJcclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIFtwb3BvdmVyXT1cInBvcG92ZXJcIlxyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgKGRlbGV0ZUV2ZW50KT1cImRlbGV0ZUV2ZW50LmVtaXQoJGV2ZW50KVwiXHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAoZWRpdEV2ZW50KT1cImVkaXRFdmVudC5lbWl0KCRldmVudClcIlxyXG4gICAgICAgICAgICAgICAgICAgICAgICA+PC9iYy1kYXktZXZlbnQtbGlzdD5cclxuICAgICAgICAgICAgICAgICAgICA8L2ZkLXBvcG92ZXI+XHJcbiAgICAgICAgICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICAgICAgPC90ZD5cclxuICAgICAgICAgICAgICAgIH1cclxuICAgICAgICAgICAgPC90cj5cclxuICAgICAgICAgICAgfVxyXG4gICAgICAgIDwvdGJvZHk+XHJcbiAgICA8L3RhYmxlPlxyXG48L25nLXRlbXBsYXRlPlxyXG5cclxuPG5nLXRlbXBsYXRlXHJcbiAgICAjcmVuZGVyRGF5VGFza3NcclxuICAgIGxldC13ZWVrVGFza3NcclxuICAgIGxldC1tYXhSb3dUYXNrcz1cIm1heFJvd1Rhc2tzXCJcclxuICAgIGxldC13ZWVrSW5kZXg9XCJ3ZWVrSW5kZXhcIlxyXG4gICAgbGV0LWRldmljZVNpemU9XCJkZXZpY2VTaXplXCJcclxuICAgIGxldC1jYWxlbmRhckZpZWxkcz1cImNhbGVuZGFyRmllbGRzXCJcclxuICAgIGxldC13ZWVrRGF5cz1cIndlZWtEYXlzXCJcclxuPlxyXG4gICAgQGZvciAocm93VGFzayBvZiBtYXhSb3dUYXNrczsgdHJhY2sgcm93VGFzazsgbGV0IGkgPSAkaW5kZXgpIHtcclxuICAgIDx0ciBmZC10YWJsZS1yb3c+XHJcbiAgICAgICAgQGlmICghd2Vla1Rhc2tzW2ldIHx8IHdlZWtUYXNrc1tpXS5sZW5ndGggPT09IDApIHsgQGZvciAoZGF5IG9mIHdlZWtEYXlzOyB0cmFjayBkYXkpIHtcclxuICAgICAgICA8dGQgZmQtdGFibGUtY2VsbD48L3RkPlxyXG4gICAgICAgIH0gfSBAZm9yICh0YXNrIG9mIHdlZWtUYXNrc1tpXTsgdHJhY2sgdGFzazsgbGV0IGRheUluZGV4ID0gJGluZGV4KSB7IEBpZiAodGFzay5jb2xTcGFuKSB7XHJcbiAgICAgICAgPHRkIGZkLXRhYmxlLWNlbGwgW2F0dHIuY29sc3Bhbl09XCJ0YXNrLmNvbFNwYW5cIj5cclxuICAgICAgICAgICAgQGlmICh0YXNrLmV2ZW50KSB7XHJcbiAgICAgICAgICAgIDxiYy1ldmVudC1idXR0b25cclxuICAgICAgICAgICAgICAgIFt0YXNrXT1cInRhc2tcIlxyXG4gICAgICAgICAgICAgICAgW2NhbGVuZGFyRmllbGRzXT1cImNhbGVuZGFyRmllbGRzXCJcclxuICAgICAgICAgICAgICAgIFtkZXZpY2VTaXplXT1cImRldmljZVNpemVcIlxyXG4gICAgICAgICAgICAgICAgW3J0bF09XCJydGxcIlxyXG4gICAgICAgICAgICAgICAgW2NhbkRlbGV0ZV09XCJjYW5EZWxldGVcIlxyXG4gICAgICAgICAgICAgICAgW2NhbkVkaXRdPVwiY2FuRWRpdFwiXHJcbiAgICAgICAgICAgICAgICBbY2FuVmlld109XCJjYW5WaWV3XCJcclxuICAgICAgICAgICAgICAgIChkZWxldGVFdmVudCk9XCJkZWxldGVFdmVudC5lbWl0KCRldmVudClcIlxyXG4gICAgICAgICAgICAgICAgKGVkaXRFdmVudCk9XCJlZGl0RXZlbnQuZW1pdCgkZXZlbnQpXCJcclxuICAgICAgICAgICAgICAgIChvcGVuUG9wb3ZlckNoYW5nZSk9XCJvbk9wZW5Qb3BvdmVyQ2hhbmdlKCRldmVudClcIlxyXG4gICAgICAgICAgICA+PC9iYy1ldmVudC1idXR0b24+XHJcbiAgICAgICAgICAgIH0gQGVsc2Uge1xyXG4gICAgICAgICAgICA8ZGl2IHN0eWxlPVwid2lkdGg6IDEwMCU7IGhlaWdodDogMTAwJVwiIChjbGljayk9XCJvbkRheVNlbGVjdCh3ZWVrSW5kZXgsIGRheUluZGV4KVwiPjwvZGl2PlxyXG4gICAgICAgICAgICB9XHJcbiAgICAgICAgPC90ZD5cclxuICAgICAgICB9IH1cclxuICAgIDwvdHI+XHJcbiAgICB9XHJcbjwvbmctdGVtcGxhdGU+XHJcbiJdfQ==