barsa-calendar 2.3.147 → 2.3.149

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.
@@ -2,7 +2,7 @@ import * as i0 from '@angular/core';
2
2
  import { inject, Injectable, Pipe, EventEmitter, signal, Output, Input, ChangeDetectionStrategy, Component, HostListener, HostBinding, ViewChild, ChangeDetectorRef, DOCUMENT, ComponentFactoryResolver, NO_ERRORS_SCHEMA, NgModule } from '@angular/core';
3
3
  import { takeUntil, distinctUntilChanged, map, switchMap } from 'rxjs/operators';
4
4
  import * as i2 from 'barsa-novin-ray-core';
5
- import { LogService, getDateService, getUniqueId, BaseComponent, PreventDefaulEvent, PortalService, BarsaApi, bodyClick, DateService, BbbTranslatePipe, removeDynamicStyle, addDynamicVariableTo, ReportViewBaseComponent, BaseModule, DynamicComponentService, BarsaNovinRayCoreModule } from 'barsa-novin-ray-core';
5
+ import { LogService, getDateService, getUniqueId, BaseComponent, PreventDefaulEvent, SortDirection, PortalService, BarsaApi, bodyClick, DateService, BbbTranslatePipe, removeDynamicStyle, addDynamicVariableTo, ReportViewBaseComponent, BaseModule, DynamicComponentService, BarsaNovinRayCoreModule } from 'barsa-novin-ray-core';
6
6
  import { Subject, BehaviorSubject, combineLatest, of } from 'rxjs';
7
7
  import moment from 'moment/moment';
8
8
  import * as i1 from '@angular/common';
@@ -689,7 +689,7 @@ class CalendarListContainerComponent extends BaseComponent {
689
689
  super(...arguments);
690
690
  this.deleteEvent = new EventEmitter();
691
691
  this.editEvent = new EventEmitter();
692
- this.eventList = signal({});
692
+ this.eventList = signal([]);
693
693
  }
694
694
  ngOnChanges(changes) {
695
695
  const { days } = changes;
@@ -705,14 +705,20 @@ class CalendarListContainerComponent extends BaseComponent {
705
705
  days.forEach((c) => c.tasks.forEach((task) => {
706
706
  temp[task.event.Id] = task.event;
707
707
  }));
708
- this.eventList.set(temp);
708
+ const sorted = Object.entries(temp).sort(([, a], [, b]) => {
709
+ const aTime = a[this.calendarFields.StartDate]?.getTime() ?? Number.MAX_SAFE_INTEGER;
710
+ const bTime = b[this.calendarFields.StartDate]?.getTime() ?? Number.MAX_SAFE_INTEGER;
711
+ return aTime - bTime;
712
+ });
713
+ const x = sorted.map(([_, v]) => v);
714
+ this.eventList.set(x);
709
715
  }
710
716
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.0.6", ngImport: i0, type: CalendarListContainerComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
711
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "20.0.6", type: CalendarListContainerComponent, isStandalone: false, selector: "bc-calendar-list-container", inputs: { canEdit: "canEdit", canView: "canView", canDelete: "canDelete", days: "days", calendarFields: "calendarFields" }, outputs: { deleteEvent: "deleteEvent", editEvent: "editEvent" }, usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<ng-container *ngTemplateOutlet=\"renderView; context: { $implicit: eventList() | keyvalue }\"> </ng-container>\r\n<ng-template #renderView let-eventList>\r\n @if(!eventList.length){\r\n <div class=\"tw-w-full tw-text-center tw-py-4\">({{ 'NoData' | bbbTranslate }})</div>\r\n } @else{\r\n <ul fd-list [subline]=\"true\">\r\n @for (event of eventList; track trackById($index,event.value)) {\r\n <li fd-list-item [interactive]=\"false\">\r\n <!-- <fd-avatar size=\"s\" label=\"Jane Doe\"></fd-avatar> -->\r\n <div fd-list-content>\r\n <div fd-list-title>\r\n {{ event.value[calendarFields.Title] }}\r\n </div>\r\n <div fd-list-subline>{{ event.value[calendarFields.Notes] }}</div>\r\n <div\r\n fd-list-byline\r\n [twoCol]=\"true\"\r\n class=\"time-wrapper tw-flex tw-justify-between tw-w-full tw-max-w-[26rem] tw-flex-wrap\"\r\n >\r\n <div\r\n fd-generic-tag\r\n [name]=\"'Gantt_Start' | bbbTranslate\"\r\n type=\"information\"\r\n [value]=\"event.value[calendarFields.StartDate + '$Caption']\"\r\n ></div>\r\n <div\r\n fd-generic-tag\r\n type=\"warning\"\r\n [name]=\"'Gantt_EndDate' | bbbTranslate\"\r\n [value]=\"event.value[calendarFields.EndDate + '$Caption']\"\r\n ></div>\r\n </div>\r\n </div>\r\n <div>\r\n @if(canEdit || canView){\r\n <button\r\n fd-button\r\n glyph=\"edit\"\r\n fdType=\"transparent\"\r\n [title]=\"'Edit' | bbbTranslate\"\r\n (click)=\"editEvent.emit(event.value)\"\r\n ></button>\r\n } @if(canDelete){\r\n <button\r\n fd-button\r\n glyph=\"delete\"\r\n fdType=\"transparent\"\r\n [title]=\"'Delete' | bbbTranslate\"\r\n (click)=\"deleteEvent.emit(event.value)\"\r\n ></button>\r\n }\r\n </div>\r\n </li>\r\n }\r\n </ul>\r\n }\r\n</ng-template>\r\n", styles: [":host{--sapFontSemiboldDuplexFamily:\"B-Font Medium\" }.time-wrapper ::ng-deep fd-icon{display:none}\n"], dependencies: [{ kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i3.ButtonComponent, selector: "button[fd-button], a[fd-button], span[fd-button]", inputs: ["class", "id"], exportAs: ["fd-button"] }, { kind: "component", type: i4.ListComponent, selector: "[fd-list], [fdList]", inputs: ["dropdownMode", "multiInputMode", "mobileMode", "hasMessage", "noBorder", "navigationIndicator", "selection", "keyboardSupport", "byline", "subline", "theme", "unreadIndicator", "role", "settingsList", "settingsListFooter"], outputs: ["focusEscapeList"] }, { kind: "component", type: i4.ListItemComponent, selector: "[fdListItem] ,[fd-list-item]", inputs: ["selected", "noData", "action", "interactive", "growing", "counter", "active", "unread", "byline", "ariaRole", "id", "preventClick", "settingsListTpl"], outputs: ["keyDown"], exportAs: ["fdListItem"] }, { kind: "directive", type: i4.ListTitleDirective, selector: "[fd-list-title], [fdListTitle]", inputs: ["wrap", "truncate"] }, { kind: "directive", type: i4.ListBylineDirective, selector: "[fdListByline], [fd-list-byline]", inputs: ["twoCol", "wrap"] }, { kind: "directive", type: i4.ListContentDirective, selector: "[fdListContent], [fd-list-content]", inputs: ["twoCol"] }, { kind: "directive", type: i4.ListSublineDirective, selector: "[fdListSubline], [fd-list-subline]", inputs: ["truncate"] }, { kind: "component", type: i4$1.GenericTagComponent, selector: "[fd-generic-tag]", inputs: ["class", "type", "name", "value", "ariaRoleDescription"] }, { kind: "pipe", type: i1.KeyValuePipe, name: "keyvalue" }, { kind: "pipe", type: i2.BbbTranslatePipe, name: "bbbTranslate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
717
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "20.0.6", type: CalendarListContainerComponent, isStandalone: false, selector: "bc-calendar-list-container", inputs: { canEdit: "canEdit", canView: "canView", canDelete: "canDelete", days: "days", calendarFields: "calendarFields" }, outputs: { deleteEvent: "deleteEvent", editEvent: "editEvent" }, usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<ng-container *ngTemplateOutlet=\"renderView; context: { $implicit: eventList() }\"> </ng-container>\r\n<ng-template #renderView let-eventList>\r\n @if(!eventList.length){\r\n <div class=\"tw-w-full tw-text-center tw-py-4\">({{ 'NoData' | bbbTranslate }})</div>\r\n } @else{\r\n <ul fd-list [subline]=\"true\">\r\n @for (event of eventList; track trackById($index,event)) {\r\n <li fd-list-item [interactive]=\"false\">\r\n <!-- <fd-avatar size=\"s\" label=\"Jane Doe\"></fd-avatar> -->\r\n <div fd-list-content>\r\n <div fd-list-title>\r\n {{ event[calendarFields.Title] }}\r\n </div>\r\n <div fd-list-subline>{{ event[calendarFields.Notes] }}</div>\r\n <div\r\n fd-list-byline\r\n [twoCol]=\"true\"\r\n class=\"time-wrapper tw-flex tw-justify-between tw-w-full tw-max-w-[26rem] tw-flex-wrap\"\r\n >\r\n <div\r\n fd-generic-tag\r\n [name]=\"'Gantt_Start' | bbbTranslate\"\r\n type=\"information\"\r\n [value]=\"event[calendarFields.StartDate + '$Caption']\"\r\n ></div>\r\n <div\r\n fd-generic-tag\r\n type=\"warning\"\r\n [name]=\"'Gantt_EndDate' | bbbTranslate\"\r\n [value]=\"event[calendarFields.EndDate + '$Caption']\"\r\n ></div>\r\n </div>\r\n </div>\r\n <div>\r\n @if(canEdit || canView){\r\n <button\r\n fd-button\r\n glyph=\"edit\"\r\n fdType=\"transparent\"\r\n [title]=\"'Edit' | bbbTranslate\"\r\n (click)=\"editEvent.emit(event)\"\r\n ></button>\r\n } @if(canDelete){\r\n <button\r\n fd-button\r\n glyph=\"delete\"\r\n fdType=\"transparent\"\r\n [title]=\"'Delete' | bbbTranslate\"\r\n (click)=\"deleteEvent.emit(event)\"\r\n ></button>\r\n }\r\n </div>\r\n </li>\r\n }\r\n </ul>\r\n }\r\n</ng-template>\r\n", styles: [":host{--sapFontSemiboldDuplexFamily:\"B-Font Medium\" }.time-wrapper ::ng-deep fd-icon{display:none}\n"], dependencies: [{ kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i3.ButtonComponent, selector: "button[fd-button], a[fd-button], span[fd-button]", inputs: ["class", "id"], exportAs: ["fd-button"] }, { kind: "component", type: i4.ListComponent, selector: "[fd-list], [fdList]", inputs: ["dropdownMode", "multiInputMode", "mobileMode", "hasMessage", "noBorder", "navigationIndicator", "selection", "keyboardSupport", "byline", "subline", "theme", "unreadIndicator", "role", "settingsList", "settingsListFooter"], outputs: ["focusEscapeList"] }, { kind: "component", type: i4.ListItemComponent, selector: "[fdListItem] ,[fd-list-item]", inputs: ["selected", "noData", "action", "interactive", "growing", "counter", "active", "unread", "byline", "ariaRole", "id", "preventClick", "settingsListTpl"], outputs: ["keyDown"], exportAs: ["fdListItem"] }, { kind: "directive", type: i4.ListTitleDirective, selector: "[fd-list-title], [fdListTitle]", inputs: ["wrap", "truncate"] }, { kind: "directive", type: i4.ListBylineDirective, selector: "[fdListByline], [fd-list-byline]", inputs: ["twoCol", "wrap"] }, { kind: "directive", type: i4.ListContentDirective, selector: "[fdListContent], [fd-list-content]", inputs: ["twoCol"] }, { kind: "directive", type: i4.ListSublineDirective, selector: "[fdListSubline], [fd-list-subline]", inputs: ["truncate"] }, { kind: "component", type: i4$1.GenericTagComponent, selector: "[fd-generic-tag]", inputs: ["class", "type", "name", "value", "ariaRoleDescription"] }, { kind: "pipe", type: i2.BbbTranslatePipe, name: "bbbTranslate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
712
718
  }
713
719
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.0.6", ngImport: i0, type: CalendarListContainerComponent, decorators: [{
714
720
  type: Component,
715
- args: [{ selector: 'bc-calendar-list-container', changeDetection: ChangeDetectionStrategy.OnPush, standalone: false, template: "<ng-container *ngTemplateOutlet=\"renderView; context: { $implicit: eventList() | keyvalue }\"> </ng-container>\r\n<ng-template #renderView let-eventList>\r\n @if(!eventList.length){\r\n <div class=\"tw-w-full tw-text-center tw-py-4\">({{ 'NoData' | bbbTranslate }})</div>\r\n } @else{\r\n <ul fd-list [subline]=\"true\">\r\n @for (event of eventList; track trackById($index,event.value)) {\r\n <li fd-list-item [interactive]=\"false\">\r\n <!-- <fd-avatar size=\"s\" label=\"Jane Doe\"></fd-avatar> -->\r\n <div fd-list-content>\r\n <div fd-list-title>\r\n {{ event.value[calendarFields.Title] }}\r\n </div>\r\n <div fd-list-subline>{{ event.value[calendarFields.Notes] }}</div>\r\n <div\r\n fd-list-byline\r\n [twoCol]=\"true\"\r\n class=\"time-wrapper tw-flex tw-justify-between tw-w-full tw-max-w-[26rem] tw-flex-wrap\"\r\n >\r\n <div\r\n fd-generic-tag\r\n [name]=\"'Gantt_Start' | bbbTranslate\"\r\n type=\"information\"\r\n [value]=\"event.value[calendarFields.StartDate + '$Caption']\"\r\n ></div>\r\n <div\r\n fd-generic-tag\r\n type=\"warning\"\r\n [name]=\"'Gantt_EndDate' | bbbTranslate\"\r\n [value]=\"event.value[calendarFields.EndDate + '$Caption']\"\r\n ></div>\r\n </div>\r\n </div>\r\n <div>\r\n @if(canEdit || canView){\r\n <button\r\n fd-button\r\n glyph=\"edit\"\r\n fdType=\"transparent\"\r\n [title]=\"'Edit' | bbbTranslate\"\r\n (click)=\"editEvent.emit(event.value)\"\r\n ></button>\r\n } @if(canDelete){\r\n <button\r\n fd-button\r\n glyph=\"delete\"\r\n fdType=\"transparent\"\r\n [title]=\"'Delete' | bbbTranslate\"\r\n (click)=\"deleteEvent.emit(event.value)\"\r\n ></button>\r\n }\r\n </div>\r\n </li>\r\n }\r\n </ul>\r\n }\r\n</ng-template>\r\n", styles: [":host{--sapFontSemiboldDuplexFamily:\"B-Font Medium\" }.time-wrapper ::ng-deep fd-icon{display:none}\n"] }]
721
+ args: [{ selector: 'bc-calendar-list-container', changeDetection: ChangeDetectionStrategy.OnPush, standalone: false, template: "<ng-container *ngTemplateOutlet=\"renderView; context: { $implicit: eventList() }\"> </ng-container>\r\n<ng-template #renderView let-eventList>\r\n @if(!eventList.length){\r\n <div class=\"tw-w-full tw-text-center tw-py-4\">({{ 'NoData' | bbbTranslate }})</div>\r\n } @else{\r\n <ul fd-list [subline]=\"true\">\r\n @for (event of eventList; track trackById($index,event)) {\r\n <li fd-list-item [interactive]=\"false\">\r\n <!-- <fd-avatar size=\"s\" label=\"Jane Doe\"></fd-avatar> -->\r\n <div fd-list-content>\r\n <div fd-list-title>\r\n {{ event[calendarFields.Title] }}\r\n </div>\r\n <div fd-list-subline>{{ event[calendarFields.Notes] }}</div>\r\n <div\r\n fd-list-byline\r\n [twoCol]=\"true\"\r\n class=\"time-wrapper tw-flex tw-justify-between tw-w-full tw-max-w-[26rem] tw-flex-wrap\"\r\n >\r\n <div\r\n fd-generic-tag\r\n [name]=\"'Gantt_Start' | bbbTranslate\"\r\n type=\"information\"\r\n [value]=\"event[calendarFields.StartDate + '$Caption']\"\r\n ></div>\r\n <div\r\n fd-generic-tag\r\n type=\"warning\"\r\n [name]=\"'Gantt_EndDate' | bbbTranslate\"\r\n [value]=\"event[calendarFields.EndDate + '$Caption']\"\r\n ></div>\r\n </div>\r\n </div>\r\n <div>\r\n @if(canEdit || canView){\r\n <button\r\n fd-button\r\n glyph=\"edit\"\r\n fdType=\"transparent\"\r\n [title]=\"'Edit' | bbbTranslate\"\r\n (click)=\"editEvent.emit(event)\"\r\n ></button>\r\n } @if(canDelete){\r\n <button\r\n fd-button\r\n glyph=\"delete\"\r\n fdType=\"transparent\"\r\n [title]=\"'Delete' | bbbTranslate\"\r\n (click)=\"deleteEvent.emit(event)\"\r\n ></button>\r\n }\r\n </div>\r\n </li>\r\n }\r\n </ul>\r\n }\r\n</ng-template>\r\n", styles: [":host{--sapFontSemiboldDuplexFamily:\"B-Font Medium\" }.time-wrapper ::ng-deep fd-icon{display:none}\n"] }]
716
722
  }], propDecorators: { canEdit: [{
717
723
  type: Input
718
724
  }], canView: [{
@@ -1172,6 +1178,7 @@ class CalendarMonthComponent extends BaseComponent {
1172
1178
  this.dayMouseUp = new EventEmitter();
1173
1179
  this.dayMouseDown = new EventEmitter();
1174
1180
  this.showEvent = new EventEmitter();
1181
+ this.sortDirection = SortDirection;
1175
1182
  this.numberOfWeek = signal([]);
1176
1183
  this.dayHeight = signal(CalendarMonthComponent.DEFAULT_DAY_ROW_HEIGHT_PX);
1177
1184
  this.maxTaskCount = signal(0);
@@ -1355,11 +1362,11 @@ class CalendarMonthComponent extends BaseComponent {
1355
1362
  this.weekTasksArray = weekTasksArray;
1356
1363
  }
1357
1364
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.0.6", ngImport: i0, type: CalendarMonthComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
1358
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "20.0.6", type: CalendarMonthComponent, isStandalone: false, selector: "bc-calendar-month", inputs: { monthWeeksCount: "monthWeeksCount", weekDays: "weekDays", weekDaysMin: "weekDaysMin", today: "today", containerHeight: "containerHeight", dayRowHeightPx: "dayRowHeightPx", 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", viewMode: "viewMode" }, outputs: { editEvent: "editEvent", deleteEvent: "deleteEvent", daySelect: "daySelect", dayClick: "dayClick", dayMouseMove: "dayMouseMove", dayMouseUp: "dayMouseUp", dayMouseDown: "dayMouseDown", showEvent: "showEvent" }, usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<ng-container *ngTemplateOutlet=\"viewMode === 'list' ? listView : calendarView\"></ng-container>\r\n<ng-template #listView>\r\n <bc-calendar-list-container\r\n [calendarFields]=\"calendarFields\"\r\n [days]=\"days\"\r\n [canDelete]=\"canDelete\"\r\n [canEdit]=\"canEdit\"\r\n [canView]=\"canView\"\r\n (editEvent)=\"editEvent.emit($event)\"\r\n (deleteEvent)=\"deleteEvent.emit($event)\"\r\n ></bc-calendar-list-container>\r\n</ng-template>\r\n<ng-template #calendarView>\r\n <table\r\n fd-table\r\n class=\"table-header\"\r\n [fdCompact]\r\n [attr.picker]=\"datePicker\"\r\n >\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\r\n [style.height.px]=\"dayHeight()\"\r\n fd-table-cell\r\n colspan=\"7\"\r\n [style.border]=\"isPickerMode ? 'none' : null\"\r\n >\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<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.index) {\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':\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 !tw-text-white':!isPickerMode && 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.index) {\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%\" (dblclick)=\"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{height:100%}.table-header td{padding:0!important}.table-header>thead>tr>th:last-child{border-right:var(--sapList_BorderWidth, .0625rem) solid var(--sapList_BorderColor, #e5e5e5)}.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 td{overflow:hidden}thead tr{border-bottom:none!important}thead tr th{text-align:center!important;background-color:var(--sapList_Background, #fff);height:1rem;border-bottom:none;border-top:none}.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;border-color:var(--sapList_BorderColor)}.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: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2.MobileDirective, selector: "[mobile]" }, { kind: "directive", type: i3$2.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: i3.ButtonComponent, selector: "button[fd-button], a[fd-button], span[fd-button]", inputs: ["class", "id"], exportAs: ["fd-button"] }, { kind: "component", type: i5.PopoverComponent, selector: "fd-popover", inputs: ["title", "trigger", "fixedPosition", "id", "mobile", "mobileConfig", "preventSpaceKeyScroll"] }, { kind: "component", type: i6.TableComponent, selector: "table[fd-table]", inputs: ["noBorderX", "noBorderY", "noOuterBorder", "topBorder", "popIn", "responsive", "keys", "allCellsFocusable"], exportAs: ["fd-table"] }, { kind: "directive", type: i6.TableHeaderDirective, selector: "[fdTableHeader], [fd-table-header]", inputs: ["noBorderX", "noBorderY", "nonInteractive"] }, { kind: "directive", type: i6.TableBodyDirective, selector: "[fdTableBody], [fd-table-body]", inputs: ["noBorderX", "noBorderY"] }, { kind: "directive", type: i6.TableRowDirective, selector: "[fdTableRow], [fd-table-row]", inputs: ["activable", "highlightActive", "hoverable", "focusable", "main", "secondary", "active"] }, { kind: "directive", type: i6.TableCellDirective, selector: "[fdTableCell], [fd-table-cell]", inputs: ["noBorderX", "noBorderY", "activable", "focusable", "hoverable", "fitContent", "noPadding", "noData", "nonInteractive", "key"] }, { kind: "component", type: CalendarListContainerComponent, selector: "bc-calendar-list-container", inputs: ["canEdit", "canView", "canDelete", "days", "calendarFields"], outputs: ["deleteEvent", "editEvent"] }, { kind: "component", type: DayNumberBoxComponent, selector: "bc-day-number-box", inputs: ["isWeekMode", "isSingleDay", "day", "isPickerMode", "itemInRange", "isActive"], outputs: ["dayClick", "dayMouseDown", "dayMouseUp", "dayMouseMove"] }, { kind: "component", type: EventButtonComponent, selector: "bc-event-button", inputs: ["buttonTemplate", "calendarFields", "task", "rtl", "canDelete", "canEdit", "canView", "index", "deviceSize"], outputs: ["deleteEvent", "editEvent", "openPopoverChange"] }, { kind: "component", type: DayEventListComponent, selector: "bc-day-event-list", inputs: ["day", "deviceSize", "weekDays", "calendarFields", "rtl", "canDelete", "canEdit", "canView", "popover"], outputs: ["deleteEvent", "editEvent", "openPopOver"] }, { kind: "pipe", type: i1.SlicePipe, name: "slice" }, { kind: "pipe", type: i2.BbbTranslatePipe, name: "bbbTranslate" }, { kind: "pipe", type: DaysInWeekPipe, name: "daysInWeek" }, { kind: "pipe", type: EqualDatePipe, name: "equalDate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
1365
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "20.0.6", type: CalendarMonthComponent, isStandalone: false, selector: "bc-calendar-month", inputs: { monthWeeksCount: "monthWeeksCount", weekDays: "weekDays", weekDaysMin: "weekDaysMin", today: "today", containerHeight: "containerHeight", dayRowHeightPx: "dayRowHeightPx", 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", viewMode: "viewMode" }, outputs: { editEvent: "editEvent", deleteEvent: "deleteEvent", daySelect: "daySelect", dayClick: "dayClick", dayMouseMove: "dayMouseMove", dayMouseUp: "dayMouseUp", dayMouseDown: "dayMouseDown", showEvent: "showEvent" }, usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<ng-container *ngTemplateOutlet=\"viewMode === 'list' ? listView : calendarView\"></ng-container>\r\n<ng-template #listView>\r\n <bc-calendar-list-container\r\n [calendarFields]=\"calendarFields\"\r\n [days]=\"days\"\r\n [canDelete]=\"canDelete\"\r\n [canEdit]=\"canEdit\"\r\n [canView]=\"canView\"\r\n (editEvent)=\"editEvent.emit($event)\"\r\n (deleteEvent)=\"deleteEvent.emit($event)\"\r\n ></bc-calendar-list-container>\r\n</ng-template>\r\n<ng-template #calendarView>\r\n <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\r\n [style.height.px]=\"dayHeight()\"\r\n fd-table-cell\r\n colspan=\"7\"\r\n [style.border]=\"isPickerMode ? 'none' : null\"\r\n >\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<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.index) {\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':\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 !tw-text-white':!isPickerMode && 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.index) {\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%\" (dblclick)=\"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{height:100%}.table-header td{padding:0!important}.table-header>thead>tr>th:last-child{border-right:var(--sapList_BorderWidth, .0625rem) solid var(--sapList_BorderColor, #e5e5e5)}.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 td{overflow:hidden}thead tr{border-bottom:none!important}thead tr th{text-align:center!important;background-color:var(--sapList_Background, #fff);height:1rem;border-bottom:none;border-top:none}.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;border-color:var(--sapList_BorderColor)}.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: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2.MobileDirective, selector: "[mobile]" }, { kind: "directive", type: i3$2.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: i3.ButtonComponent, selector: "button[fd-button], a[fd-button], span[fd-button]", inputs: ["class", "id"], exportAs: ["fd-button"] }, { kind: "component", type: i5.PopoverComponent, selector: "fd-popover", inputs: ["title", "trigger", "fixedPosition", "id", "mobile", "mobileConfig", "preventSpaceKeyScroll"] }, { kind: "component", type: i6.TableComponent, selector: "table[fd-table]", inputs: ["noBorderX", "noBorderY", "noOuterBorder", "topBorder", "popIn", "responsive", "keys", "allCellsFocusable"], exportAs: ["fd-table"] }, { kind: "directive", type: i6.TableHeaderDirective, selector: "[fdTableHeader], [fd-table-header]", inputs: ["noBorderX", "noBorderY", "nonInteractive"] }, { kind: "directive", type: i6.TableBodyDirective, selector: "[fdTableBody], [fd-table-body]", inputs: ["noBorderX", "noBorderY"] }, { kind: "directive", type: i6.TableRowDirective, selector: "[fdTableRow], [fd-table-row]", inputs: ["activable", "highlightActive", "hoverable", "focusable", "main", "secondary", "active"] }, { kind: "directive", type: i6.TableCellDirective, selector: "[fdTableCell], [fd-table-cell]", inputs: ["noBorderX", "noBorderY", "activable", "focusable", "hoverable", "fitContent", "noPadding", "noData", "nonInteractive", "key"] }, { kind: "component", type: CalendarListContainerComponent, selector: "bc-calendar-list-container", inputs: ["canEdit", "canView", "canDelete", "days", "calendarFields"], outputs: ["deleteEvent", "editEvent"] }, { kind: "component", type: DayNumberBoxComponent, selector: "bc-day-number-box", inputs: ["isWeekMode", "isSingleDay", "day", "isPickerMode", "itemInRange", "isActive"], outputs: ["dayClick", "dayMouseDown", "dayMouseUp", "dayMouseMove"] }, { kind: "component", type: EventButtonComponent, selector: "bc-event-button", inputs: ["buttonTemplate", "calendarFields", "task", "rtl", "canDelete", "canEdit", "canView", "index", "deviceSize"], outputs: ["deleteEvent", "editEvent", "openPopoverChange"] }, { kind: "component", type: DayEventListComponent, selector: "bc-day-event-list", inputs: ["day", "deviceSize", "weekDays", "calendarFields", "rtl", "canDelete", "canEdit", "canView", "popover"], outputs: ["deleteEvent", "editEvent", "openPopOver"] }, { kind: "pipe", type: i1.SlicePipe, name: "slice" }, { kind: "pipe", type: i2.BbbTranslatePipe, name: "bbbTranslate" }, { kind: "pipe", type: DaysInWeekPipe, name: "daysInWeek" }, { kind: "pipe", type: EqualDatePipe, name: "equalDate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
1359
1366
  }
1360
1367
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.0.6", ngImport: i0, type: CalendarMonthComponent, decorators: [{
1361
1368
  type: Component,
1362
- args: [{ selector: 'bc-calendar-month', changeDetection: ChangeDetectionStrategy.OnPush, standalone: false, template: "<ng-container *ngTemplateOutlet=\"viewMode === 'list' ? listView : calendarView\"></ng-container>\r\n<ng-template #listView>\r\n <bc-calendar-list-container\r\n [calendarFields]=\"calendarFields\"\r\n [days]=\"days\"\r\n [canDelete]=\"canDelete\"\r\n [canEdit]=\"canEdit\"\r\n [canView]=\"canView\"\r\n (editEvent)=\"editEvent.emit($event)\"\r\n (deleteEvent)=\"deleteEvent.emit($event)\"\r\n ></bc-calendar-list-container>\r\n</ng-template>\r\n<ng-template #calendarView>\r\n <table\r\n fd-table\r\n class=\"table-header\"\r\n [fdCompact]\r\n [attr.picker]=\"datePicker\"\r\n >\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\r\n [style.height.px]=\"dayHeight()\"\r\n fd-table-cell\r\n colspan=\"7\"\r\n [style.border]=\"isPickerMode ? 'none' : null\"\r\n >\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<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.index) {\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':\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 !tw-text-white':!isPickerMode && 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.index) {\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%\" (dblclick)=\"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{height:100%}.table-header td{padding:0!important}.table-header>thead>tr>th:last-child{border-right:var(--sapList_BorderWidth, .0625rem) solid var(--sapList_BorderColor, #e5e5e5)}.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 td{overflow:hidden}thead tr{border-bottom:none!important}thead tr th{text-align:center!important;background-color:var(--sapList_Background, #fff);height:1rem;border-bottom:none;border-top:none}.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;border-color:var(--sapList_BorderColor)}.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"] }]
1369
+ args: [{ selector: 'bc-calendar-month', changeDetection: ChangeDetectionStrategy.OnPush, standalone: false, template: "<ng-container *ngTemplateOutlet=\"viewMode === 'list' ? listView : calendarView\"></ng-container>\r\n<ng-template #listView>\r\n <bc-calendar-list-container\r\n [calendarFields]=\"calendarFields\"\r\n [days]=\"days\"\r\n [canDelete]=\"canDelete\"\r\n [canEdit]=\"canEdit\"\r\n [canView]=\"canView\"\r\n (editEvent)=\"editEvent.emit($event)\"\r\n (deleteEvent)=\"deleteEvent.emit($event)\"\r\n ></bc-calendar-list-container>\r\n</ng-template>\r\n<ng-template #calendarView>\r\n <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\r\n [style.height.px]=\"dayHeight()\"\r\n fd-table-cell\r\n colspan=\"7\"\r\n [style.border]=\"isPickerMode ? 'none' : null\"\r\n >\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<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.index) {\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':\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 !tw-text-white':!isPickerMode && 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.index) {\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%\" (dblclick)=\"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{height:100%}.table-header td{padding:0!important}.table-header>thead>tr>th:last-child{border-right:var(--sapList_BorderWidth, .0625rem) solid var(--sapList_BorderColor, #e5e5e5)}.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 td{overflow:hidden}thead tr{border-bottom:none!important}thead tr th{text-align:center!important;background-color:var(--sapList_Background, #fff);height:1rem;border-bottom:none;border-top:none}.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;border-color:var(--sapList_BorderColor)}.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"] }]
1363
1370
  }], propDecorators: { monthWeeksCount: [{
1364
1371
  type: Input
1365
1372
  }], weekDays: [{
@@ -2934,7 +2941,7 @@ class CalendarContainerComponent extends ReportViewBaseComponent {
2934
2941
  // const divRef= this._el.nativeElement;
2935
2942
  const divRef = this._divRef.nativeElement;
2936
2943
  this.width = divRef.offsetWidth;
2937
- this.height = divRef.offsetHeight - 45;
2944
+ this.calendarHeight = divRef.offsetHeight - 45;
2938
2945
  }
2939
2946
  /** Measure after layout; week view needs `height` / `width` for `bc-calendar-week` and `fillEmptySpace`. */
2940
2947
  _scheduleMeasureLayout() {
@@ -2952,7 +2959,7 @@ class CalendarContainerComponent extends ReportViewBaseComponent {
2952
2959
  useFactory: getDateService,
2953
2960
  deps: [LogService]
2954
2961
  }
2955
- ], viewQueries: [{ propertyName: "_divRef", first: true, predicate: ["divRef"], descendants: true, static: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<div\r\n style=\"display: flex; width: 100%; height: 100%; flex-direction: row\"\r\n intersectionObserver\r\n [intersectionThreshold]=\"0.5\"\r\n (visibilityChange)=\"onVisibilityChange($event)\"\r\n>\r\n @if ( deviceSize==='xl' || userCalendars?.Data?.MoDataList?.length ){\r\n <div style=\"width: 320px; height: 100%\">\r\n @if(!viewSetting.HideSelectionDays){\r\n <bc-calendar-selection-days\r\n [inline]=\"true\"\r\n [monthInfo]=\"(selectedMonth$ | async)!!\"\r\n (rangeChange)=\"onRangeChange($event)\"\r\n ></bc-calendar-selection-days>\r\n } @if (userCalendars?.Data?.MoDataList?.length) {\r\n <div style=\"height: 1px; background: #ccc\"></div>\r\n <div>\r\n <h4>\u062A\u0642\u0648\u06CC\u0645\u200C\u0647\u0627\u06CC\u200C\u0645\u0646</h4>\r\n @for (calendar of userCalendars.Data.MoDataList; track calendar) {\r\n <ul fd-list>\r\n <li fd-list-item style=\"padding: 0\" class=\"user-calendar\">\r\n <span\r\n [style.background]=\"calendar.Color ? calendar.Color : null\"\r\n style=\"width: 5px; height: 100%; position: absolute\"\r\n ></span>\r\n <fd-checkbox\r\n [(ngModel)]=\"calendar.$IsChecked\"\r\n (change)=\"onCalendarCheckChange(calendar)\"\r\n ></fd-checkbox>\r\n <span fd-list-title>{{ calendar.$Caption }}</span>\r\n </li>\r\n </ul>\r\n }\r\n </div>\r\n }\r\n </div>\r\n }\r\n <div class=\"calendar-main-column\" #divRef>\r\n @if(!viewSetting.HideHeader){\r\n <bc-calendar-header\r\n [monthInfo]=\"(selectedMonth$ | async)!!\"\r\n [weekModeDays]=\"(weekModeDays$ | async)!!\"\r\n [rtl]=\"rtl\"\r\n [hidePrevNext]=\"viewSetting.HidePrevNex\"\r\n [hideTodayButton]=\"viewSetting.HideTodayButton\"\r\n [hideSelectionDays]=\"viewSetting.HideSelectionDays\"\r\n [hideDailyButton]=\"viewSetting.HideDailyButton\"\r\n [hideMonthlyButton]=\"viewSetting.HideMonthlyButton\"\r\n [hideWeeklyButton]=\"viewSetting.HideWeeklyButton\"\r\n [hideModeButton]=\"viewSetting.HideModeButton\"\r\n [hideViewMode]=\"viewSetting.HideViewMode\"\r\n [viewMode]=\"viewMode()\"\r\n [deviceSize]=\"deviceSize\"\r\n [mode]=\"(mode$ | async)!!\"\r\n [modeTitle]=\"(modeTitle$ | async)!!\"\r\n [title]=\"(title$ | async)!!\"\r\n (viewModeChange)=\"onViewModeChange($event)\"\r\n (modeChange)=\"onModeChange($event)\"\r\n (prevTap)=\"onPrevTap()\"\r\n (nextTap)=\"onNextTap()\"\r\n (today)=\"onToday()\"\r\n (rangeChange)=\"onRangeChange($event)\"\r\n >\r\n </bc-calendar-header>\r\n }\r\n <div\r\n class=\"calendar-body-region\"\r\n [class.ui-report-gridshell]=\"resolvedViewportPolicy().scroll === 'self'\"\r\n [class.report-grid-wrapper]=\"resolvedViewportPolicy().scroll === 'self'\"\r\n [class.report-layout-fill]=\"resolvedViewportPolicy().layout === 'fill'\"\r\n [class.report-layout-inline]=\"resolvedViewportPolicy().layout === 'inline'\"\r\n [class.report-scroll-self]=\"resolvedViewportPolicy().scroll === 'self'\"\r\n [class.report-scroll-inherit]=\"resolvedViewportPolicy().scroll === 'inherit'\"\r\n >\r\n @switch (mode$ | async) { @case ('week') {\r\n <ng-container\r\n *ngTemplateOutlet=\"\r\n weekCalendar;\r\n context: {\r\n $implicit: selectedMonth$ | async,\r\n moDataList: eventMoDataList$ | async,\r\n height: height,\r\n rtl: rtl,\r\n showEvents: showEvents,\r\n weekModeDays: weekModeDays$ | async,\r\n viewMode: viewMode(),\r\n today: today,\r\n deviceSize: deviceSize,\r\n calendarFields: calendarFields,\r\n access: access\r\n }\r\n \"\r\n ></ng-container>\r\n } @case ('day') {\r\n <ng-container\r\n *ngTemplateOutlet=\"\r\n weekCalendar;\r\n context: {\r\n $implicit: selectedMonth$ | async,\r\n moDataList: eventMoDataList$ | async,\r\n height: height,\r\n rtl: rtl,\r\n showEvents: showEvents,\r\n weekModeDays: weekModeDays$ | async,\r\n viewMode: viewMode(),\r\n today: today,\r\n deviceSize: deviceSize,\r\n calendarFields: calendarFields,\r\n access: access\r\n }\r\n \"\r\n ></ng-container>\r\n } @default {\r\n <ng-container\r\n *ngTemplateOutlet=\"\r\n monthCalendar;\r\n context: {\r\n $implicit: days$ | async,\r\n moDataList: eventMoDataList$ | async,\r\n height: height,\r\n rtl: rtl,\r\n showEvents: showEvents,\r\n viewMode: viewMode(),\r\n today: today,\r\n deviceSize: deviceSize,\r\n calendarFields: calendarFields,\r\n monthWeeksCount: monthWeeksCount$ | async,\r\n access: access\r\n }\r\n \"\r\n ></ng-container>\r\n } }\r\n </div>\r\n </div>\r\n</div>\r\n<ng-template\r\n #monthCalendar\r\n let-days\r\n let-moDataList=\"moDataList\"\r\n let-height=\"height\"\r\n let-calendarFields=\"calendarFields\"\r\n let-rtl=\"rtl\"\r\n let-today=\"today\"\r\n let-viewMode=\"viewMode\"\r\n let-showEvents=\"showEvents\"\r\n let-deviceSize=\"deviceSize\"\r\n let-monthWeeksCount=\"monthWeeksCount\"\r\n let-access=\"access\"\r\n>\r\n <bc-calendar-month\r\n [viewMode]=\"viewMode\"\r\n [calendarFields]=\"calendarFields\"\r\n [moDataList]=\"moDataList\"\r\n [monthWeeksCount]=\"monthWeeksCount\"\r\n [rtl]=\"rtl\"\r\n [weekDays]=\"weekDays\"\r\n [weekDaysMin]=\"weekDaysMin\"\r\n [today]=\"today\"\r\n [showEvents]=\"showEvents\"\r\n [days]=\"days\"\r\n [canView]=\"access.View\"\r\n [canAdd]=\"access.Add\"\r\n [canEdit]=\"access.Edit\"\r\n [canDelete]=\"access.Delete\"\r\n [deviceSize]=\"deviceSize\"\r\n (dayClick)=\"onDayClick($event)\"\r\n (showEvent)=\"onShowTask()\"\r\n (deleteEvent)=\"deleteTask.emit($event)\"\r\n (editEvent)=\"editTask.emit($event)\"\r\n (daySelect)=\"daySelect.emit($event)\"\r\n ></bc-calendar-month>\r\n</ng-template>\r\n<ng-template\r\n #weekCalendar\r\n let-selectedMonth\r\n let-moDataList=\"moDataList\"\r\n let-height=\"height\"\r\n let-calendarFields=\"calendarFields\"\r\n let-viewMode=\"viewMode\"\r\n let-rtl=\"rtl\"\r\n let-today=\"today\"\r\n let-showEvents=\"showEvents\"\r\n let-deviceSize=\"deviceSize\"\r\n let-weekModeDays=\"weekModeDays\"\r\n let-access=\"access\"\r\n>\r\n <bc-calendar-week\r\n fillEmptySpace\r\n [decrement]=\"'2rem'\"\r\n [setMaxHeight]=\"true\"\r\n class=\"tw-overflow-auto\"\r\n [viewMode]=\"viewMode\"\r\n [containerHeight]=\"parentHeight !== 0 ? parentHeight : height\"\r\n [inDialog]=\"inDialog\"\r\n [calendarFields]=\"calendarFields\"\r\n [moDataList]=\"moDataList\"\r\n [rtl]=\"rtl\"\r\n [canAdd]=\"access.Add\"\r\n [canView]=\"access.View\"\r\n [canEdit]=\"access.Edit\"\r\n [canDelete]=\"access.Delete\"\r\n [weekDays]=\"weekDays\"\r\n [weekDaysMin]=\"weekDaysMin\"\r\n [today]=\"today\"\r\n [showEvents]=\"showEvents\"\r\n [days]=\"weekModeDays\"\r\n [deviceSize]=\"deviceSize\"\r\n (dayClick)=\"onDayClick($event)\"\r\n (showEvent)=\"onShowTask()\"\r\n (deleteEvent)=\"deleteTask.emit($event)\"\r\n (editEvent)=\"editTask.emit($event)\"\r\n (daySelect)=\"daySelect.emit($event)\"\r\n (rangeSelect)=\"onRangeSelect($event)\"\r\n ></bc-calendar-week>\r\n</ng-template>\r\n", styles: [":host{display:block;width:100%;height:100%}:host ::ng-deep li.user-calendar .fd-list__form-item{padding:.5rem}.calendar-main-column{flex:1;min-height:0;display:flex;flex-direction:column}.calendar-main-column .calendar-body-region{flex:1;min-height:0;display:flex;flex-direction:column;width:100%}.calendar-body-region.ui-report-gridshell{flex:1 1 auto;min-height:0}.calendar-body-region.ui-report-gridshell.report-grid-wrapper{overflow:auto}.report-layout-fill.calendar-body-region bc-calendar-month,.report-layout-fill.calendar-body-region bc-calendar-week{flex:1 1 auto;min-height:0}.report-layout-inline.calendar-body-region bc-calendar-month,.report-layout-inline.calendar-body-region bc-calendar-week{flex:0 1 auto}.calendar-main-column .calendar-body-region.report-scroll-inherit{flex:0 1 auto;min-height:auto;overflow:visible}\n"], dependencies: [{ kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2$2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2$2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i2.IntersectionObserverDirective, selector: "[intersectionObserver]", inputs: ["intersectionDebounce", "intersectionRootMargin", "intersectionRoot", "intersectionThreshold"], outputs: ["visibilityChange"] }, { kind: "directive", type: i2.FillEmptySpaceDirective, selector: "[fillEmptySpace]", inputs: ["mode", "containerDom", "decrement", "disable", "height", "dontUseTopBound", "setMinHeight", "setMaxHeight"], outputs: ["heightChanged"], exportAs: ["fillEmptySpace"] }, { kind: "component", type: i4$3.CheckboxComponent, selector: "fd-checkbox", inputs: ["wrapLabel", "valignLabel", "ariaLabel", "role", "value", "ariaLabelledBy", "ariaDescribedBy", "title", "inputId", "state", "name", "label", "disabled", "readonly", "tristate", "tristateSelectable", "labelClass", "required", "displayOnly", "values", "standalone"], outputs: ["focusChange"] }, { kind: "component", type: i4.ListComponent, selector: "[fd-list], [fdList]", inputs: ["dropdownMode", "multiInputMode", "mobileMode", "hasMessage", "noBorder", "navigationIndicator", "selection", "keyboardSupport", "byline", "subline", "theme", "unreadIndicator", "role", "settingsList", "settingsListFooter"], outputs: ["focusEscapeList"] }, { kind: "component", type: i4.ListItemComponent, selector: "[fdListItem] ,[fd-list-item]", inputs: ["selected", "noData", "action", "interactive", "growing", "counter", "active", "unread", "byline", "ariaRole", "id", "preventClick", "settingsListTpl"], outputs: ["keyDown"], exportAs: ["fdListItem"] }, { kind: "directive", type: i4.ListTitleDirective, selector: "[fd-list-title], [fdListTitle]", inputs: ["wrap", "truncate"] }, { kind: "component", type: CalendarWeekComponent, selector: "bc-calendar-week", inputs: ["viewMode", "weekDays", "weekDaysMin", "today", "containerHeight", "calendarFields", "rtl", "inDialog", "deviceSize", "moDataList", "days", "canDelete", "canAdd", "canEdit", "canView"], outputs: ["editEvent", "deleteEvent", "showEvent", "rangeSelect", "daySelect", "dayClick"] }, { kind: "component", type: CalendarMonthComponent, selector: "bc-calendar-month", inputs: ["monthWeeksCount", "weekDays", "weekDaysMin", "today", "containerHeight", "dayRowHeightPx", "days", "calendarFields", "rtl", "deviceSize", "moDataList", "datePicker", "rangePicker", "canDelete", "canAdd", "canEdit", "canView", "selectedDate", "startSelectedDayIndex", "endSelectedDayIndex", "viewMode"], outputs: ["editEvent", "deleteEvent", "daySelect", "dayClick", "dayMouseMove", "dayMouseUp", "dayMouseDown", "showEvent"] }, { kind: "component", type: CalendarHeaderComponent, selector: "bc-calendar-header", inputs: ["monthInfo", "weekModeDays", "hideModeButton", "modeTitle", "title", "deviceSize", "rtl", "mode", "hideTodayButton", "hidePrevNext", "hideDailyButton", "hideMonthlyButton", "hideWeeklyButton", "hideSelectionDays", "hideLisButton", "hideYearButton", "hideViewMode", "viewMode"], outputs: ["viewModeChange", "prevTap", "nextTap", "modeChange", "rangeChange", "today"] }, { kind: "component", type: CalendarSelectionDaysComponent, selector: "bc-calendar-selection-days", inputs: ["startSelectedDayIndex", "endSelectedDayIndex", "monthInfo", "inline"], outputs: ["rangeChange"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
2962
+ ], viewQueries: [{ propertyName: "_divRef", first: true, predicate: ["divRef"], descendants: true, static: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<div\r\n style=\"display: flex; width: 100%; height: 100%; flex-direction: row\"\r\n intersectionObserver\r\n [intersectionThreshold]=\"0.5\"\r\n (visibilityChange)=\"onVisibilityChange($event)\"\r\n>\r\n @if ( deviceSize==='xl' || userCalendars?.Data?.MoDataList?.length ){\r\n <div style=\"width: 320px; height: 100%\">\r\n @if(!viewSetting.HideSelectionDays){\r\n <bc-calendar-selection-days\r\n [inline]=\"true\"\r\n [monthInfo]=\"(selectedMonth$ | async)!!\"\r\n (rangeChange)=\"onRangeChange($event)\"\r\n ></bc-calendar-selection-days>\r\n } @if (userCalendars?.Data?.MoDataList?.length) {\r\n <div style=\"height: 1px; background: #ccc\"></div>\r\n <div>\r\n <h4>\u062A\u0642\u0648\u06CC\u0645\u200C\u0647\u0627\u06CC\u200C\u0645\u0646</h4>\r\n @for (calendar of userCalendars.Data.MoDataList; track calendar) {\r\n <ul fd-list>\r\n <li fd-list-item style=\"padding: 0\" class=\"user-calendar\">\r\n <span\r\n [style.background]=\"calendar.Color ? calendar.Color : null\"\r\n style=\"width: 5px; height: 100%; position: absolute\"\r\n ></span>\r\n <fd-checkbox\r\n [(ngModel)]=\"calendar.$IsChecked\"\r\n (change)=\"onCalendarCheckChange(calendar)\"\r\n ></fd-checkbox>\r\n <span fd-list-title>{{ calendar.$Caption }}</span>\r\n </li>\r\n </ul>\r\n }\r\n </div>\r\n }\r\n </div>\r\n }\r\n <div class=\"calendar-main-column\" #divRef>\r\n @if(!viewSetting.HideHeader){\r\n <bc-calendar-header\r\n [monthInfo]=\"(selectedMonth$ | async)!!\"\r\n [weekModeDays]=\"(weekModeDays$ | async)!!\"\r\n [rtl]=\"rtl\"\r\n [hidePrevNext]=\"viewSetting.HidePrevNex\"\r\n [hideTodayButton]=\"viewSetting.HideTodayButton\"\r\n [hideSelectionDays]=\"viewSetting.HideSelectionDays\"\r\n [hideDailyButton]=\"viewSetting.HideDailyButton\"\r\n [hideMonthlyButton]=\"viewSetting.HideMonthlyButton\"\r\n [hideWeeklyButton]=\"viewSetting.HideWeeklyButton\"\r\n [hideModeButton]=\"viewSetting.HideModeButton\"\r\n [hideViewMode]=\"viewSetting.HideViewMode\"\r\n [viewMode]=\"viewMode()\"\r\n [deviceSize]=\"deviceSize\"\r\n [mode]=\"(mode$ | async)!!\"\r\n [modeTitle]=\"(modeTitle$ | async)!!\"\r\n [title]=\"(title$ | async)!!\"\r\n (viewModeChange)=\"onViewModeChange($event)\"\r\n (modeChange)=\"onModeChange($event)\"\r\n (prevTap)=\"onPrevTap()\"\r\n (nextTap)=\"onNextTap()\"\r\n (today)=\"onToday()\"\r\n (rangeChange)=\"onRangeChange($event)\"\r\n >\r\n </bc-calendar-header>\r\n }\r\n <div\r\n class=\"calendar-body-region\"\r\n [class.ui-report-gridshell]=\"resolvedViewportPolicy().scroll === 'self'\"\r\n [class.report-grid-wrapper]=\"resolvedViewportPolicy().scroll === 'self'\"\r\n [class.report-layout-fill]=\"resolvedViewportPolicy().layout === 'fill'\"\r\n [class.report-layout-inline]=\"resolvedViewportPolicy().layout === 'inline'\"\r\n [class.report-scroll-self]=\"resolvedViewportPolicy().scroll === 'self'\"\r\n [class.report-scroll-inherit]=\"resolvedViewportPolicy().scroll === 'inherit'\"\r\n >\r\n @switch (mode$ | async) { @case ('week') {\r\n <ng-container\r\n *ngTemplateOutlet=\"\r\n weekCalendar;\r\n context: {\r\n $implicit: selectedMonth$ | async,\r\n moDataList: eventMoDataList$ | async,\r\n height: calendarHeight,\r\n rtl: rtl,\r\n showEvents: showEvents,\r\n weekModeDays: weekModeDays$ | async,\r\n viewMode: viewMode(),\r\n today: today,\r\n deviceSize: deviceSize,\r\n calendarFields: calendarFields,\r\n access: access\r\n }\r\n \"\r\n ></ng-container>\r\n } @case ('day') {\r\n <ng-container\r\n *ngTemplateOutlet=\"\r\n weekCalendar;\r\n context: {\r\n $implicit: selectedMonth$ | async,\r\n moDataList: eventMoDataList$ | async,\r\n height: calendarHeight,\r\n rtl: rtl,\r\n showEvents: showEvents,\r\n weekModeDays: weekModeDays$ | async,\r\n viewMode: viewMode(),\r\n today: today,\r\n deviceSize: deviceSize,\r\n calendarFields: calendarFields,\r\n access: access\r\n }\r\n \"\r\n ></ng-container>\r\n } @default {\r\n <ng-container\r\n *ngTemplateOutlet=\"\r\n monthCalendar;\r\n context: {\r\n $implicit: days$ | async,\r\n moDataList: eventMoDataList$ | async,\r\n height: calendarHeight,\r\n rtl: rtl,\r\n showEvents: showEvents,\r\n viewMode: viewMode(),\r\n today: today,\r\n deviceSize: deviceSize,\r\n calendarFields: calendarFields,\r\n monthWeeksCount: monthWeeksCount$ | async,\r\n access: access\r\n }\r\n \"\r\n ></ng-container>\r\n } }\r\n </div>\r\n </div>\r\n</div>\r\n<ng-template\r\n #monthCalendar\r\n let-days\r\n let-moDataList=\"moDataList\"\r\n let-height=\"height\"\r\n let-calendarFields=\"calendarFields\"\r\n let-rtl=\"rtl\"\r\n let-today=\"today\"\r\n let-viewMode=\"viewMode\"\r\n let-showEvents=\"showEvents\"\r\n let-deviceSize=\"deviceSize\"\r\n let-monthWeeksCount=\"monthWeeksCount\"\r\n let-access=\"access\"\r\n>\r\n <bc-calendar-month\r\n [viewMode]=\"viewMode\"\r\n [calendarFields]=\"calendarFields\"\r\n [moDataList]=\"moDataList\"\r\n [monthWeeksCount]=\"monthWeeksCount\"\r\n [rtl]=\"rtl\"\r\n [weekDays]=\"weekDays\"\r\n [weekDaysMin]=\"weekDaysMin\"\r\n [today]=\"today\"\r\n [showEvents]=\"showEvents\"\r\n [days]=\"days\"\r\n [canView]=\"access.View\"\r\n [canAdd]=\"access.Add\"\r\n [canEdit]=\"access.Edit\"\r\n [canDelete]=\"access.Delete\"\r\n [deviceSize]=\"deviceSize\"\r\n (dayClick)=\"onDayClick($event)\"\r\n (showEvent)=\"onShowTask()\"\r\n (deleteEvent)=\"deleteTask.emit($event)\"\r\n (editEvent)=\"editTask.emit($event)\"\r\n (daySelect)=\"daySelect.emit($event)\"\r\n ></bc-calendar-month>\r\n</ng-template>\r\n<ng-template\r\n #weekCalendar\r\n let-selectedMonth\r\n let-moDataList=\"moDataList\"\r\n let-height=\"height\"\r\n let-calendarFields=\"calendarFields\"\r\n let-viewMode=\"viewMode\"\r\n let-rtl=\"rtl\"\r\n let-today=\"today\"\r\n let-showEvents=\"showEvents\"\r\n let-deviceSize=\"deviceSize\"\r\n let-weekModeDays=\"weekModeDays\"\r\n let-access=\"access\"\r\n>\r\n <bc-calendar-week\r\n fillEmptySpace\r\n [decrement]=\"'2rem'\"\r\n [setMaxHeight]=\"true\"\r\n class=\"tw-overflow-auto\"\r\n [viewMode]=\"viewMode\"\r\n [containerHeight]=\"parentHeight !== 0 ? parentHeight : height\"\r\n [inDialog]=\"inDialog\"\r\n [calendarFields]=\"calendarFields\"\r\n [moDataList]=\"moDataList\"\r\n [rtl]=\"rtl\"\r\n [canAdd]=\"access.Add\"\r\n [canView]=\"access.View\"\r\n [canEdit]=\"access.Edit\"\r\n [canDelete]=\"access.Delete\"\r\n [weekDays]=\"weekDays\"\r\n [weekDaysMin]=\"weekDaysMin\"\r\n [today]=\"today\"\r\n [showEvents]=\"showEvents\"\r\n [days]=\"weekModeDays\"\r\n [deviceSize]=\"deviceSize\"\r\n (dayClick)=\"onDayClick($event)\"\r\n (showEvent)=\"onShowTask()\"\r\n (deleteEvent)=\"deleteTask.emit($event)\"\r\n (editEvent)=\"editTask.emit($event)\"\r\n (daySelect)=\"daySelect.emit($event)\"\r\n (rangeSelect)=\"onRangeSelect($event)\"\r\n ></bc-calendar-week>\r\n</ng-template>\r\n", styles: [":host{display:block;width:100%;height:100%}:host ::ng-deep li.user-calendar .fd-list__form-item{padding:.5rem}.calendar-main-column{flex:1;min-height:0;display:flex;flex-direction:column}.calendar-main-column .calendar-body-region{flex:1;min-height:0;display:flex;flex-direction:column;width:100%}.calendar-body-region.ui-report-gridshell{flex:1 1 auto;min-height:0}.calendar-body-region.ui-report-gridshell.report-grid-wrapper{overflow:auto}.report-layout-fill.calendar-body-region bc-calendar-month,.report-layout-fill.calendar-body-region bc-calendar-week{flex:1 1 auto;min-height:0}.report-layout-inline.calendar-body-region bc-calendar-month,.report-layout-inline.calendar-body-region bc-calendar-week{flex:0 1 auto}.calendar-main-column .calendar-body-region.report-scroll-inherit{flex:0 1 auto;min-height:auto;overflow:visible}\n"], dependencies: [{ kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2$2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2$2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i2.IntersectionObserverDirective, selector: "[intersectionObserver]", inputs: ["intersectionDebounce", "intersectionRootMargin", "intersectionRoot", "intersectionThreshold"], outputs: ["visibilityChange"] }, { kind: "directive", type: i2.FillEmptySpaceDirective, selector: "[fillEmptySpace]", inputs: ["mode", "containerDom", "decrement", "disable", "height", "dontUseTopBound", "setMinHeight", "setMaxHeight"], outputs: ["heightChanged"], exportAs: ["fillEmptySpace"] }, { kind: "component", type: i4$3.CheckboxComponent, selector: "fd-checkbox", inputs: ["wrapLabel", "valignLabel", "ariaLabel", "role", "value", "ariaLabelledBy", "ariaDescribedBy", "title", "inputId", "state", "name", "label", "disabled", "readonly", "tristate", "tristateSelectable", "labelClass", "required", "displayOnly", "values", "standalone"], outputs: ["focusChange"] }, { kind: "component", type: i4.ListComponent, selector: "[fd-list], [fdList]", inputs: ["dropdownMode", "multiInputMode", "mobileMode", "hasMessage", "noBorder", "navigationIndicator", "selection", "keyboardSupport", "byline", "subline", "theme", "unreadIndicator", "role", "settingsList", "settingsListFooter"], outputs: ["focusEscapeList"] }, { kind: "component", type: i4.ListItemComponent, selector: "[fdListItem] ,[fd-list-item]", inputs: ["selected", "noData", "action", "interactive", "growing", "counter", "active", "unread", "byline", "ariaRole", "id", "preventClick", "settingsListTpl"], outputs: ["keyDown"], exportAs: ["fdListItem"] }, { kind: "directive", type: i4.ListTitleDirective, selector: "[fd-list-title], [fdListTitle]", inputs: ["wrap", "truncate"] }, { kind: "component", type: CalendarWeekComponent, selector: "bc-calendar-week", inputs: ["viewMode", "weekDays", "weekDaysMin", "today", "containerHeight", "calendarFields", "rtl", "inDialog", "deviceSize", "moDataList", "days", "canDelete", "canAdd", "canEdit", "canView"], outputs: ["editEvent", "deleteEvent", "showEvent", "rangeSelect", "daySelect", "dayClick"] }, { kind: "component", type: CalendarMonthComponent, selector: "bc-calendar-month", inputs: ["monthWeeksCount", "weekDays", "weekDaysMin", "today", "containerHeight", "dayRowHeightPx", "days", "calendarFields", "rtl", "deviceSize", "moDataList", "datePicker", "rangePicker", "canDelete", "canAdd", "canEdit", "canView", "selectedDate", "startSelectedDayIndex", "endSelectedDayIndex", "viewMode"], outputs: ["editEvent", "deleteEvent", "daySelect", "dayClick", "dayMouseMove", "dayMouseUp", "dayMouseDown", "showEvent"] }, { kind: "component", type: CalendarHeaderComponent, selector: "bc-calendar-header", inputs: ["monthInfo", "weekModeDays", "hideModeButton", "modeTitle", "title", "deviceSize", "rtl", "mode", "hideTodayButton", "hidePrevNext", "hideDailyButton", "hideMonthlyButton", "hideWeeklyButton", "hideSelectionDays", "hideLisButton", "hideYearButton", "hideViewMode", "viewMode"], outputs: ["viewModeChange", "prevTap", "nextTap", "modeChange", "rangeChange", "today"] }, { kind: "component", type: CalendarSelectionDaysComponent, selector: "bc-calendar-selection-days", inputs: ["startSelectedDayIndex", "endSelectedDayIndex", "monthInfo", "inline"], outputs: ["rangeChange"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
2956
2963
  }
2957
2964
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.0.6", ngImport: i0, type: CalendarContainerComponent, decorators: [{
2958
2965
  type: Component,
@@ -2962,7 +2969,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.0.6", ngImpor
2962
2969
  useFactory: getDateService,
2963
2970
  deps: [LogService]
2964
2971
  }
2965
- ], standalone: false, template: "<div\r\n style=\"display: flex; width: 100%; height: 100%; flex-direction: row\"\r\n intersectionObserver\r\n [intersectionThreshold]=\"0.5\"\r\n (visibilityChange)=\"onVisibilityChange($event)\"\r\n>\r\n @if ( deviceSize==='xl' || userCalendars?.Data?.MoDataList?.length ){\r\n <div style=\"width: 320px; height: 100%\">\r\n @if(!viewSetting.HideSelectionDays){\r\n <bc-calendar-selection-days\r\n [inline]=\"true\"\r\n [monthInfo]=\"(selectedMonth$ | async)!!\"\r\n (rangeChange)=\"onRangeChange($event)\"\r\n ></bc-calendar-selection-days>\r\n } @if (userCalendars?.Data?.MoDataList?.length) {\r\n <div style=\"height: 1px; background: #ccc\"></div>\r\n <div>\r\n <h4>\u062A\u0642\u0648\u06CC\u0645\u200C\u0647\u0627\u06CC\u200C\u0645\u0646</h4>\r\n @for (calendar of userCalendars.Data.MoDataList; track calendar) {\r\n <ul fd-list>\r\n <li fd-list-item style=\"padding: 0\" class=\"user-calendar\">\r\n <span\r\n [style.background]=\"calendar.Color ? calendar.Color : null\"\r\n style=\"width: 5px; height: 100%; position: absolute\"\r\n ></span>\r\n <fd-checkbox\r\n [(ngModel)]=\"calendar.$IsChecked\"\r\n (change)=\"onCalendarCheckChange(calendar)\"\r\n ></fd-checkbox>\r\n <span fd-list-title>{{ calendar.$Caption }}</span>\r\n </li>\r\n </ul>\r\n }\r\n </div>\r\n }\r\n </div>\r\n }\r\n <div class=\"calendar-main-column\" #divRef>\r\n @if(!viewSetting.HideHeader){\r\n <bc-calendar-header\r\n [monthInfo]=\"(selectedMonth$ | async)!!\"\r\n [weekModeDays]=\"(weekModeDays$ | async)!!\"\r\n [rtl]=\"rtl\"\r\n [hidePrevNext]=\"viewSetting.HidePrevNex\"\r\n [hideTodayButton]=\"viewSetting.HideTodayButton\"\r\n [hideSelectionDays]=\"viewSetting.HideSelectionDays\"\r\n [hideDailyButton]=\"viewSetting.HideDailyButton\"\r\n [hideMonthlyButton]=\"viewSetting.HideMonthlyButton\"\r\n [hideWeeklyButton]=\"viewSetting.HideWeeklyButton\"\r\n [hideModeButton]=\"viewSetting.HideModeButton\"\r\n [hideViewMode]=\"viewSetting.HideViewMode\"\r\n [viewMode]=\"viewMode()\"\r\n [deviceSize]=\"deviceSize\"\r\n [mode]=\"(mode$ | async)!!\"\r\n [modeTitle]=\"(modeTitle$ | async)!!\"\r\n [title]=\"(title$ | async)!!\"\r\n (viewModeChange)=\"onViewModeChange($event)\"\r\n (modeChange)=\"onModeChange($event)\"\r\n (prevTap)=\"onPrevTap()\"\r\n (nextTap)=\"onNextTap()\"\r\n (today)=\"onToday()\"\r\n (rangeChange)=\"onRangeChange($event)\"\r\n >\r\n </bc-calendar-header>\r\n }\r\n <div\r\n class=\"calendar-body-region\"\r\n [class.ui-report-gridshell]=\"resolvedViewportPolicy().scroll === 'self'\"\r\n [class.report-grid-wrapper]=\"resolvedViewportPolicy().scroll === 'self'\"\r\n [class.report-layout-fill]=\"resolvedViewportPolicy().layout === 'fill'\"\r\n [class.report-layout-inline]=\"resolvedViewportPolicy().layout === 'inline'\"\r\n [class.report-scroll-self]=\"resolvedViewportPolicy().scroll === 'self'\"\r\n [class.report-scroll-inherit]=\"resolvedViewportPolicy().scroll === 'inherit'\"\r\n >\r\n @switch (mode$ | async) { @case ('week') {\r\n <ng-container\r\n *ngTemplateOutlet=\"\r\n weekCalendar;\r\n context: {\r\n $implicit: selectedMonth$ | async,\r\n moDataList: eventMoDataList$ | async,\r\n height: height,\r\n rtl: rtl,\r\n showEvents: showEvents,\r\n weekModeDays: weekModeDays$ | async,\r\n viewMode: viewMode(),\r\n today: today,\r\n deviceSize: deviceSize,\r\n calendarFields: calendarFields,\r\n access: access\r\n }\r\n \"\r\n ></ng-container>\r\n } @case ('day') {\r\n <ng-container\r\n *ngTemplateOutlet=\"\r\n weekCalendar;\r\n context: {\r\n $implicit: selectedMonth$ | async,\r\n moDataList: eventMoDataList$ | async,\r\n height: height,\r\n rtl: rtl,\r\n showEvents: showEvents,\r\n weekModeDays: weekModeDays$ | async,\r\n viewMode: viewMode(),\r\n today: today,\r\n deviceSize: deviceSize,\r\n calendarFields: calendarFields,\r\n access: access\r\n }\r\n \"\r\n ></ng-container>\r\n } @default {\r\n <ng-container\r\n *ngTemplateOutlet=\"\r\n monthCalendar;\r\n context: {\r\n $implicit: days$ | async,\r\n moDataList: eventMoDataList$ | async,\r\n height: height,\r\n rtl: rtl,\r\n showEvents: showEvents,\r\n viewMode: viewMode(),\r\n today: today,\r\n deviceSize: deviceSize,\r\n calendarFields: calendarFields,\r\n monthWeeksCount: monthWeeksCount$ | async,\r\n access: access\r\n }\r\n \"\r\n ></ng-container>\r\n } }\r\n </div>\r\n </div>\r\n</div>\r\n<ng-template\r\n #monthCalendar\r\n let-days\r\n let-moDataList=\"moDataList\"\r\n let-height=\"height\"\r\n let-calendarFields=\"calendarFields\"\r\n let-rtl=\"rtl\"\r\n let-today=\"today\"\r\n let-viewMode=\"viewMode\"\r\n let-showEvents=\"showEvents\"\r\n let-deviceSize=\"deviceSize\"\r\n let-monthWeeksCount=\"monthWeeksCount\"\r\n let-access=\"access\"\r\n>\r\n <bc-calendar-month\r\n [viewMode]=\"viewMode\"\r\n [calendarFields]=\"calendarFields\"\r\n [moDataList]=\"moDataList\"\r\n [monthWeeksCount]=\"monthWeeksCount\"\r\n [rtl]=\"rtl\"\r\n [weekDays]=\"weekDays\"\r\n [weekDaysMin]=\"weekDaysMin\"\r\n [today]=\"today\"\r\n [showEvents]=\"showEvents\"\r\n [days]=\"days\"\r\n [canView]=\"access.View\"\r\n [canAdd]=\"access.Add\"\r\n [canEdit]=\"access.Edit\"\r\n [canDelete]=\"access.Delete\"\r\n [deviceSize]=\"deviceSize\"\r\n (dayClick)=\"onDayClick($event)\"\r\n (showEvent)=\"onShowTask()\"\r\n (deleteEvent)=\"deleteTask.emit($event)\"\r\n (editEvent)=\"editTask.emit($event)\"\r\n (daySelect)=\"daySelect.emit($event)\"\r\n ></bc-calendar-month>\r\n</ng-template>\r\n<ng-template\r\n #weekCalendar\r\n let-selectedMonth\r\n let-moDataList=\"moDataList\"\r\n let-height=\"height\"\r\n let-calendarFields=\"calendarFields\"\r\n let-viewMode=\"viewMode\"\r\n let-rtl=\"rtl\"\r\n let-today=\"today\"\r\n let-showEvents=\"showEvents\"\r\n let-deviceSize=\"deviceSize\"\r\n let-weekModeDays=\"weekModeDays\"\r\n let-access=\"access\"\r\n>\r\n <bc-calendar-week\r\n fillEmptySpace\r\n [decrement]=\"'2rem'\"\r\n [setMaxHeight]=\"true\"\r\n class=\"tw-overflow-auto\"\r\n [viewMode]=\"viewMode\"\r\n [containerHeight]=\"parentHeight !== 0 ? parentHeight : height\"\r\n [inDialog]=\"inDialog\"\r\n [calendarFields]=\"calendarFields\"\r\n [moDataList]=\"moDataList\"\r\n [rtl]=\"rtl\"\r\n [canAdd]=\"access.Add\"\r\n [canView]=\"access.View\"\r\n [canEdit]=\"access.Edit\"\r\n [canDelete]=\"access.Delete\"\r\n [weekDays]=\"weekDays\"\r\n [weekDaysMin]=\"weekDaysMin\"\r\n [today]=\"today\"\r\n [showEvents]=\"showEvents\"\r\n [days]=\"weekModeDays\"\r\n [deviceSize]=\"deviceSize\"\r\n (dayClick)=\"onDayClick($event)\"\r\n (showEvent)=\"onShowTask()\"\r\n (deleteEvent)=\"deleteTask.emit($event)\"\r\n (editEvent)=\"editTask.emit($event)\"\r\n (daySelect)=\"daySelect.emit($event)\"\r\n (rangeSelect)=\"onRangeSelect($event)\"\r\n ></bc-calendar-week>\r\n</ng-template>\r\n", styles: [":host{display:block;width:100%;height:100%}:host ::ng-deep li.user-calendar .fd-list__form-item{padding:.5rem}.calendar-main-column{flex:1;min-height:0;display:flex;flex-direction:column}.calendar-main-column .calendar-body-region{flex:1;min-height:0;display:flex;flex-direction:column;width:100%}.calendar-body-region.ui-report-gridshell{flex:1 1 auto;min-height:0}.calendar-body-region.ui-report-gridshell.report-grid-wrapper{overflow:auto}.report-layout-fill.calendar-body-region bc-calendar-month,.report-layout-fill.calendar-body-region bc-calendar-week{flex:1 1 auto;min-height:0}.report-layout-inline.calendar-body-region bc-calendar-month,.report-layout-inline.calendar-body-region bc-calendar-week{flex:0 1 auto}.calendar-main-column .calendar-body-region.report-scroll-inherit{flex:0 1 auto;min-height:auto;overflow:visible}\n"] }]
2972
+ ], standalone: false, template: "<div\r\n style=\"display: flex; width: 100%; height: 100%; flex-direction: row\"\r\n intersectionObserver\r\n [intersectionThreshold]=\"0.5\"\r\n (visibilityChange)=\"onVisibilityChange($event)\"\r\n>\r\n @if ( deviceSize==='xl' || userCalendars?.Data?.MoDataList?.length ){\r\n <div style=\"width: 320px; height: 100%\">\r\n @if(!viewSetting.HideSelectionDays){\r\n <bc-calendar-selection-days\r\n [inline]=\"true\"\r\n [monthInfo]=\"(selectedMonth$ | async)!!\"\r\n (rangeChange)=\"onRangeChange($event)\"\r\n ></bc-calendar-selection-days>\r\n } @if (userCalendars?.Data?.MoDataList?.length) {\r\n <div style=\"height: 1px; background: #ccc\"></div>\r\n <div>\r\n <h4>\u062A\u0642\u0648\u06CC\u0645\u200C\u0647\u0627\u06CC\u200C\u0645\u0646</h4>\r\n @for (calendar of userCalendars.Data.MoDataList; track calendar) {\r\n <ul fd-list>\r\n <li fd-list-item style=\"padding: 0\" class=\"user-calendar\">\r\n <span\r\n [style.background]=\"calendar.Color ? calendar.Color : null\"\r\n style=\"width: 5px; height: 100%; position: absolute\"\r\n ></span>\r\n <fd-checkbox\r\n [(ngModel)]=\"calendar.$IsChecked\"\r\n (change)=\"onCalendarCheckChange(calendar)\"\r\n ></fd-checkbox>\r\n <span fd-list-title>{{ calendar.$Caption }}</span>\r\n </li>\r\n </ul>\r\n }\r\n </div>\r\n }\r\n </div>\r\n }\r\n <div class=\"calendar-main-column\" #divRef>\r\n @if(!viewSetting.HideHeader){\r\n <bc-calendar-header\r\n [monthInfo]=\"(selectedMonth$ | async)!!\"\r\n [weekModeDays]=\"(weekModeDays$ | async)!!\"\r\n [rtl]=\"rtl\"\r\n [hidePrevNext]=\"viewSetting.HidePrevNex\"\r\n [hideTodayButton]=\"viewSetting.HideTodayButton\"\r\n [hideSelectionDays]=\"viewSetting.HideSelectionDays\"\r\n [hideDailyButton]=\"viewSetting.HideDailyButton\"\r\n [hideMonthlyButton]=\"viewSetting.HideMonthlyButton\"\r\n [hideWeeklyButton]=\"viewSetting.HideWeeklyButton\"\r\n [hideModeButton]=\"viewSetting.HideModeButton\"\r\n [hideViewMode]=\"viewSetting.HideViewMode\"\r\n [viewMode]=\"viewMode()\"\r\n [deviceSize]=\"deviceSize\"\r\n [mode]=\"(mode$ | async)!!\"\r\n [modeTitle]=\"(modeTitle$ | async)!!\"\r\n [title]=\"(title$ | async)!!\"\r\n (viewModeChange)=\"onViewModeChange($event)\"\r\n (modeChange)=\"onModeChange($event)\"\r\n (prevTap)=\"onPrevTap()\"\r\n (nextTap)=\"onNextTap()\"\r\n (today)=\"onToday()\"\r\n (rangeChange)=\"onRangeChange($event)\"\r\n >\r\n </bc-calendar-header>\r\n }\r\n <div\r\n class=\"calendar-body-region\"\r\n [class.ui-report-gridshell]=\"resolvedViewportPolicy().scroll === 'self'\"\r\n [class.report-grid-wrapper]=\"resolvedViewportPolicy().scroll === 'self'\"\r\n [class.report-layout-fill]=\"resolvedViewportPolicy().layout === 'fill'\"\r\n [class.report-layout-inline]=\"resolvedViewportPolicy().layout === 'inline'\"\r\n [class.report-scroll-self]=\"resolvedViewportPolicy().scroll === 'self'\"\r\n [class.report-scroll-inherit]=\"resolvedViewportPolicy().scroll === 'inherit'\"\r\n >\r\n @switch (mode$ | async) { @case ('week') {\r\n <ng-container\r\n *ngTemplateOutlet=\"\r\n weekCalendar;\r\n context: {\r\n $implicit: selectedMonth$ | async,\r\n moDataList: eventMoDataList$ | async,\r\n height: calendarHeight,\r\n rtl: rtl,\r\n showEvents: showEvents,\r\n weekModeDays: weekModeDays$ | async,\r\n viewMode: viewMode(),\r\n today: today,\r\n deviceSize: deviceSize,\r\n calendarFields: calendarFields,\r\n access: access\r\n }\r\n \"\r\n ></ng-container>\r\n } @case ('day') {\r\n <ng-container\r\n *ngTemplateOutlet=\"\r\n weekCalendar;\r\n context: {\r\n $implicit: selectedMonth$ | async,\r\n moDataList: eventMoDataList$ | async,\r\n height: calendarHeight,\r\n rtl: rtl,\r\n showEvents: showEvents,\r\n weekModeDays: weekModeDays$ | async,\r\n viewMode: viewMode(),\r\n today: today,\r\n deviceSize: deviceSize,\r\n calendarFields: calendarFields,\r\n access: access\r\n }\r\n \"\r\n ></ng-container>\r\n } @default {\r\n <ng-container\r\n *ngTemplateOutlet=\"\r\n monthCalendar;\r\n context: {\r\n $implicit: days$ | async,\r\n moDataList: eventMoDataList$ | async,\r\n height: calendarHeight,\r\n rtl: rtl,\r\n showEvents: showEvents,\r\n viewMode: viewMode(),\r\n today: today,\r\n deviceSize: deviceSize,\r\n calendarFields: calendarFields,\r\n monthWeeksCount: monthWeeksCount$ | async,\r\n access: access\r\n }\r\n \"\r\n ></ng-container>\r\n } }\r\n </div>\r\n </div>\r\n</div>\r\n<ng-template\r\n #monthCalendar\r\n let-days\r\n let-moDataList=\"moDataList\"\r\n let-height=\"height\"\r\n let-calendarFields=\"calendarFields\"\r\n let-rtl=\"rtl\"\r\n let-today=\"today\"\r\n let-viewMode=\"viewMode\"\r\n let-showEvents=\"showEvents\"\r\n let-deviceSize=\"deviceSize\"\r\n let-monthWeeksCount=\"monthWeeksCount\"\r\n let-access=\"access\"\r\n>\r\n <bc-calendar-month\r\n [viewMode]=\"viewMode\"\r\n [calendarFields]=\"calendarFields\"\r\n [moDataList]=\"moDataList\"\r\n [monthWeeksCount]=\"monthWeeksCount\"\r\n [rtl]=\"rtl\"\r\n [weekDays]=\"weekDays\"\r\n [weekDaysMin]=\"weekDaysMin\"\r\n [today]=\"today\"\r\n [showEvents]=\"showEvents\"\r\n [days]=\"days\"\r\n [canView]=\"access.View\"\r\n [canAdd]=\"access.Add\"\r\n [canEdit]=\"access.Edit\"\r\n [canDelete]=\"access.Delete\"\r\n [deviceSize]=\"deviceSize\"\r\n (dayClick)=\"onDayClick($event)\"\r\n (showEvent)=\"onShowTask()\"\r\n (deleteEvent)=\"deleteTask.emit($event)\"\r\n (editEvent)=\"editTask.emit($event)\"\r\n (daySelect)=\"daySelect.emit($event)\"\r\n ></bc-calendar-month>\r\n</ng-template>\r\n<ng-template\r\n #weekCalendar\r\n let-selectedMonth\r\n let-moDataList=\"moDataList\"\r\n let-height=\"height\"\r\n let-calendarFields=\"calendarFields\"\r\n let-viewMode=\"viewMode\"\r\n let-rtl=\"rtl\"\r\n let-today=\"today\"\r\n let-showEvents=\"showEvents\"\r\n let-deviceSize=\"deviceSize\"\r\n let-weekModeDays=\"weekModeDays\"\r\n let-access=\"access\"\r\n>\r\n <bc-calendar-week\r\n fillEmptySpace\r\n [decrement]=\"'2rem'\"\r\n [setMaxHeight]=\"true\"\r\n class=\"tw-overflow-auto\"\r\n [viewMode]=\"viewMode\"\r\n [containerHeight]=\"parentHeight !== 0 ? parentHeight : height\"\r\n [inDialog]=\"inDialog\"\r\n [calendarFields]=\"calendarFields\"\r\n [moDataList]=\"moDataList\"\r\n [rtl]=\"rtl\"\r\n [canAdd]=\"access.Add\"\r\n [canView]=\"access.View\"\r\n [canEdit]=\"access.Edit\"\r\n [canDelete]=\"access.Delete\"\r\n [weekDays]=\"weekDays\"\r\n [weekDaysMin]=\"weekDaysMin\"\r\n [today]=\"today\"\r\n [showEvents]=\"showEvents\"\r\n [days]=\"weekModeDays\"\r\n [deviceSize]=\"deviceSize\"\r\n (dayClick)=\"onDayClick($event)\"\r\n (showEvent)=\"onShowTask()\"\r\n (deleteEvent)=\"deleteTask.emit($event)\"\r\n (editEvent)=\"editTask.emit($event)\"\r\n (daySelect)=\"daySelect.emit($event)\"\r\n (rangeSelect)=\"onRangeSelect($event)\"\r\n ></bc-calendar-week>\r\n</ng-template>\r\n", styles: [":host{display:block;width:100%;height:100%}:host ::ng-deep li.user-calendar .fd-list__form-item{padding:.5rem}.calendar-main-column{flex:1;min-height:0;display:flex;flex-direction:column}.calendar-main-column .calendar-body-region{flex:1;min-height:0;display:flex;flex-direction:column;width:100%}.calendar-body-region.ui-report-gridshell{flex:1 1 auto;min-height:0}.calendar-body-region.ui-report-gridshell.report-grid-wrapper{overflow:auto}.report-layout-fill.calendar-body-region bc-calendar-month,.report-layout-fill.calendar-body-region bc-calendar-week{flex:1 1 auto;min-height:0}.report-layout-inline.calendar-body-region bc-calendar-month,.report-layout-inline.calendar-body-region bc-calendar-week{flex:0 1 auto}.calendar-main-column .calendar-body-region.report-scroll-inherit{flex:0 1 auto;min-height:auto;overflow:visible}\n"] }]
2966
2973
  }], propDecorators: { _divRef: [{
2967
2974
  type: ViewChild,
2968
2975
  args: ['divRef', { static: true }]