barsa-calendar 0.0.2

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 (56) hide show
  1. package/README.md +25 -0
  2. package/esm2020/barsa-calendar.mjs +5 -0
  3. package/esm2020/lib/barsa-calendar.module.mjs +106 -0
  4. package/esm2020/lib/calendar-container/calendar-container.component.mjs +190 -0
  5. package/esm2020/lib/calendar-header/calendar-header.component.mjs +61 -0
  6. package/esm2020/lib/calendar-list/calendar-list.component.mjs +19 -0
  7. package/esm2020/lib/calendar-list-container/calendar-list-container.component.mjs +30 -0
  8. package/esm2020/lib/calendar-list-item/calendar-list-item.component.mjs +14 -0
  9. package/esm2020/lib/calendar-month/calendar-month.component.mjs +244 -0
  10. package/esm2020/lib/calendar-selection-days/calendar-selection-days.component.mjs +193 -0
  11. package/esm2020/lib/calendar-week/calendar-week.component.mjs +182 -0
  12. package/esm2020/lib/constants.mjs +4 -0
  13. package/esm2020/lib/date-time-picker/date-time-picker.component.mjs +324 -0
  14. package/esm2020/lib/day-event-list/day-event-list.component.mjs +53 -0
  15. package/esm2020/lib/day-number-box/day-number-box.component.mjs +105 -0
  16. package/esm2020/lib/days-in-week.pipe.mjs +17 -0
  17. package/esm2020/lib/equal-date.pipe.mjs +23 -0
  18. package/esm2020/lib/event-button/event-button.component.mjs +70 -0
  19. package/esm2020/lib/event-date.pipe.mjs +24 -0
  20. package/esm2020/lib/event-preview/event-preview.component.mjs +60 -0
  21. package/esm2020/lib/event-time.pipe.mjs +22 -0
  22. package/esm2020/lib/from-to-time.pipe.mjs +23 -0
  23. package/esm2020/lib/models.mjs +14 -0
  24. package/esm2020/lib/month-days/month-days.component.mjs +220 -0
  25. package/esm2020/lib/services/calendar.service.mjs +610 -0
  26. package/esm2020/public-api.mjs +21 -0
  27. package/fesm2015/barsa-calendar.mjs +2447 -0
  28. package/fesm2015/barsa-calendar.mjs.map +1 -0
  29. package/fesm2020/barsa-calendar.mjs +2455 -0
  30. package/fesm2020/barsa-calendar.mjs.map +1 -0
  31. package/index.d.ts +5 -0
  32. package/lib/barsa-calendar.module.d.ts +33 -0
  33. package/lib/calendar-container/calendar-container.component.d.ts +73 -0
  34. package/lib/calendar-header/calendar-header.component.d.ts +29 -0
  35. package/lib/calendar-list/calendar-list.component.d.ts +8 -0
  36. package/lib/calendar-list-container/calendar-list-container.component.d.ts +14 -0
  37. package/lib/calendar-list-item/calendar-list-item.component.d.ts +7 -0
  38. package/lib/calendar-month/calendar-month.component.d.ts +70 -0
  39. package/lib/calendar-selection-days/calendar-selection-days.component.d.ts +47 -0
  40. package/lib/calendar-week/calendar-week.component.d.ts +57 -0
  41. package/lib/constants.d.ts +1 -0
  42. package/lib/date-time-picker/date-time-picker.component.d.ts +98 -0
  43. package/lib/day-event-list/day-event-list.component.d.ts +20 -0
  44. package/lib/day-number-box/day-number-box.component.d.ts +30 -0
  45. package/lib/days-in-week.pipe.d.ts +9 -0
  46. package/lib/equal-date.pipe.d.ts +8 -0
  47. package/lib/event-button/event-button.component.d.ts +26 -0
  48. package/lib/event-date.pipe.d.ts +9 -0
  49. package/lib/event-preview/event-preview.component.d.ts +19 -0
  50. package/lib/event-time.pipe.d.ts +9 -0
  51. package/lib/from-to-time.pipe.d.ts +9 -0
  52. package/lib/models.d.ts +107 -0
  53. package/lib/month-days/month-days.component.d.ts +69 -0
  54. package/lib/services/calendar.service.d.ts +70 -0
  55. package/package.json +31 -0
  56. package/public-api.d.ts +17 -0
@@ -0,0 +1,324 @@
1
+ import { ChangeDetectionStrategy, Component, EventEmitter, Injectable, Input, Output, ViewChild } from '@angular/core';
2
+ import { distinctUntilChanged, map } from 'rxjs/operators';
3
+ import { BaseComponent, DateService, getDateService, BarsaApi } from 'barsa-novin-ray-core';
4
+ import { CalendarService } from '../services/calendar.service';
5
+ import { DatetimeAdapter, FdDate, FdDatetimeAdapter, TimeComponent, TimeI18n } from '@fundamental-ngx/core';
6
+ import * as i0 from "@angular/core";
7
+ import * as i1 from "barsa-novin-ray-core";
8
+ import * as i2 from "@fundamental-ngx/core";
9
+ import * as i3 from "@angular/common";
10
+ import * as i4 from "@angular/forms";
11
+ import * as i5 from "@fundamental-ngx/core/bar";
12
+ import * as i6 from "@fundamental-ngx/core/button";
13
+ import * as i7 from "@fundamental-ngx/core/input-group";
14
+ import * as i8 from "@fundamental-ngx/core/popover";
15
+ import * as i9 from "@fundamental-ngx/core/time";
16
+ import * as i10 from "@fundamental-ngx/core/toolbar";
17
+ import * as i11 from "../calendar-month/calendar-month.component";
18
+ export class TimeConfigI18n {
19
+ constructor(_bbbTranslate) {
20
+ this._bbbTranslate = _bbbTranslate;
21
+ /** Aria label for the 'increase hours' button */
22
+ this.increaseHoursLabel = 'Increase hours';
23
+ /** label for the 'hours' column */
24
+ this.hoursLabel = this._bbbTranslate.transform('Hours');
25
+ /** Aria label for the 'decrease hours' button */
26
+ this.decreaseHoursLabel = 'Decrease hours';
27
+ /** Aria label for the 'increase minutes' button */
28
+ this.increaseMinutesLabel = 'Increase minutes';
29
+ /** label for the 'minutes' column */
30
+ this.minutesLabel = this._bbbTranslate.transform('Minutes');
31
+ /** Aria label for the 'decrease minutes' button */
32
+ this.decreaseMinutesLabel = 'Decrease minutes';
33
+ /** Aria label for the 'increase seconds' button */
34
+ this.increaseSecondsLabel = 'Increase seconds';
35
+ /** label for the 'seconds' column */
36
+ this.secondsLabel = this._bbbTranslate.transform('Sec');
37
+ /** Aria label for the 'decrease seconds' button */
38
+ this.decreaseSecondsLabel = 'Decrease seconds';
39
+ /** Aria label for the 'increase period' button */
40
+ this.increasePeriodLabel = 'Increase period';
41
+ /** label for the 'period' column */
42
+ this.periodLabel = 'Period';
43
+ /** Aria label for the 'decrease period' button */
44
+ this.decreasePeriodLabel = 'Decrease period';
45
+ }
46
+ }
47
+ TimeConfigI18n.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: TimeConfigI18n, deps: [{ token: i1.BbbTranslatePipe }], target: i0.ɵɵFactoryTarget.Injectable });
48
+ TimeConfigI18n.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: TimeConfigI18n });
49
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: TimeConfigI18n, decorators: [{
50
+ type: Injectable
51
+ }], ctorParameters: function () { return [{ type: i1.BbbTranslatePipe }]; } });
52
+ export class DateTimePickerComponent extends BaseComponent {
53
+ constructor(_datetimeAdapter, _logService, _portalService) {
54
+ super();
55
+ this._datetimeAdapter = _datetimeAdapter;
56
+ this._logService = _logService;
57
+ this.rtl = true;
58
+ this.rangeChange = new EventEmitter();
59
+ this.valueChange = new EventEmitter();
60
+ this.valueCaption = '';
61
+ this.selectionMode = 'day';
62
+ this.todayIndex = -1;
63
+ this.isValid = true;
64
+ this.months = [];
65
+ this.rtl$ = _portalService.rtl$;
66
+ this.width$ = _portalService.deviceSize$.pipe(distinctUntilChanged(), map((deviceSize) => {
67
+ if (!this.showDate) {
68
+ return 260;
69
+ }
70
+ switch (deviceSize) {
71
+ case 'l':
72
+ case 'xl':
73
+ return 560;
74
+ case 's':
75
+ return 320;
76
+ default:
77
+ return 520;
78
+ }
79
+ }));
80
+ this.height = 420;
81
+ }
82
+ ngOnInit() {
83
+ super.ngOnInit();
84
+ let culture = 'en-US';
85
+ switch (this.primaryCalendarType) {
86
+ case 'HijriShamsi':
87
+ culture = 'fa-IR';
88
+ break;
89
+ }
90
+ this.culture = culture;
91
+ this._calendarService = new CalendarService(this._logService, culture);
92
+ this.weekDaysMin = this._calendarService.weekDaysMin();
93
+ this.weekDays = this._calendarService.weekDays();
94
+ this.selectedMonth$ = this._calendarService.selected$;
95
+ this.today = this._calendarService.today;
96
+ if (this.value) {
97
+ this.timeValue = FdDate.getFdDateByDate(this.value);
98
+ this._setCaption(this.value);
99
+ this._calendarService.loadMonthByDate(this.value);
100
+ }
101
+ else {
102
+ this.timeValue = FdDate.getFdDateByDate(new Date());
103
+ }
104
+ // if (this.isRangePicker) {
105
+ // if (this.startRangeDate) {
106
+ // this._calendarService.loadMonthByDate(this.startRangeDate);
107
+ // }
108
+ // if (this.endRangeDate) {
109
+ // }
110
+ // } else {
111
+ // this._calendarService.loadMonthByDate(this.value);
112
+ // }
113
+ this.months = this._calendarService.Months;
114
+ this._prepareYear(this._calendarService.selectedMonth.dateInfo.year);
115
+ }
116
+ onOpenPopover(popover) {
117
+ if (this.readonly || this.disabled) {
118
+ return;
119
+ }
120
+ if (this.timeComponent) {
121
+ setTimeout(() => this.timeComponent.refreshColumns(), 0);
122
+ }
123
+ popover.open();
124
+ }
125
+ onMonthSelected(monthName, index) {
126
+ this._calendarService.gotoMonth(monthName, index);
127
+ }
128
+ onYearSelected(year) {
129
+ this._calendarService.gotoYear(+year);
130
+ }
131
+ onCaptionChanged(e) {
132
+ if (e.length < 10) {
133
+ return;
134
+ }
135
+ const englishDateStr = BarsaApi.Common.Util.ReplaceFaToArCharchter(e);
136
+ const moment = this._calendarService._dateService.stringToMoment(englishDateStr, 'jYYYY/jM/jD');
137
+ const isValid = moment.isValid();
138
+ const date = moment.toDate();
139
+ if (isValid) {
140
+ this.startSelectedDay = this.endSelectedDay = null;
141
+ this._raisValueChanged(date, false);
142
+ }
143
+ this.isValid = isValid;
144
+ }
145
+ onPrevTap() {
146
+ if (this.selectionMode === 'day') {
147
+ this._calendarService.loadPrevious();
148
+ }
149
+ else if (this.selectionMode === 'month') {
150
+ this._calendarService.loadPrevYear();
151
+ }
152
+ else if (this.selectionMode === 'year') {
153
+ this._prepareYear(Number(this.years[0]) - 20);
154
+ }
155
+ }
156
+ onNextTap() {
157
+ if (this.selectionMode === 'day') {
158
+ this._calendarService.loadNext();
159
+ }
160
+ else if (this.selectionMode === 'month') {
161
+ this._calendarService.loadNextYear();
162
+ }
163
+ else if (this.selectionMode === 'year') {
164
+ this._prepareYear(Number(this.years[this.years.length - 1]) + 1);
165
+ }
166
+ }
167
+ onToday() {
168
+ const today = new Date();
169
+ this.timeValue = this._datetimeAdapter.setTime(this.timeValue, today.getHours(), today.getMinutes(), today.getSeconds());
170
+ if (this._calendarService.todayDay) {
171
+ this.startSelectedDay = this._calendarService.todayDay;
172
+ }
173
+ this._calendarService.gotoToday();
174
+ }
175
+ onDayClick(day, popover) {
176
+ this.isValid = true;
177
+ this.startSelectedDay = this.endSelectedDay = day;
178
+ if (this.showTime) {
179
+ return;
180
+ }
181
+ this._setFirstAndEndDay(day, popover);
182
+ }
183
+ onPopoverOpenChange(isOpen) {
184
+ if (isOpen) {
185
+ this._lastValue = this.value;
186
+ }
187
+ else {
188
+ this._lastValue = undefined;
189
+ }
190
+ }
191
+ onOk(popover) {
192
+ popover.close();
193
+ this.value = this.showDate ? this.startSelectedDay?.date ?? this.value : new Date();
194
+ this.value?.setHours(this.timeValue.hour);
195
+ this.value?.setMinutes(this.timeValue.minute);
196
+ this.value?.setSeconds(this.timeValue.second);
197
+ this._raisValueChanged(this.value);
198
+ }
199
+ onCancel(popover) {
200
+ if (this._lastValue !== this.value) {
201
+ this.value = this._lastValue;
202
+ this._setCaption(this.value);
203
+ }
204
+ popover.close();
205
+ }
206
+ _prepareYear(from) {
207
+ const years = [];
208
+ for (let i = 0; i < 20; i++) {
209
+ years.push(`${from + i}`);
210
+ }
211
+ this.years = years;
212
+ }
213
+ _setCaption(value) {
214
+ if (!value) {
215
+ this.valueCaption = '';
216
+ return;
217
+ }
218
+ let formatPattern = this.formatPattern.replace('YYYY', 'jYYYY');
219
+ formatPattern = formatPattern.replace('MM', 'jMM');
220
+ formatPattern = formatPattern.replace('DD', 'jDD');
221
+ this.valueCaption = this._calendarService._dateService.getMoment(value).format(formatPattern);
222
+ }
223
+ _raisValueChanged(date, setCaption = true) {
224
+ this.value = date;
225
+ if (setCaption) {
226
+ this._setCaption(date);
227
+ }
228
+ this.valueChange.emit(date);
229
+ }
230
+ _setFirstAndEndDay(day, popover) {
231
+ if (popover) {
232
+ popover.close();
233
+ }
234
+ if (!this.isRangePicker) {
235
+ this._raisValueChanged(day.date);
236
+ return;
237
+ }
238
+ if (this.startSelectedDay) {
239
+ this.endSelectedDay = day;
240
+ }
241
+ else {
242
+ this.startSelectedDay = day;
243
+ }
244
+ if (this.startSelectedDay && this.endSelectedDay && this.startSelectedDay.date > this.endSelectedDay.date) {
245
+ const temp = this.startSelectedDay;
246
+ this.startSelectedDay = this.endSelectedDay;
247
+ this.endSelectedDay = temp;
248
+ }
249
+ if (this.startSelectedDay && this.endSelectedDay) {
250
+ this.rangeChange.emit({
251
+ startDay: this.startSelectedDay.date,
252
+ endDay: this.endSelectedDay.date
253
+ });
254
+ }
255
+ }
256
+ }
257
+ DateTimePickerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: DateTimePickerComponent, deps: [{ token: i2.DatetimeAdapter }, { token: i1.LogService }, { token: i1.PortalService }], target: i0.ɵɵFactoryTarget.Component });
258
+ DateTimePickerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: DateTimePickerComponent, selector: "bc-date-time-picker", inputs: { placeholder: "placeholder", primaryCalendarType: "primaryCalendarType", formatPattern: "formatPattern", value: "value", timeValue: "timeValue", startRangeDate: "startRangeDate", endRangeDate: "endRangeDate", isRangePicker: "isRangePicker", showTime: "showTime", showDate: "showDate", rtl: "rtl", readonly: "readonly", disabled: "disabled" }, outputs: { rangeChange: "rangeChange", valueChange: "valueChange" }, providers: [
259
+ {
260
+ provide: DatetimeAdapter,
261
+ useClass: FdDatetimeAdapter
262
+ },
263
+ {
264
+ provide: TimeI18n,
265
+ useClass: TimeConfigI18n
266
+ },
267
+ {
268
+ provide: DateService,
269
+ useFactory: getDateService
270
+ },
271
+ CalendarService
272
+ ], viewQueries: [{ propertyName: "timeComponent", first: true, predicate: TimeComponent, descendants: true }], usesInheritance: true, ngImport: i0, template: "<fd-input-group\n placement=\"after\"\n glyph=\"calendar\"\n glyphAriaLabel=\"select day\"\n [placeholder]=\"placeholder\"\n ariaLabelledby=\"fd-input-group-icon-label-2\"\n [button]=\"true\"\n [state]=\"isValid ? 'success' : 'error'\"\n [showFocus]=\"true\"\n (addOnButtonClicked)=\"onOpenPopover(popover)\"\n [ngModel]=\"value | dateTimeToCaption: formatPattern:culture:showDate:showTime\"\n (ngModelChange)=\"onCaptionChanged($event)\"\n [disabled]=\"disabled\"\n [readonly]=\"readonly\"\n>\n</fd-input-group>\n<fd-popover\n #popover\n (isOpenChange)=\"onPopoverOpenChange($event)\"\n [focusTrapped]=\"true\"\n [focusAutoCapture]=\"true\"\n [mobile]=\"(deviceSize$ | async) === 's'\"\n>\n <fd-popover-body [style.width.px]=\"width$ | async\">\n <ng-container\n *ngTemplateOutlet=\"\n month;\n context: {\n $implicit: selectedMonth$ | async,\n width: width$ | async,\n height: height,\n rtl: rtl$ | async,\n weekDays: weekDays,\n weekDaysMin: weekDaysMin,\n today: today,\n deviceSize: deviceSize$ | async,\n popover: popover\n }\n \"\n >\n </ng-container>\n <div fd-popover-body-footer *ngIf=\"showTime\">\n <div fd-bar [barDesign]=\"'footer'\">\n <div fd-bar-left *ngIf=\"rtl\">\n <container *ngTemplateOutlet=\"footerButtons\"></container>\n </div>\n <div fd-bar-right *ngIf=\"!rtl\">\n <container *ngTemplateOutlet=\"footerButtons\"></container>\n </div>\n </div>\n </div>\n </fd-popover-body>\n</fd-popover>\n<ng-template #footerButtons>\n <fd-button-bar [label]=\"'Cancel' | bbbTranslate\" (click)=\"onCancel(popover)\"></fd-button-bar>\n <fd-button-bar [label]=\"'Ok' | bbbTranslate\" fdType=\"emphasized\" (click)=\"onOk(popover)\"></fd-button-bar>\n</ng-template>\n<ng-template\n #month\n let-selectedMonth\n let-width=\"width\"\n let-height=\"height\"\n let-rtl=\"rtl\"\n let-today=\"today\"\n let-showEvents=\"showEvents\"\n let-deviceSize=\"deviceSize\"\n let-popover=\"popover\"\n>\n <fd-toolbar [fdType]=\"'transparent'\">\n <button\n fd-button\n fd-toolbar-item\n [label]=\"(showDate ? 'DateR_Today' : 'Now') | bbbTranslate\"\n (click)=\"onToday()\"\n ></button>\n <button\n *ngIf=\"showDate\"\n fd-button\n fd-toolbar-item\n [fdType]=\"'transparent'\"\n [glyph]=\"rtl ? 'navigation-right-arrow' : 'navigation-left-arrow'\"\n (click)=\"onPrevTap()\"\n ></button>\n <button\n *ngIf=\"showDate\"\n fd-button\n fd-toolbar-item\n [fdType]=\"'transparent'\"\n [glyph]=\"rtl ? 'navigation-left-arrow' : 'navigation-right-arrow'\"\n (click)=\"onNextTap()\"\n ></button>\n <div class=\"month-years-wrapper\" *ngIf=\"showDate\" fd-title fd-toolbar-item>\n <button\n *ngIf=\"selectionMode === 'day' || selectionMode === 'month'\"\n fd-button\n [fdType]=\"'transparent'\"\n [label]=\"selectedMonth.dateInfo.monthName\"\n (click)=\"selectionMode = 'month'\"\n ></button>\n <button\n fd-button\n [fdType]=\"'transparent'\"\n [label]=\"selectedMonth.dateInfo.year\"\n (click)=\"selectionMode = 'year'\"\n ></button>\n </div>\n </fd-toolbar>\n <div style=\"display: flex\">\n <ng-container [ngSwitch]=\"selectionMode\">\n <ng-container *ngSwitchCase=\"'month'\">\n <div class=\"month-year-selection-wrapper\">\n <button\n style=\"flex-grow: 1; width: 33%\"\n *ngFor=\"let month of months; let i = index\"\n fd-button\n [fdType]=\"selectedMonth.dateInfo.monthName === month ? 'emphasized' : 'transparent'\"\n [label]=\"month\"\n (click)=\"selectionMode = 'day'; onMonthSelected(month, i)\"\n ></button>\n </div>\n </ng-container>\n <ng-container *ngSwitchCase=\"'year'\">\n <div class=\"month-year-selection-wrapper\">\n <button\n style=\"flex-grow: 1; width: 25%\"\n *ngFor=\"let year of years\"\n fd-button\n [fdType]=\"selectedMonth.dateInfo.year === +year ? 'emphasized' : 'transparent'\"\n [label]=\"year\"\n (click)=\"selectionMode = 'day'; onYearSelected(year)\"\n ></button>\n </div>\n </ng-container>\n <div *ngSwitchDefault style=\"display: flex\">\n <bc-calendar-month\n *ngIf=\"showDate\"\n [style.width]=\"width\"\n [containerHeight]=\"height\"\n [containerWidth]=\"width\"\n [rtl]=\"rtl\"\n [monthWeeksCount]=\"selectedMonth.weeksCount\"\n [weekDays]=\"weekDays\"\n [weekDaysMin]=\"weekDaysMin\"\n [today]=\"today\"\n [datePicker]=\"true\"\n [dateRange]=\"true\"\n [selectedDate]=\"startSelectedDay ? startSelectedDay.date : value\"\n [days]=\"selectedMonth.days\"\n [deviceSize]=\"deviceSize\"\n (dayClick)=\"onDayClick($event, popover)\"\n ></bc-calendar-month>\n <div class=\"seperator\"></div>\n <fd-time\n *ngIf=\"showTime\"\n [(ngModel)]=\"timeValue\"\n [compact]=\"(deviceSize$ | async) !== 's'\"\n [displaySeconds]=\"false\"\n ></fd-time>\n </div>\n </ng-container>\n </div>\n</ng-template>\n", styles: [":host{display:block}fd-popover{display:block}fd-input-group ::ng-deep input{direction:ltr}fd-time ::ng-deep .fd-time{padding-top:0}.seperator{border-left:.0625rem solid var(--sapPageFooter_BorderColor, #d9d9d9)}\n"], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i3.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i3.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i3.NgSwitchDefault, selector: "[ngSwitchDefault]" }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i5.BarComponent, selector: "[fd-bar]", inputs: ["class", "barDesign", "inPage", "inHomePage", "size"] }, { kind: "directive", type: i5.BarLeftDirective, selector: "[fd-bar-left]" }, { kind: "directive", type: i5.BarRightDirective, selector: "[fd-bar-right]" }, { kind: "component", type: i5.ButtonBarComponent, selector: "fd-button-bar", inputs: ["fullWidth", "fdType", "title", "ariaLabel", "ariaLabelledby", "id"] }, { kind: "component", type: i6.ButtonComponent, selector: "button[fd-button], a[fd-button]", inputs: ["class"], exportAs: ["fd-button"] }, { kind: "component", type: i7.InputGroupComponent, selector: "fd-input-group", inputs: ["inputTemplate", "placement", "required", "inline", "placeholder", "addOnText", "buttonFocusable", "type", "glyph", "button", "disabled", "readonly", "state", "isControl", "showFocus", "isExpanded", "glyphAriaLabel", "iconTitle", "ariaLabelledby", "ariaLabelledBy"], outputs: ["addOnButtonClicked", "search"] }, { kind: "component", type: i8.PopoverBodyComponent, selector: "fd-popover-body" }, { kind: "directive", type: i8.PopoverBodyFooterDirective, selector: "[fdPopoverBodyFooter], [fd-popover-body-footer]" }, { kind: "component", type: i8.PopoverComponent, selector: "fd-popover", inputs: ["title", "trigger", "fixedPosition", "id", "mobile", "mobileConfig"] }, { kind: "component", type: i9.TimeComponent, selector: "fd-time", inputs: ["meridian", "validate", "keepTwoDigits", "disabled", "displaySeconds", "displayMinutes", "displayHours", "tablet", "elementsAtOnce", "time", "spinnerButtons"] }, { kind: "directive", type: i9.DeprecatedTimeContentDensityDirective, selector: "fd-time-column[compact], fd-time[compact]" }, { kind: "component", type: i10.ToolbarComponent, selector: "fd-toolbar", inputs: ["class", "shouldOverflow", "fdType", "hasTitle", "title", "active", "clearBorder", "forceOverflow", "tabindex"] }, { kind: "directive", type: i10.ToolbarItemDirective, selector: "[fd-toolbar-item]" }, { kind: "component", type: i11.CalendarMonthComponent, selector: "bc-calendar-month", inputs: ["monthWeeksCount", "weekDays", "weekDaysMin", "today", "containerHeight", "days", "calendarFields", "rtl", "deviceSize", "moDataList", "datePicker", "rangePicker", "canDelete", "canAdd", "canEdit", "selectedDate", "startSelectedDayIndex", "endSelectedDayIndex"], outputs: ["editEvent", "deleteEvent", "daySelect", "dayClick", "dayMouseMove", "dayMouseUp", "dayMouseDown", "showEvent"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }, { kind: "pipe", type: i1.BbbTranslatePipe, name: "bbbTranslate" }, { kind: "pipe", type: i1.DateTimeToCaptionPipe, name: "dateTimeToCaption" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
273
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: DateTimePickerComponent, decorators: [{
274
+ type: Component,
275
+ args: [{ selector: 'bc-date-time-picker', changeDetection: ChangeDetectionStrategy.OnPush, providers: [
276
+ {
277
+ provide: DatetimeAdapter,
278
+ useClass: FdDatetimeAdapter
279
+ },
280
+ {
281
+ provide: TimeI18n,
282
+ useClass: TimeConfigI18n
283
+ },
284
+ {
285
+ provide: DateService,
286
+ useFactory: getDateService
287
+ },
288
+ CalendarService
289
+ ], template: "<fd-input-group\n placement=\"after\"\n glyph=\"calendar\"\n glyphAriaLabel=\"select day\"\n [placeholder]=\"placeholder\"\n ariaLabelledby=\"fd-input-group-icon-label-2\"\n [button]=\"true\"\n [state]=\"isValid ? 'success' : 'error'\"\n [showFocus]=\"true\"\n (addOnButtonClicked)=\"onOpenPopover(popover)\"\n [ngModel]=\"value | dateTimeToCaption: formatPattern:culture:showDate:showTime\"\n (ngModelChange)=\"onCaptionChanged($event)\"\n [disabled]=\"disabled\"\n [readonly]=\"readonly\"\n>\n</fd-input-group>\n<fd-popover\n #popover\n (isOpenChange)=\"onPopoverOpenChange($event)\"\n [focusTrapped]=\"true\"\n [focusAutoCapture]=\"true\"\n [mobile]=\"(deviceSize$ | async) === 's'\"\n>\n <fd-popover-body [style.width.px]=\"width$ | async\">\n <ng-container\n *ngTemplateOutlet=\"\n month;\n context: {\n $implicit: selectedMonth$ | async,\n width: width$ | async,\n height: height,\n rtl: rtl$ | async,\n weekDays: weekDays,\n weekDaysMin: weekDaysMin,\n today: today,\n deviceSize: deviceSize$ | async,\n popover: popover\n }\n \"\n >\n </ng-container>\n <div fd-popover-body-footer *ngIf=\"showTime\">\n <div fd-bar [barDesign]=\"'footer'\">\n <div fd-bar-left *ngIf=\"rtl\">\n <container *ngTemplateOutlet=\"footerButtons\"></container>\n </div>\n <div fd-bar-right *ngIf=\"!rtl\">\n <container *ngTemplateOutlet=\"footerButtons\"></container>\n </div>\n </div>\n </div>\n </fd-popover-body>\n</fd-popover>\n<ng-template #footerButtons>\n <fd-button-bar [label]=\"'Cancel' | bbbTranslate\" (click)=\"onCancel(popover)\"></fd-button-bar>\n <fd-button-bar [label]=\"'Ok' | bbbTranslate\" fdType=\"emphasized\" (click)=\"onOk(popover)\"></fd-button-bar>\n</ng-template>\n<ng-template\n #month\n let-selectedMonth\n let-width=\"width\"\n let-height=\"height\"\n let-rtl=\"rtl\"\n let-today=\"today\"\n let-showEvents=\"showEvents\"\n let-deviceSize=\"deviceSize\"\n let-popover=\"popover\"\n>\n <fd-toolbar [fdType]=\"'transparent'\">\n <button\n fd-button\n fd-toolbar-item\n [label]=\"(showDate ? 'DateR_Today' : 'Now') | bbbTranslate\"\n (click)=\"onToday()\"\n ></button>\n <button\n *ngIf=\"showDate\"\n fd-button\n fd-toolbar-item\n [fdType]=\"'transparent'\"\n [glyph]=\"rtl ? 'navigation-right-arrow' : 'navigation-left-arrow'\"\n (click)=\"onPrevTap()\"\n ></button>\n <button\n *ngIf=\"showDate\"\n fd-button\n fd-toolbar-item\n [fdType]=\"'transparent'\"\n [glyph]=\"rtl ? 'navigation-left-arrow' : 'navigation-right-arrow'\"\n (click)=\"onNextTap()\"\n ></button>\n <div class=\"month-years-wrapper\" *ngIf=\"showDate\" fd-title fd-toolbar-item>\n <button\n *ngIf=\"selectionMode === 'day' || selectionMode === 'month'\"\n fd-button\n [fdType]=\"'transparent'\"\n [label]=\"selectedMonth.dateInfo.monthName\"\n (click)=\"selectionMode = 'month'\"\n ></button>\n <button\n fd-button\n [fdType]=\"'transparent'\"\n [label]=\"selectedMonth.dateInfo.year\"\n (click)=\"selectionMode = 'year'\"\n ></button>\n </div>\n </fd-toolbar>\n <div style=\"display: flex\">\n <ng-container [ngSwitch]=\"selectionMode\">\n <ng-container *ngSwitchCase=\"'month'\">\n <div class=\"month-year-selection-wrapper\">\n <button\n style=\"flex-grow: 1; width: 33%\"\n *ngFor=\"let month of months; let i = index\"\n fd-button\n [fdType]=\"selectedMonth.dateInfo.monthName === month ? 'emphasized' : 'transparent'\"\n [label]=\"month\"\n (click)=\"selectionMode = 'day'; onMonthSelected(month, i)\"\n ></button>\n </div>\n </ng-container>\n <ng-container *ngSwitchCase=\"'year'\">\n <div class=\"month-year-selection-wrapper\">\n <button\n style=\"flex-grow: 1; width: 25%\"\n *ngFor=\"let year of years\"\n fd-button\n [fdType]=\"selectedMonth.dateInfo.year === +year ? 'emphasized' : 'transparent'\"\n [label]=\"year\"\n (click)=\"selectionMode = 'day'; onYearSelected(year)\"\n ></button>\n </div>\n </ng-container>\n <div *ngSwitchDefault style=\"display: flex\">\n <bc-calendar-month\n *ngIf=\"showDate\"\n [style.width]=\"width\"\n [containerHeight]=\"height\"\n [containerWidth]=\"width\"\n [rtl]=\"rtl\"\n [monthWeeksCount]=\"selectedMonth.weeksCount\"\n [weekDays]=\"weekDays\"\n [weekDaysMin]=\"weekDaysMin\"\n [today]=\"today\"\n [datePicker]=\"true\"\n [dateRange]=\"true\"\n [selectedDate]=\"startSelectedDay ? startSelectedDay.date : value\"\n [days]=\"selectedMonth.days\"\n [deviceSize]=\"deviceSize\"\n (dayClick)=\"onDayClick($event, popover)\"\n ></bc-calendar-month>\n <div class=\"seperator\"></div>\n <fd-time\n *ngIf=\"showTime\"\n [(ngModel)]=\"timeValue\"\n [compact]=\"(deviceSize$ | async) !== 's'\"\n [displaySeconds]=\"false\"\n ></fd-time>\n </div>\n </ng-container>\n </div>\n</ng-template>\n", styles: [":host{display:block}fd-popover{display:block}fd-input-group ::ng-deep input{direction:ltr}fd-time ::ng-deep .fd-time{padding-top:0}.seperator{border-left:.0625rem solid var(--sapPageFooter_BorderColor, #d9d9d9)}\n"] }]
290
+ }], ctorParameters: function () { return [{ type: i2.DatetimeAdapter }, { type: i1.LogService }, { type: i1.PortalService }]; }, propDecorators: { placeholder: [{
291
+ type: Input
292
+ }], primaryCalendarType: [{
293
+ type: Input
294
+ }], formatPattern: [{
295
+ type: Input
296
+ }], value: [{
297
+ type: Input
298
+ }], timeValue: [{
299
+ type: Input
300
+ }], startRangeDate: [{
301
+ type: Input
302
+ }], endRangeDate: [{
303
+ type: Input
304
+ }], isRangePicker: [{
305
+ type: Input
306
+ }], showTime: [{
307
+ type: Input
308
+ }], showDate: [{
309
+ type: Input
310
+ }], rtl: [{
311
+ type: Input
312
+ }], readonly: [{
313
+ type: Input
314
+ }], disabled: [{
315
+ type: Input
316
+ }], rangeChange: [{
317
+ type: Output
318
+ }], valueChange: [{
319
+ type: Output
320
+ }], timeComponent: [{
321
+ type: ViewChild,
322
+ args: [TimeComponent]
323
+ }] } });
324
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-time-picker.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-calendar/src/lib/date-time-picker/date-time-picker.component.ts","../../../../../projects/barsa-calendar/src/lib/date-time-picker/date-time-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component,\n    EventEmitter,\n    Injectable,\n    Input,\n    OnInit,\n    Output,\n    ViewChild\n} from '@angular/core';\nimport { Observable } from 'rxjs';\nimport { distinctUntilChanged, map } from 'rxjs/operators';\n\nimport {\n    BaseComponent,\n    BbbTranslatePipe,\n    DateService,\n    getDateService,\n    LogService,\n    PortalService,\n    BarsaApi\n} from 'barsa-novin-ray-core';\nimport { CalendarMonthInfo, Day } from '../models';\nimport { CalendarService } from '../services/calendar.service';\nimport { DatetimeAdapter, FdDate, FdDatetimeAdapter, TimeComponent, TimeI18n } from '@fundamental-ngx/core';\n@Injectable()\nexport class TimeConfigI18n {\n    /** Aria label for the 'increase hours' button */\n    increaseHoursLabel = 'Increase hours';\n\n    /** label for the 'hours' column */\n    hoursLabel = this._bbbTranslate.transform('Hours');\n\n    /** Aria label for the 'decrease hours' button */\n    decreaseHoursLabel = 'Decrease hours';\n\n    /** Aria label for the 'increase minutes' button */\n    increaseMinutesLabel = 'Increase minutes';\n\n    /** label for the 'minutes' column */\n    minutesLabel = this._bbbTranslate.transform('Minutes');\n\n    /** Aria label for the 'decrease minutes' button */\n    decreaseMinutesLabel = 'Decrease minutes';\n\n    /** Aria label for the 'increase seconds' button */\n    increaseSecondsLabel = 'Increase seconds';\n\n    /** label for the 'seconds' column */\n    secondsLabel = this._bbbTranslate.transform('Sec');\n\n    /** Aria label for the 'decrease seconds' button */\n    decreaseSecondsLabel = 'Decrease seconds';\n\n    /** Aria label for the 'increase period' button */\n    increasePeriodLabel = 'Increase period';\n\n    /** label for the 'period' column */\n    periodLabel = 'Period';\n\n    /** Aria label for the 'decrease period' button */\n    decreasePeriodLabel = 'Decrease period';\n    constructor(private _bbbTranslate: BbbTranslatePipe) {}\n}\n\n@Component({\n    selector: 'bc-date-time-picker',\n    templateUrl: './date-time-picker.component.html',\n    styleUrls: ['./date-time-picker.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        {\n            provide: DatetimeAdapter,\n            useClass: FdDatetimeAdapter\n        },\n        {\n            provide: TimeI18n,\n            useClass: TimeConfigI18n\n        },\n        {\n            provide: DateService,\n            useFactory: getDateService\n        },\n        CalendarService\n    ]\n})\nexport class DateTimePickerComponent extends BaseComponent implements OnInit {\n    @Input() placeholder: string;\n    @Input() primaryCalendarType: 'Gregorian' | 'Persian' | string;\n    @Input() formatPattern: string;\n    @Input() value: Date | undefined;\n    @Input() timeValue: FdDate;\n    @Input() startRangeDate: Date;\n    @Input() endRangeDate: Date;\n    @Input() isRangePicker: boolean;\n    @Input() showTime: boolean;\n    @Input() showDate: boolean;\n    @Input() rtl = true;\n    @Input() readonly: boolean;\n    @Input() disabled: boolean;\n    @Output() rangeChange = new EventEmitter<{ startDay: Date; endDay: Date }>();\n    @Output() valueChange = new EventEmitter<Date>();\n    @ViewChild(TimeComponent) timeComponent: TimeComponent<FdDate>;\n    valueCaption = '';\n    endSelectedDay: Day | null;\n    startSelectedDay: Day | null;\n    valueDay: Day | null;\n\n    selectionMode: 'day' | 'month' | 'year' = 'day';\n    todayIndex = -1;\n    width$: Observable<number>;\n    height: number;\n    selectedMonth$: Observable<CalendarMonthInfo>;\n    rtl$: Observable<boolean>;\n    today: Date;\n    weekDaysMin: string[];\n    weekDays: string[];\n    deviceSize$: Observable<string>;\n    isValid = true;\n    culture: string;\n    months: string[] = [];\n    years: string[];\n    private _calendarService: CalendarService;\n    private _lastValue: Date | undefined;\n\n    constructor(\n        private _datetimeAdapter: DatetimeAdapter<FdDate>,\n        private _logService: LogService,\n        _portalService: PortalService\n    ) {\n        super();\n\n        this.rtl$ = _portalService.rtl$;\n        this.width$ = _portalService.deviceSize$.pipe(\n            distinctUntilChanged(),\n            map((deviceSize) => {\n                if (!this.showDate) {\n                    return 260;\n                }\n                switch (deviceSize) {\n                    case 'l':\n                    case 'xl':\n                        return 560;\n                    case 's':\n                        return 320;\n                    default:\n                        return 520;\n                }\n            })\n        );\n\n        this.height = 420;\n    }\n\n    ngOnInit(): void {\n        super.ngOnInit();\n        let culture = 'en-US';\n        switch (this.primaryCalendarType) {\n            case 'HijriShamsi':\n                culture = 'fa-IR';\n                break;\n        }\n        this.culture = culture;\n        this._calendarService = new CalendarService(this._logService, culture);\n        this.weekDaysMin = this._calendarService.weekDaysMin();\n        this.weekDays = this._calendarService.weekDays();\n        this.selectedMonth$ = this._calendarService.selected$;\n        this.today = this._calendarService.today;\n\n        if (this.value) {\n            this.timeValue = FdDate.getFdDateByDate(this.value);\n            this._setCaption(this.value);\n            this._calendarService.loadMonthByDate(this.value);\n        } else {\n            this.timeValue = FdDate.getFdDateByDate(new Date());\n        }\n        // if (this.isRangePicker) {\n        //   if (this.startRangeDate) {\n        //     this._calendarService.loadMonthByDate(this.startRangeDate);\n        //   }\n        //   if (this.endRangeDate) {\n        //   }\n        // } else {\n        //   this._calendarService.loadMonthByDate(this.value);\n        // }\n        this.months = this._calendarService.Months;\n        this._prepareYear(this._calendarService.selectedMonth.dateInfo.year);\n    }\n\n    onOpenPopover(popover): void {\n        if (this.readonly || this.disabled) {\n            return;\n        }\n        if (this.timeComponent) {\n            setTimeout(() => this.timeComponent.refreshColumns(), 0);\n        }\n        popover.open();\n    }\n    onMonthSelected(monthName: string, index: number): void {\n        this._calendarService.gotoMonth(monthName, index);\n    }\n    onYearSelected(year: string): void {\n        this._calendarService.gotoYear(+year);\n    }\n\n    onCaptionChanged(e): void {\n        if (e.length < 10) {\n            return;\n        }\n        const englishDateStr = BarsaApi.Common.Util.ReplaceFaToArCharchter(e);\n        const moment = this._calendarService._dateService.stringToMoment(englishDateStr, 'jYYYY/jM/jD');\n        const isValid = moment.isValid();\n        const date = moment.toDate();\n        if (isValid) {\n            this.startSelectedDay = this.endSelectedDay = null;\n            this._raisValueChanged(date, false);\n        }\n        this.isValid = isValid;\n    }\n    onPrevTap(): void {\n        if (this.selectionMode === 'day') {\n            this._calendarService.loadPrevious();\n        } else if (this.selectionMode === 'month') {\n            this._calendarService.loadPrevYear();\n        } else if (this.selectionMode === 'year') {\n            this._prepareYear(Number(this.years[0]) - 20);\n        }\n    }\n\n    onNextTap(): void {\n        if (this.selectionMode === 'day') {\n            this._calendarService.loadNext();\n        } else if (this.selectionMode === 'month') {\n            this._calendarService.loadNextYear();\n        } else if (this.selectionMode === 'year') {\n            this._prepareYear(Number(this.years[this.years.length - 1]) + 1);\n        }\n    }\n\n    onToday(): void {\n        const today = new Date();\n        this.timeValue = this._datetimeAdapter.setTime(\n            this.timeValue,\n            today.getHours(),\n            today.getMinutes(),\n            today.getSeconds()\n        );\n        if (this._calendarService.todayDay) {\n            this.startSelectedDay = this._calendarService.todayDay;\n        }\n        this._calendarService.gotoToday();\n    }\n\n    onDayClick(day: Day, popover): void {\n        this.isValid = true;\n        this.startSelectedDay = this.endSelectedDay = day;\n        if (this.showTime) {\n            return;\n        }\n        this._setFirstAndEndDay(day, popover);\n    }\n\n    onPopoverOpenChange(isOpen): void {\n        if (isOpen) {\n            this._lastValue = this.value;\n        } else {\n            this._lastValue = undefined;\n        }\n    }\n\n    onOk(popover): void {\n        popover.close();\n        this.value = this.showDate ? this.startSelectedDay?.date ?? this.value : new Date();\n        this.value?.setHours(this.timeValue.hour);\n        this.value?.setMinutes(this.timeValue.minute);\n        this.value?.setSeconds(this.timeValue.second);\n        this._raisValueChanged(this.value);\n    }\n\n    onCancel(popover): void {\n        if (this._lastValue !== this.value) {\n            this.value = this._lastValue;\n            this._setCaption(this.value);\n        }\n        popover.close();\n    }\n    private _prepareYear(from: number): void {\n        const years: string[] = [];\n        for (let i = 0; i < 20; i++) {\n            years.push(`${from + i}`);\n        }\n        this.years = years;\n    }\n    private _setCaption(value): void {\n        if (!value) {\n            this.valueCaption = '';\n            return;\n        }\n        let formatPattern = this.formatPattern.replace('YYYY', 'jYYYY');\n        formatPattern = formatPattern.replace('MM', 'jMM');\n        formatPattern = formatPattern.replace('DD', 'jDD');\n        this.valueCaption = this._calendarService._dateService.getMoment(value).format(formatPattern);\n    }\n    private _raisValueChanged(date, setCaption = true): void {\n        this.value = date;\n        if (setCaption) {\n            this._setCaption(date);\n        }\n        this.valueChange.emit(date);\n    }\n\n    private _setFirstAndEndDay(day: Day, popover): void {\n        if (popover) {\n            popover.close();\n        }\n        if (!this.isRangePicker) {\n            this._raisValueChanged(day.date);\n            return;\n        }\n        if (this.startSelectedDay) {\n            this.endSelectedDay = day;\n        } else {\n            this.startSelectedDay = day;\n        }\n        if (this.startSelectedDay && this.endSelectedDay && this.startSelectedDay.date > this.endSelectedDay.date) {\n            const temp = this.startSelectedDay;\n            this.startSelectedDay = this.endSelectedDay;\n            this.endSelectedDay = temp;\n        }\n        if (this.startSelectedDay && this.endSelectedDay) {\n            this.rangeChange.emit({\n                startDay: this.startSelectedDay.date,\n                endDay: this.endSelectedDay.date\n            });\n        }\n    }\n}\n","<fd-input-group\n    placement=\"after\"\n    glyph=\"calendar\"\n    glyphAriaLabel=\"select day\"\n    [placeholder]=\"placeholder\"\n    ariaLabelledby=\"fd-input-group-icon-label-2\"\n    [button]=\"true\"\n    [state]=\"isValid ? 'success' : 'error'\"\n    [showFocus]=\"true\"\n    (addOnButtonClicked)=\"onOpenPopover(popover)\"\n    [ngModel]=\"value | dateTimeToCaption: formatPattern:culture:showDate:showTime\"\n    (ngModelChange)=\"onCaptionChanged($event)\"\n    [disabled]=\"disabled\"\n    [readonly]=\"readonly\"\n>\n</fd-input-group>\n<fd-popover\n    #popover\n    (isOpenChange)=\"onPopoverOpenChange($event)\"\n    [focusTrapped]=\"true\"\n    [focusAutoCapture]=\"true\"\n    [mobile]=\"(deviceSize$ | async) === 's'\"\n>\n    <fd-popover-body [style.width.px]=\"width$ | async\">\n        <ng-container\n            *ngTemplateOutlet=\"\n                month;\n                context: {\n                    $implicit: selectedMonth$ | async,\n                    width: width$ | async,\n                    height: height,\n                    rtl: rtl$ | async,\n                    weekDays: weekDays,\n                    weekDaysMin: weekDaysMin,\n                    today: today,\n                    deviceSize: deviceSize$ | async,\n                    popover: popover\n                }\n            \"\n        >\n        </ng-container>\n        <div fd-popover-body-footer *ngIf=\"showTime\">\n            <div fd-bar [barDesign]=\"'footer'\">\n                <div fd-bar-left *ngIf=\"rtl\">\n                    <container *ngTemplateOutlet=\"footerButtons\"></container>\n                </div>\n                <div fd-bar-right *ngIf=\"!rtl\">\n                    <container *ngTemplateOutlet=\"footerButtons\"></container>\n                </div>\n            </div>\n        </div>\n    </fd-popover-body>\n</fd-popover>\n<ng-template #footerButtons>\n    <fd-button-bar [label]=\"'Cancel' | bbbTranslate\" (click)=\"onCancel(popover)\"></fd-button-bar>\n    <fd-button-bar [label]=\"'Ok' | bbbTranslate\" fdType=\"emphasized\" (click)=\"onOk(popover)\"></fd-button-bar>\n</ng-template>\n<ng-template\n    #month\n    let-selectedMonth\n    let-width=\"width\"\n    let-height=\"height\"\n    let-rtl=\"rtl\"\n    let-today=\"today\"\n    let-showEvents=\"showEvents\"\n    let-deviceSize=\"deviceSize\"\n    let-popover=\"popover\"\n>\n    <fd-toolbar [fdType]=\"'transparent'\">\n        <button\n            fd-button\n            fd-toolbar-item\n            [label]=\"(showDate ? 'DateR_Today' : 'Now') | bbbTranslate\"\n            (click)=\"onToday()\"\n        ></button>\n        <button\n            *ngIf=\"showDate\"\n            fd-button\n            fd-toolbar-item\n            [fdType]=\"'transparent'\"\n            [glyph]=\"rtl ? 'navigation-right-arrow' : 'navigation-left-arrow'\"\n            (click)=\"onPrevTap()\"\n        ></button>\n        <button\n            *ngIf=\"showDate\"\n            fd-button\n            fd-toolbar-item\n            [fdType]=\"'transparent'\"\n            [glyph]=\"rtl ? 'navigation-left-arrow' : 'navigation-right-arrow'\"\n            (click)=\"onNextTap()\"\n        ></button>\n        <div class=\"month-years-wrapper\" *ngIf=\"showDate\" fd-title fd-toolbar-item>\n            <button\n                *ngIf=\"selectionMode === 'day' || selectionMode === 'month'\"\n                fd-button\n                [fdType]=\"'transparent'\"\n                [label]=\"selectedMonth.dateInfo.monthName\"\n                (click)=\"selectionMode = 'month'\"\n            ></button>\n            <button\n                fd-button\n                [fdType]=\"'transparent'\"\n                [label]=\"selectedMonth.dateInfo.year\"\n                (click)=\"selectionMode = 'year'\"\n            ></button>\n        </div>\n    </fd-toolbar>\n    <div style=\"display: flex\">\n        <ng-container [ngSwitch]=\"selectionMode\">\n            <ng-container *ngSwitchCase=\"'month'\">\n                <div class=\"month-year-selection-wrapper\">\n                    <button\n                        style=\"flex-grow: 1; width: 33%\"\n                        *ngFor=\"let month of months; let i = index\"\n                        fd-button\n                        [fdType]=\"selectedMonth.dateInfo.monthName === month ? 'emphasized' : 'transparent'\"\n                        [label]=\"month\"\n                        (click)=\"selectionMode = 'day'; onMonthSelected(month, i)\"\n                    ></button>\n                </div>\n            </ng-container>\n            <ng-container *ngSwitchCase=\"'year'\">\n                <div class=\"month-year-selection-wrapper\">\n                    <button\n                        style=\"flex-grow: 1; width: 25%\"\n                        *ngFor=\"let year of years\"\n                        fd-button\n                        [fdType]=\"selectedMonth.dateInfo.year === +year ? 'emphasized' : 'transparent'\"\n                        [label]=\"year\"\n                        (click)=\"selectionMode = 'day'; onYearSelected(year)\"\n                    ></button>\n                </div>\n            </ng-container>\n            <div *ngSwitchDefault style=\"display: flex\">\n                <bc-calendar-month\n                    *ngIf=\"showDate\"\n                    [style.width]=\"width\"\n                    [containerHeight]=\"height\"\n                    [containerWidth]=\"width\"\n                    [rtl]=\"rtl\"\n                    [monthWeeksCount]=\"selectedMonth.weeksCount\"\n                    [weekDays]=\"weekDays\"\n                    [weekDaysMin]=\"weekDaysMin\"\n                    [today]=\"today\"\n                    [datePicker]=\"true\"\n                    [dateRange]=\"true\"\n                    [selectedDate]=\"startSelectedDay ? startSelectedDay.date : value\"\n                    [days]=\"selectedMonth.days\"\n                    [deviceSize]=\"deviceSize\"\n                    (dayClick)=\"onDayClick($event, popover)\"\n                ></bc-calendar-month>\n                <div class=\"seperator\"></div>\n                <fd-time\n                    *ngIf=\"showTime\"\n                    [(ngModel)]=\"timeValue\"\n                    [compact]=\"(deviceSize$ | async) !== 's'\"\n                    [displaySeconds]=\"false\"\n                ></fd-time>\n            </div>\n        </ng-container>\n    </div>\n</ng-template>\n"]}
@@ -0,0 +1,53 @@
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 "@angular/common";
5
+ import * as i2 from "@fundamental-ngx/core/bar";
6
+ import * as i3 from "@fundamental-ngx/core/list";
7
+ import * as i4 from "@fundamental-ngx/core/popover";
8
+ import * as i5 from "@fundamental-ngx/platform/button";
9
+ import * as i6 from "../event-preview/event-preview.component";
10
+ import * as i7 from "../day-number-box/day-number-box.component";
11
+ export class DayEventListComponent extends BaseComponent {
12
+ constructor() {
13
+ super(...arguments);
14
+ this.deleteEvent = new EventEmitter();
15
+ this.editEvent = new EventEmitter();
16
+ this.openPopOver = new EventEmitter();
17
+ }
18
+ onClosePopover(popover, popover2) {
19
+ popover.close();
20
+ if (popover2) {
21
+ popover2.close();
22
+ }
23
+ }
24
+ }
25
+ DayEventListComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: DayEventListComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
26
+ DayEventListComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: DayEventListComponent, selector: "bc-day-event-list", inputs: { day: "day", deviceSize: "deviceSize", weekDays: "weekDays", calendarFields: "calendarFields", rtl: "rtl", canDelete: "canDelete", canEdit: "canEdit", popover: "popover" }, outputs: { deleteEvent: "deleteEvent", editEvent: "editEvent", openPopOver: "openPopOver" }, usesInheritance: true, ngImport: i0, template: "<div fd-bar [barDesign]=\"'header-with-subheader'\">\n <div fd-bar-left>\n <fd-bar-element>\n <fdp-button glyph=\"decline\" [buttonType]=\"'transparent'\" (click)=\"onClosePopover(popover)\"></fdp-button>\n </fd-bar-element>\n </div>\n <div fd-bar-middle>\n <fd-bar-element>\n {{ weekDays[day.dayInWeek] }}\n </fd-bar-element>\n </div>\n <div fd-bar-right>\n <fd-bar-element> </fd-bar-element>\n </div>\n</div>\n<div fd-bar [barDesign]=\"'subheader'\">\n <div fd-bar-middle>\n <fd-bar-element [fullWidth]=\"true\">\n <bc-day-number-box [day]=\"day\" [isWeekMode]=\"true\"></bc-day-number-box>\n </fd-bar-element>\n </div>\n</div>\n<ul fd-list>\n <li fd-list-item *ngFor=\"let task of day.tasks\" class=\"task-start-end\" (click)=\"popoverPreview.open()\">\n <span [ngClass]=\"{ 'end-day': rtl, 'start-day': !rtl }\" *ngIf=\"task.isMiddle && !task.isStartDay\"></span>\n <span class=\"middle-day\">{{ task.event[calendarFields.Title] }}</span>\n <span\n [ngClass]=\"{ 'start-day': rtl, 'end-day': !rtl }\"\n *ngIf=\"(task.isMiddle || task.isStartDay) && !task.isEndDay\"\n ></span>\n <fd-popover\n #popoverPreview\n placement=\"bottom\"\n [mobile]=\"deviceSize === 's'\"\n [focusTrapped]=\"true\"\n [focusAutoCapture]=\"true\"\n [title]=\"task.event[calendarFields.Title]\"\n >\n <bc-event-preview\n [event]=\"task.event\"\n [calendarFields]=\"calendarFields\"\n [popover]=\"popoverPreview\"\n [canDelete]=\"canDelete\"\n [canEdit]=\"canEdit\"\n [popover2]=\"popover\"\n (deleteEvent)=\"deleteEvent.emit($event)\"\n (editEvent)=\"editEvent.emit($event)\"\n ></bc-event-preview>\n </fd-popover>\n </li>\n</ul>\n", styles: [".task-start-end{cursor:pointer}.start-day{width:0;height:0;border-top:10px solid transparent;border-right:10px solid var(--sapButton_Emphasized_BorderColor, #0a6ed1);border-bottom:10px solid transparent}.middle-day{width:100%;min-width:200px;height:20px;background-color:var(--sapButton_Emphasized_Background, #0a6ed1);color:var(--sapButton_Emphasized_TextColor, #fff);text-align:center}.end-day{width:0;height:0;border-top:10px solid transparent;border-left:10px solid var(--sapButton_Emphasized_BorderColor, #0a6ed1);border-bottom:10px solid transparent}.event-list-number-day{width:40px;height:40px;flex-grow:0;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-grow:0!important}.event-list-number-day:hover{color:var(--sapButton_Hover_TextColor, #0854a0);background-color:var(--sapButton_Hover_Background, #ebf5fe);cursor:pointer}::ng-deep .fd-form-item{flex-direction:row!important}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.BarComponent, selector: "[fd-bar]", inputs: ["class", "barDesign", "inPage", "inHomePage", "size"] }, { kind: "directive", type: i2.BarLeftDirective, selector: "[fd-bar-left]" }, { kind: "directive", type: i2.BarMiddleDirective, selector: "[fd-bar-middle]" }, { kind: "directive", type: i2.BarRightDirective, selector: "[fd-bar-right]" }, { kind: "directive", type: i2.BarElementDirective, selector: "fd-bar-element", inputs: ["fullWidth", "isTitle"] }, { kind: "component", type: i3.ListComponent, selector: "[fd-list], [fdList]", inputs: ["dropdownMode", "multiInputMode", "mobileMode", "hasMessage", "noBorder", "navigationIndicator", "selection", "keyboardSupport", "byline"], outputs: ["focusEscapeList"] }, { kind: "component", type: i3.ListItemComponent, selector: "[fdListItem] ,[fd-list-item]", inputs: ["selected", "ariaDescribedBy", "noData", "action", "interactive", "growing", "counter", "unread", "selectedListItemScreenReaderText", "navigatedListItemScreenReaderText", "navigatableListItemScreenReaderText"], outputs: ["keyDown"] }, { kind: "component", type: i4.PopoverComponent, selector: "fd-popover", inputs: ["title", "trigger", "fixedPosition", "id", "mobile", "mobileConfig"] }, { kind: "component", type: i5.ButtonComponent, selector: "fdp-button", inputs: ["glyphPosition", "label", "glyph", "buttonType", "title", "ariaSelected", "ariaDisabled", "ariaExpanded", "ariaControlsId", "ariaPressed", "name", "type", "value"], outputs: ["buttonClicked"] }, { kind: "component", type: i6.EventPreviewComponent, selector: "bc-event-preview", inputs: ["event", "calendarFields", "popover", "popover2", "canEdit", "canDelete"], outputs: ["deleteEvent", "editEvent"] }, { kind: "component", type: i7.DayNumberBoxComponent, selector: "bc-day-number-box", inputs: ["isWeekMode", "isSingleDay", "day", "isPickerMode", "itemInRange", "isActive"], outputs: ["dayClick", "dayMouseDown", "dayMouseUp", "dayMouseMove"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
27
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: DayEventListComponent, decorators: [{
28
+ type: Component,
29
+ args: [{ selector: 'bc-day-event-list', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div fd-bar [barDesign]=\"'header-with-subheader'\">\n <div fd-bar-left>\n <fd-bar-element>\n <fdp-button glyph=\"decline\" [buttonType]=\"'transparent'\" (click)=\"onClosePopover(popover)\"></fdp-button>\n </fd-bar-element>\n </div>\n <div fd-bar-middle>\n <fd-bar-element>\n {{ weekDays[day.dayInWeek] }}\n </fd-bar-element>\n </div>\n <div fd-bar-right>\n <fd-bar-element> </fd-bar-element>\n </div>\n</div>\n<div fd-bar [barDesign]=\"'subheader'\">\n <div fd-bar-middle>\n <fd-bar-element [fullWidth]=\"true\">\n <bc-day-number-box [day]=\"day\" [isWeekMode]=\"true\"></bc-day-number-box>\n </fd-bar-element>\n </div>\n</div>\n<ul fd-list>\n <li fd-list-item *ngFor=\"let task of day.tasks\" class=\"task-start-end\" (click)=\"popoverPreview.open()\">\n <span [ngClass]=\"{ 'end-day': rtl, 'start-day': !rtl }\" *ngIf=\"task.isMiddle && !task.isStartDay\"></span>\n <span class=\"middle-day\">{{ task.event[calendarFields.Title] }}</span>\n <span\n [ngClass]=\"{ 'start-day': rtl, 'end-day': !rtl }\"\n *ngIf=\"(task.isMiddle || task.isStartDay) && !task.isEndDay\"\n ></span>\n <fd-popover\n #popoverPreview\n placement=\"bottom\"\n [mobile]=\"deviceSize === 's'\"\n [focusTrapped]=\"true\"\n [focusAutoCapture]=\"true\"\n [title]=\"task.event[calendarFields.Title]\"\n >\n <bc-event-preview\n [event]=\"task.event\"\n [calendarFields]=\"calendarFields\"\n [popover]=\"popoverPreview\"\n [canDelete]=\"canDelete\"\n [canEdit]=\"canEdit\"\n [popover2]=\"popover\"\n (deleteEvent)=\"deleteEvent.emit($event)\"\n (editEvent)=\"editEvent.emit($event)\"\n ></bc-event-preview>\n </fd-popover>\n </li>\n</ul>\n", styles: [".task-start-end{cursor:pointer}.start-day{width:0;height:0;border-top:10px solid transparent;border-right:10px solid var(--sapButton_Emphasized_BorderColor, #0a6ed1);border-bottom:10px solid transparent}.middle-day{width:100%;min-width:200px;height:20px;background-color:var(--sapButton_Emphasized_Background, #0a6ed1);color:var(--sapButton_Emphasized_TextColor, #fff);text-align:center}.end-day{width:0;height:0;border-top:10px solid transparent;border-left:10px solid var(--sapButton_Emphasized_BorderColor, #0a6ed1);border-bottom:10px solid transparent}.event-list-number-day{width:40px;height:40px;flex-grow:0;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-grow:0!important}.event-list-number-day:hover{color:var(--sapButton_Hover_TextColor, #0854a0);background-color:var(--sapButton_Hover_Background, #ebf5fe);cursor:pointer}::ng-deep .fd-form-item{flex-direction:row!important}\n"] }]
30
+ }], propDecorators: { day: [{
31
+ type: Input
32
+ }], deviceSize: [{
33
+ type: Input
34
+ }], weekDays: [{
35
+ type: Input
36
+ }], calendarFields: [{
37
+ type: Input
38
+ }], rtl: [{
39
+ type: Input
40
+ }], canDelete: [{
41
+ type: Input
42
+ }], canEdit: [{
43
+ type: Input
44
+ }], popover: [{
45
+ type: Input
46
+ }], deleteEvent: [{
47
+ type: Output
48
+ }], editEvent: [{
49
+ type: Output
50
+ }], openPopOver: [{
51
+ type: Output
52
+ }] } });
53
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF5LWV2ZW50LWxpc3QuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFyc2EtY2FsZW5kYXIvc3JjL2xpYi9kYXktZXZlbnQtbGlzdC9kYXktZXZlbnQtbGlzdC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9iYXJzYS1jYWxlbmRhci9zcmMvbGliL2RheS1ldmVudC1saXN0L2RheS1ldmVudC1saXN0LmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFaEcsT0FBTyxFQUFFLGFBQWEsRUFBdUMsTUFBTSxzQkFBc0IsQ0FBQzs7Ozs7Ozs7O0FBUTFGLE1BQU0sT0FBTyxxQkFBc0IsU0FBUSxhQUFhO0lBTnhEOztRQWVjLGdCQUFXLEdBQUcsSUFBSSxZQUFZLEVBQXVCLENBQUM7UUFDdEQsY0FBUyxHQUFHLElBQUksWUFBWSxFQUF1QixDQUFDO1FBQ3BELGdCQUFXLEdBQUcsSUFBSSxZQUFZLEVBQU8sQ0FBQztLQVFuRDtJQU5HLGNBQWMsQ0FBQyxPQUFPLEVBQUUsUUFBUztRQUM3QixPQUFPLENBQUMsS0FBSyxFQUFFLENBQUM7UUFDaEIsSUFBSSxRQUFRLEVBQUU7WUFDVixRQUFRLENBQUMsS0FBSyxFQUFFLENBQUM7U0FDcEI7SUFDTCxDQUFDOztrSEFsQlEscUJBQXFCO3NHQUFyQixxQkFBcUIsbVdDVmxDLGs5REFtREE7MkZEekNhLHFCQUFxQjtrQkFOakMsU0FBUzsrQkFDSSxtQkFBbUIsbUJBR1osdUJBQXVCLENBQUMsTUFBTTs4QkFHdEMsR0FBRztzQkFBWCxLQUFLO2dCQUNHLFVBQVU7c0JBQWxCLEtBQUs7Z0JBQ0csUUFBUTtzQkFBaEIsS0FBSztnQkFDRyxjQUFjO3NCQUF0QixLQUFLO2dCQUNHLEdBQUc7c0JBQVgsS0FBSztnQkFDRyxTQUFTO3NCQUFqQixLQUFLO2dCQUNHLE9BQU87c0JBQWYsS0FBSztnQkFDRyxPQUFPO3NCQUFmLEtBQUs7Z0JBQ0ksV0FBVztzQkFBcEIsTUFBTTtnQkFDRyxTQUFTO3NCQUFsQixNQUFNO2dCQUNHLFdBQVc7c0JBQXBCLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIElucHV0LCBPdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgQmFzZUNvbXBvbmVudCwgQ2FsZW5kYXJGaWVsZHMsIE1ldGFvYmplY3REYXRhTW9kZWwgfSBmcm9tICdiYXJzYS1ub3Zpbi1yYXktY29yZSc7XG5pbXBvcnQgeyBEYXkgfSBmcm9tICcuLi9tb2RlbHMnO1xuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICdiYy1kYXktZXZlbnQtbGlzdCcsXG4gICAgdGVtcGxhdGVVcmw6ICcuL2RheS1ldmVudC1saXN0LmNvbXBvbmVudC5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnLi9kYXktZXZlbnQtbGlzdC5jb21wb25lbnQuc2NzcyddLFxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoXG59KVxuZXhwb3J0IGNsYXNzIERheUV2ZW50TGlzdENvbXBvbmVudCBleHRlbmRzIEJhc2VDb21wb25lbnQge1xuICAgIEBJbnB1dCgpIGRheTogRGF5O1xuICAgIEBJbnB1dCgpIGRldmljZVNpemU6IHN0cmluZztcbiAgICBASW5wdXQoKSB3ZWVrRGF5czogc3RyaW5nW107XG4gICAgQElucHV0KCkgY2FsZW5kYXJGaWVsZHM6IENhbGVuZGFyRmllbGRzO1xuICAgIEBJbnB1dCgpIHJ0bDogYm9vbGVhbjtcbiAgICBASW5wdXQoKSBjYW5EZWxldGU6IGJvb2xlYW47XG4gICAgQElucHV0KCkgY2FuRWRpdDogYm9vbGVhbjtcbiAgICBASW5wdXQoKSBwb3BvdmVyOiBhbnk7XG4gICAgQE91dHB1dCgpIGRlbGV0ZUV2ZW50ID0gbmV3IEV2ZW50RW1pdHRlcjxNZXRhb2JqZWN0RGF0YU1vZGVsPigpO1xuICAgIEBPdXRwdXQoKSBlZGl0RXZlbnQgPSBuZXcgRXZlbnRFbWl0dGVyPE1ldGFvYmplY3REYXRhTW9kZWw+KCk7XG4gICAgQE91dHB1dCgpIG9wZW5Qb3BPdmVyID0gbmV3IEV2ZW50RW1pdHRlcjxhbnk+KCk7XG5cbiAgICBvbkNsb3NlUG9wb3Zlcihwb3BvdmVyLCBwb3BvdmVyMj8pOiB2b2lkIHtcbiAgICAgICAgcG9wb3Zlci5jbG9zZSgpO1xuICAgICAgICBpZiAocG9wb3ZlcjIpIHtcbiAgICAgICAgICAgIHBvcG92ZXIyLmNsb3NlKCk7XG4gICAgICAgIH1cbiAgICB9XG59XG4iLCI8ZGl2IGZkLWJhciBbYmFyRGVzaWduXT1cIidoZWFkZXItd2l0aC1zdWJoZWFkZXInXCI+XG4gICAgPGRpdiBmZC1iYXItbGVmdD5cbiAgICAgICAgPGZkLWJhci1lbGVtZW50PlxuICAgICAgICAgICAgPGZkcC1idXR0b24gZ2x5cGg9XCJkZWNsaW5lXCIgW2J1dHRvblR5cGVdPVwiJ3RyYW5zcGFyZW50J1wiIChjbGljayk9XCJvbkNsb3NlUG9wb3Zlcihwb3BvdmVyKVwiPjwvZmRwLWJ1dHRvbj5cbiAgICAgICAgPC9mZC1iYXItZWxlbWVudD5cbiAgICA8L2Rpdj5cbiAgICA8ZGl2IGZkLWJhci1taWRkbGU+XG4gICAgICAgIDxmZC1iYXItZWxlbWVudD5cbiAgICAgICAgICAgIHt7IHdlZWtEYXlzW2RheS5kYXlJbldlZWtdIH19XG4gICAgICAgIDwvZmQtYmFyLWVsZW1lbnQ+XG4gICAgPC9kaXY+XG4gICAgPGRpdiBmZC1iYXItcmlnaHQ+XG4gICAgICAgIDxmZC1iYXItZWxlbWVudD4gPC9mZC1iYXItZWxlbWVudD5cbiAgICA8L2Rpdj5cbjwvZGl2PlxuPGRpdiBmZC1iYXIgW2JhckRlc2lnbl09XCInc3ViaGVhZGVyJ1wiPlxuICAgIDxkaXYgZmQtYmFyLW1pZGRsZT5cbiAgICAgICAgPGZkLWJhci1lbGVtZW50IFtmdWxsV2lkdGhdPVwidHJ1ZVwiPlxuICAgICAgICAgICAgPGJjLWRheS1udW1iZXItYm94IFtkYXldPVwiZGF5XCIgW2lzV2Vla01vZGVdPVwidHJ1ZVwiPjwvYmMtZGF5LW51bWJlci1ib3g+XG4gICAgICAgIDwvZmQtYmFyLWVsZW1lbnQ+XG4gICAgPC9kaXY+XG48L2Rpdj5cbjx1bCBmZC1saXN0PlxuICAgIDxsaSBmZC1saXN0LWl0ZW0gKm5nRm9yPVwibGV0IHRhc2sgb2YgZGF5LnRhc2tzXCIgY2xhc3M9XCJ0YXNrLXN0YXJ0LWVuZFwiIChjbGljayk9XCJwb3BvdmVyUHJldmlldy5vcGVuKClcIj5cbiAgICAgICAgPHNwYW4gW25nQ2xhc3NdPVwieyAnZW5kLWRheSc6IHJ0bCwgJ3N0YXJ0LWRheSc6ICFydGwgfVwiICpuZ0lmPVwidGFzay5pc01pZGRsZSAmJiAhdGFzay5pc1N0YXJ0RGF5XCI+PC9zcGFuPlxuICAgICAgICA8c3BhbiBjbGFzcz1cIm1pZGRsZS1kYXlcIj57eyB0YXNrLmV2ZW50W2NhbGVuZGFyRmllbGRzLlRpdGxlXSB9fTwvc3Bhbj5cbiAgICAgICAgPHNwYW5cbiAgICAgICAgICAgIFtuZ0NsYXNzXT1cInsgJ3N0YXJ0LWRheSc6IHJ0bCwgJ2VuZC1kYXknOiAhcnRsIH1cIlxuICAgICAgICAgICAgKm5nSWY9XCIodGFzay5pc01pZGRsZSB8fCB0YXNrLmlzU3RhcnREYXkpICYmICF0YXNrLmlzRW5kRGF5XCJcbiAgICAgICAgPjwvc3Bhbj5cbiAgICAgICAgPGZkLXBvcG92ZXJcbiAgICAgICAgICAgICNwb3BvdmVyUHJldmlld1xuICAgICAgICAgICAgcGxhY2VtZW50PVwiYm90dG9tXCJcbiAgICAgICAgICAgIFttb2JpbGVdPVwiZGV2aWNlU2l6ZSA9PT0gJ3MnXCJcbiAgICAgICAgICAgIFtmb2N1c1RyYXBwZWRdPVwidHJ1ZVwiXG4gICAgICAgICAgICBbZm9jdXNBdXRvQ2FwdHVyZV09XCJ0cnVlXCJcbiAgICAgICAgICAgIFt0aXRsZV09XCJ0YXNrLmV2ZW50W2NhbGVuZGFyRmllbGRzLlRpdGxlXVwiXG4gICAgICAgID5cbiAgICAgICAgICAgIDxiYy1ldmVudC1wcmV2aWV3XG4gICAgICAgICAgICAgICAgW2V2ZW50XT1cInRhc2suZXZlbnRcIlxuICAgICAgICAgICAgICAgIFtjYWxlbmRhckZpZWxkc109XCJjYWxlbmRhckZpZWxkc1wiXG4gICAgICAgICAgICAgICAgW3BvcG92ZXJdPVwicG9wb3ZlclByZXZpZXdcIlxuICAgICAgICAgICAgICAgIFtjYW5EZWxldGVdPVwiY2FuRGVsZXRlXCJcbiAgICAgICAgICAgICAgICBbY2FuRWRpdF09XCJjYW5FZGl0XCJcbiAgICAgICAgICAgICAgICBbcG9wb3ZlcjJdPVwicG9wb3ZlclwiXG4gICAgICAgICAgICAgICAgKGRlbGV0ZUV2ZW50KT1cImRlbGV0ZUV2ZW50LmVtaXQoJGV2ZW50KVwiXG4gICAgICAgICAgICAgICAgKGVkaXRFdmVudCk9XCJlZGl0RXZlbnQuZW1pdCgkZXZlbnQpXCJcbiAgICAgICAgICAgID48L2JjLWV2ZW50LXByZXZpZXc+XG4gICAgICAgIDwvZmQtcG9wb3Zlcj5cbiAgICA8L2xpPlxuPC91bD5cbiJdfQ==