barsa-calendar 0.0.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (56) hide show
  1. package/README.md +25 -0
  2. package/esm2020/barsa-calendar.mjs +5 -0
  3. package/esm2020/lib/barsa-calendar.module.mjs +106 -0
  4. package/esm2020/lib/calendar-container/calendar-container.component.mjs +190 -0
  5. package/esm2020/lib/calendar-header/calendar-header.component.mjs +61 -0
  6. package/esm2020/lib/calendar-list/calendar-list.component.mjs +19 -0
  7. package/esm2020/lib/calendar-list-container/calendar-list-container.component.mjs +30 -0
  8. package/esm2020/lib/calendar-list-item/calendar-list-item.component.mjs +14 -0
  9. package/esm2020/lib/calendar-month/calendar-month.component.mjs +244 -0
  10. package/esm2020/lib/calendar-selection-days/calendar-selection-days.component.mjs +193 -0
  11. package/esm2020/lib/calendar-week/calendar-week.component.mjs +182 -0
  12. package/esm2020/lib/constants.mjs +4 -0
  13. package/esm2020/lib/date-time-picker/date-time-picker.component.mjs +324 -0
  14. package/esm2020/lib/day-event-list/day-event-list.component.mjs +53 -0
  15. package/esm2020/lib/day-number-box/day-number-box.component.mjs +105 -0
  16. package/esm2020/lib/days-in-week.pipe.mjs +17 -0
  17. package/esm2020/lib/equal-date.pipe.mjs +23 -0
  18. package/esm2020/lib/event-button/event-button.component.mjs +70 -0
  19. package/esm2020/lib/event-date.pipe.mjs +24 -0
  20. package/esm2020/lib/event-preview/event-preview.component.mjs +60 -0
  21. package/esm2020/lib/event-time.pipe.mjs +22 -0
  22. package/esm2020/lib/from-to-time.pipe.mjs +23 -0
  23. package/esm2020/lib/models.mjs +14 -0
  24. package/esm2020/lib/month-days/month-days.component.mjs +220 -0
  25. package/esm2020/lib/services/calendar.service.mjs +610 -0
  26. package/esm2020/public-api.mjs +21 -0
  27. package/fesm2015/barsa-calendar.mjs +2447 -0
  28. package/fesm2015/barsa-calendar.mjs.map +1 -0
  29. package/fesm2020/barsa-calendar.mjs +2455 -0
  30. package/fesm2020/barsa-calendar.mjs.map +1 -0
  31. package/index.d.ts +5 -0
  32. package/lib/barsa-calendar.module.d.ts +33 -0
  33. package/lib/calendar-container/calendar-container.component.d.ts +73 -0
  34. package/lib/calendar-header/calendar-header.component.d.ts +29 -0
  35. package/lib/calendar-list/calendar-list.component.d.ts +8 -0
  36. package/lib/calendar-list-container/calendar-list-container.component.d.ts +14 -0
  37. package/lib/calendar-list-item/calendar-list-item.component.d.ts +7 -0
  38. package/lib/calendar-month/calendar-month.component.d.ts +70 -0
  39. package/lib/calendar-selection-days/calendar-selection-days.component.d.ts +47 -0
  40. package/lib/calendar-week/calendar-week.component.d.ts +57 -0
  41. package/lib/constants.d.ts +1 -0
  42. package/lib/date-time-picker/date-time-picker.component.d.ts +98 -0
  43. package/lib/day-event-list/day-event-list.component.d.ts +20 -0
  44. package/lib/day-number-box/day-number-box.component.d.ts +30 -0
  45. package/lib/days-in-week.pipe.d.ts +9 -0
  46. package/lib/equal-date.pipe.d.ts +8 -0
  47. package/lib/event-button/event-button.component.d.ts +26 -0
  48. package/lib/event-date.pipe.d.ts +9 -0
  49. package/lib/event-preview/event-preview.component.d.ts +19 -0
  50. package/lib/event-time.pipe.d.ts +9 -0
  51. package/lib/from-to-time.pipe.d.ts +9 -0
  52. package/lib/models.d.ts +107 -0
  53. package/lib/month-days/month-days.component.d.ts +69 -0
  54. package/lib/services/calendar.service.d.ts +70 -0
  55. package/package.json +31 -0
  56. package/public-api.d.ts +17 -0
package/README.md ADDED
@@ -0,0 +1,25 @@
1
+ # BarsaCalendar
2
+
3
+ This library was generated with [Angular CLI](https://github.com/angular/angular-cli) version 11.1.2.
4
+
5
+ ## Code scaffolding
6
+
7
+ Run `ng generate component component-name --project BarsaCalendar` to generate a new component. You can also use `ng generate directive|pipe|service|class|guard|interface|enum|module --project BarsaCalendar`.
8
+
9
+ > Note: Don't forget to add `--project BarsaCalendar` or else it will be added to the default project in your `angular.json` file.
10
+
11
+ ## Build
12
+
13
+ Run `ng build BarsaCalendar` to build the project. The build artifacts will be stored in the `dist/` directory.
14
+
15
+ ## Publishing
16
+
17
+ After building your library with `ng build BarsaCalendar`, go to the dist folder `cd dist/barsa-calendar` and run `npm publish`.
18
+
19
+ ## Running unit tests
20
+
21
+ Run `ng test BarsaCalendar` to execute the unit tests via [Karma](https://karma-runner.github.io).
22
+
23
+ ## Further help
24
+
25
+ To get more help on the Angular CLI use `ng help` or go check out the [Angular CLI Overview and Command Reference](https://angular.io/cli) page.
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Generated bundle index. Do not edit.
3
+ */
4
+ export * from './public-api';
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFyc2EtY2FsZW5kYXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9wcm9qZWN0cy9iYXJzYS1jYWxlbmRhci9zcmMvYmFyc2EtY2FsZW5kYXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLGNBQWMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9wdWJsaWMtYXBpJztcbiJdfQ==
@@ -0,0 +1,106 @@
1
+ import { NgModule, NO_ERRORS_SCHEMA } from '@angular/core';
2
+ import { CommonModule, TitleCasePipe } from '@angular/common';
3
+ import { FormsModule } from '@angular/forms';
4
+ import { FundamentalNgxPlatformModule } from '@fundamental-ngx/platform';
5
+ import { FundamentalNgxCoreModule } from '@fundamental-ngx/core';
6
+ import { CardModule } from '@fundamental-ngx/core/card';
7
+ import { QuickViewModule } from '@fundamental-ngx/core/quick-view';
8
+ import { PopoverModule } from '@fundamental-ngx/core/popover';
9
+ import { BarsaNovinRayCoreModule } from 'barsa-novin-ray-core';
10
+ import { CalendarContainerComponent } from './calendar-container/calendar-container.component';
11
+ import { CalendarListComponent } from './calendar-list/calendar-list.component';
12
+ import { CalendarListContainerComponent } from './calendar-list-container/calendar-list-container.component';
13
+ import { CalendarListItemComponent } from './calendar-list-item/calendar-list-item.component';
14
+ import { CalendarWeekComponent } from './calendar-week/calendar-week.component';
15
+ import { CalendarMonthComponent } from './calendar-month/calendar-month.component';
16
+ import { CalendarService } from './services/calendar.service';
17
+ import { MonthDaysComponent } from './month-days/month-days.component';
18
+ import { DaysInWeekPipe } from './days-in-week.pipe';
19
+ import { EventDatePipe } from './event-date.pipe';
20
+ import { EventTimePipe } from './event-time.pipe';
21
+ import { FromToTimePipe } from './from-to-time.pipe';
22
+ import { EqualDatePipe } from './equal-date.pipe';
23
+ import { CalendarHeaderComponent } from './calendar-header/calendar-header.component';
24
+ import { EventPreviewComponent } from './event-preview/event-preview.component';
25
+ import { DayNumberBoxComponent } from './day-number-box/day-number-box.component';
26
+ import { EventButtonComponent } from './event-button/event-button.component';
27
+ import { DayEventListComponent } from './day-event-list/day-event-list.component';
28
+ import { DateTimePickerComponent } from './date-time-picker/date-time-picker.component';
29
+ import { CalendarSelectionDaysComponent } from './calendar-selection-days/calendar-selection-days.component';
30
+ import * as i0 from "@angular/core";
31
+ const components = [
32
+ CalendarContainerComponent,
33
+ CalendarListComponent,
34
+ CalendarListContainerComponent,
35
+ CalendarListItemComponent,
36
+ CalendarWeekComponent,
37
+ CalendarMonthComponent,
38
+ MonthDaysComponent,
39
+ CalendarHeaderComponent,
40
+ EventPreviewComponent,
41
+ DayNumberBoxComponent,
42
+ EventButtonComponent,
43
+ DayEventListComponent
44
+ ];
45
+ const pipes = [DaysInWeekPipe, EventDatePipe, EventTimePipe, FromToTimePipe, EqualDatePipe];
46
+ export class BarsaCalendarModule {
47
+ }
48
+ BarsaCalendarModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: BarsaCalendarModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
49
+ BarsaCalendarModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.2.7", ngImport: i0, type: BarsaCalendarModule, declarations: [CalendarContainerComponent,
50
+ CalendarListComponent,
51
+ CalendarListContainerComponent,
52
+ CalendarListItemComponent,
53
+ CalendarWeekComponent,
54
+ CalendarMonthComponent,
55
+ MonthDaysComponent,
56
+ CalendarHeaderComponent,
57
+ EventPreviewComponent,
58
+ DayNumberBoxComponent,
59
+ EventButtonComponent,
60
+ DayEventListComponent, DaysInWeekPipe, EventDatePipe, EventTimePipe, FromToTimePipe, EqualDatePipe, DateTimePickerComponent, CalendarSelectionDaysComponent], imports: [CommonModule,
61
+ FormsModule,
62
+ BarsaNovinRayCoreModule,
63
+ FundamentalNgxCoreModule,
64
+ FundamentalNgxPlatformModule,
65
+ PopoverModule,
66
+ CardModule,
67
+ QuickViewModule], exports: [CalendarContainerComponent,
68
+ CalendarListComponent,
69
+ CalendarListContainerComponent,
70
+ CalendarListItemComponent,
71
+ CalendarWeekComponent,
72
+ CalendarMonthComponent,
73
+ MonthDaysComponent,
74
+ CalendarHeaderComponent,
75
+ EventPreviewComponent,
76
+ DayNumberBoxComponent,
77
+ EventButtonComponent,
78
+ DayEventListComponent, DateTimePickerComponent, CalendarSelectionDaysComponent] });
79
+ BarsaCalendarModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: BarsaCalendarModule, providers: [TitleCasePipe, CalendarService, ...pipes], imports: [CommonModule,
80
+ FormsModule,
81
+ BarsaNovinRayCoreModule,
82
+ FundamentalNgxCoreModule,
83
+ FundamentalNgxPlatformModule,
84
+ PopoverModule,
85
+ CardModule,
86
+ QuickViewModule] });
87
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: BarsaCalendarModule, decorators: [{
88
+ type: NgModule,
89
+ args: [{
90
+ schemas: [NO_ERRORS_SCHEMA],
91
+ imports: [
92
+ CommonModule,
93
+ FormsModule,
94
+ BarsaNovinRayCoreModule,
95
+ FundamentalNgxCoreModule,
96
+ FundamentalNgxPlatformModule,
97
+ PopoverModule,
98
+ CardModule,
99
+ QuickViewModule
100
+ ],
101
+ declarations: [...components, ...pipes, DateTimePickerComponent, CalendarSelectionDaysComponent],
102
+ providers: [TitleCasePipe, CalendarService, ...pipes],
103
+ exports: [...components, DateTimePickerComponent, CalendarSelectionDaysComponent]
104
+ }]
105
+ }] });
106
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"barsa-calendar.module.js","sourceRoot":"","sources":["../../../../projects/barsa-calendar/src/lib/barsa-calendar.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { NgModule, NO_ERRORS_SCHEMA } from '@angular/core';\r\nimport { CommonModule, TitleCasePipe } from '@angular/common';\r\nimport { FormsModule } from '@angular/forms';\r\n\r\nimport { FundamentalNgxPlatformModule } from '@fundamental-ngx/platform';\r\nimport { FundamentalNgxCoreModule } from '@fundamental-ngx/core';\r\nimport { CardModule } from '@fundamental-ngx/core/card';\r\nimport { QuickViewModule } from '@fundamental-ngx/core/quick-view';\r\nimport { PopoverModule } from '@fundamental-ngx/core/popover';\r\n\r\nimport { BarsaNovinRayCoreModule } from 'barsa-novin-ray-core';\r\n\r\nimport { CalendarContainerComponent } from './calendar-container/calendar-container.component';\r\nimport { CalendarListComponent } from './calendar-list/calendar-list.component';\r\nimport { CalendarListContainerComponent } from './calendar-list-container/calendar-list-container.component';\r\nimport { CalendarListItemComponent } from './calendar-list-item/calendar-list-item.component';\r\nimport { CalendarWeekComponent } from './calendar-week/calendar-week.component';\r\nimport { CalendarMonthComponent } from './calendar-month/calendar-month.component';\r\nimport { CalendarService } from './services/calendar.service';\r\nimport { MonthDaysComponent } from './month-days/month-days.component';\r\nimport { DaysInWeekPipe } from './days-in-week.pipe';\r\nimport { EventDatePipe } from './event-date.pipe';\r\nimport { EventTimePipe } from './event-time.pipe';\r\nimport { FromToTimePipe } from './from-to-time.pipe';\r\nimport { EqualDatePipe } from './equal-date.pipe';\r\nimport { CalendarHeaderComponent } from './calendar-header/calendar-header.component';\r\nimport { EventPreviewComponent } from './event-preview/event-preview.component';\r\nimport { DayNumberBoxComponent } from './day-number-box/day-number-box.component';\r\nimport { EventButtonComponent } from './event-button/event-button.component';\r\nimport { DayEventListComponent } from './day-event-list/day-event-list.component';\r\nimport { DateTimePickerComponent } from './date-time-picker/date-time-picker.component';\r\nimport { CalendarSelectionDaysComponent } from './calendar-selection-days/calendar-selection-days.component';\r\n\r\nconst components = [\r\n    CalendarContainerComponent,\r\n    CalendarListComponent,\r\n    CalendarListContainerComponent,\r\n    CalendarListItemComponent,\r\n    CalendarWeekComponent,\r\n    CalendarMonthComponent,\r\n    MonthDaysComponent,\r\n    CalendarHeaderComponent,\r\n    EventPreviewComponent,\r\n    DayNumberBoxComponent,\r\n    EventButtonComponent,\r\n    DayEventListComponent\r\n];\r\nconst pipes = [DaysInWeekPipe, EventDatePipe, EventTimePipe, FromToTimePipe, EqualDatePipe];\r\n@NgModule({\r\n    schemas: [NO_ERRORS_SCHEMA],\r\n    imports: [\r\n        CommonModule,\r\n        FormsModule,\r\n        BarsaNovinRayCoreModule,\r\n        FundamentalNgxCoreModule,\r\n        FundamentalNgxPlatformModule,\r\n        PopoverModule,\r\n        CardModule,\r\n        QuickViewModule\r\n    ],\r\n    declarations: [...components, ...pipes, DateTimePickerComponent, CalendarSelectionDaysComponent],\r\n    providers: [TitleCasePipe, CalendarService, ...pipes],\r\n    exports: [...components, DateTimePickerComponent, CalendarSelectionDaysComponent]\r\n})\r\nexport class BarsaCalendarModule {}\r\n"]}
@@ -0,0 +1,190 @@
1
+ import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output } from '@angular/core';
2
+ import { BehaviorSubject, combineLatest, of } from 'rxjs';
3
+ import { map, switchMap, takeUntil } from 'rxjs/operators';
4
+ import { ReportViewBaseComponent, DateService, LogService, getDateService } from 'barsa-novin-ray-core';
5
+ import * as i0 from "@angular/core";
6
+ import * as i1 from "@angular/common";
7
+ import * as i2 from "barsa-novin-ray-core";
8
+ import * as i3 from "../services/calendar.service";
9
+ import * as i4 from "../calendar-list-container/calendar-list-container.component";
10
+ import * as i5 from "../calendar-week/calendar-week.component";
11
+ import * as i6 from "../calendar-month/calendar-month.component";
12
+ import * as i7 from "../calendar-header/calendar-header.component";
13
+ export class CalendarContainerComponent extends ReportViewBaseComponent {
14
+ constructor(_titleCase, _bbbTranslate, _calendarService, _dateService, _el, _cdr, _renderer2, _findColumnByDbName, _ulvMainService, _portalService) {
15
+ super(_el, _cdr, _renderer2, _findColumnByDbName, _ulvMainService, _portalService);
16
+ this._titleCase = _titleCase;
17
+ this._bbbTranslate = _bbbTranslate;
18
+ this._calendarService = _calendarService;
19
+ this._dateService = _dateService;
20
+ this._el = _el;
21
+ this._cdr = _cdr;
22
+ this._renderer2 = _renderer2;
23
+ this._findColumnByDbName = _findColumnByDbName;
24
+ this._ulvMainService = _ulvMainService;
25
+ this._portalService = _portalService;
26
+ this.deleteTask = new EventEmitter();
27
+ this.editTask = new EventEmitter();
28
+ this.daySelect = new EventEmitter();
29
+ this.loadData = new EventEmitter();
30
+ this.todayIndex = -1;
31
+ this.eventMoDataList$ = new BehaviorSubject([]);
32
+ }
33
+ ngOnInit() {
34
+ super.ngOnInit();
35
+ this.prepare();
36
+ this._setWidthAndHeight();
37
+ this.prepareMoDataList(this.moDataList);
38
+ this.selectedMonth$.pipe(takeUntil(this._onDestroy$)).subscribe((month) => {
39
+ this.loadData.emit({
40
+ start: month.days[0].date,
41
+ end: month.days[month.days.length - 1].date
42
+ });
43
+ });
44
+ // this.setTasks(this.calendars, this.moDataList, this.calendarFields);
45
+ }
46
+ ngOnChanges(changes) {
47
+ super.ngOnChanges(changes);
48
+ const { moDataList, deviceSize } = changes;
49
+ if (moDataList && !moDataList.firstChange) {
50
+ this.prepareMoDataList(changes.moDataList.currentValue);
51
+ this._cdr.detectChanges();
52
+ }
53
+ if (deviceSize && !deviceSize.firstChange) {
54
+ this._setWidthAndHeight();
55
+ this._cdr.detectChanges();
56
+ }
57
+ }
58
+ onDayClick(day) {
59
+ this._calendarService.setMode('day', day);
60
+ }
61
+ onShowTask() { }
62
+ onSlideChange(selected) {
63
+ this._calendarService.setSelected(selected);
64
+ }
65
+ onMonthCarouselLoaded({ object }) {
66
+ object.selectedPage = 1;
67
+ }
68
+ onToday() {
69
+ this._calendarService.gotoToday();
70
+ }
71
+ onModeChange(mode) {
72
+ this._calendarService.setMode(mode);
73
+ }
74
+ onRangeChange(e) {
75
+ this._calendarService.rangeSelect(e.startDay, e.endDay, e.monthInfo);
76
+ }
77
+ onPrevTap() {
78
+ // this.gotoPage(this.monthCarouselView.nativeElement.selectedPage - 1);
79
+ this._calendarService.loadPrevious();
80
+ }
81
+ onNextTap() {
82
+ this._calendarService.loadNext();
83
+ // this.gotoPage(this.monthCarouselView.nativeElement.selectedPage + 1);
84
+ }
85
+ onSelectedChange(day) {
86
+ this.selectedDay = { ...day };
87
+ }
88
+ prepareMoDataList(moDataList) {
89
+ this.eventMoDataList$.next(moDataList.map((event) => ({
90
+ ...event,
91
+ id: event.Id,
92
+ $StartDateInfo: this._dateService.getDateInfo(event[this.calendarFields.StartDate]),
93
+ $EndDateInfo: this._dateService.getDateInfo(event[this.calendarFields.EndDate])
94
+ })));
95
+ }
96
+ addTd(table, tr, event, colSpan) {
97
+ const colSpanCount = tr.length > 0 ? tr.map((c) => c.colSpan).reduce((a, b) => a + b) > 6 : 0;
98
+ if (colSpanCount) {
99
+ table.push(tr);
100
+ tr = [];
101
+ }
102
+ tr.push({ type: 'td', colSpan, event });
103
+ }
104
+ prepare() {
105
+ this.weekDaysMin = this._calendarService.weekDaysMin();
106
+ this.weekDays = this._calendarService.weekDays();
107
+ this.selectedMonth$ = this._calendarService.selected$;
108
+ this.days$ = this._calendarService.days$;
109
+ this.today = this._calendarService.today;
110
+ this.mode$ = this._calendarService.mode$;
111
+ this.monthWeeksCount$ = this.mode$.pipe(map((mode) => {
112
+ if (mode === 'month') {
113
+ return this._calendarService.selectedMonth.weeksCount;
114
+ }
115
+ return 0;
116
+ }));
117
+ this.modeTitle$ = combineLatest([this.days$, this.mode$]).pipe(takeUntil(this._onDestroy$), switchMap(([, mode]) => {
118
+ if (mode === 'customMonth') {
119
+ return of(`${this._calendarService.weeksCount} ${this._bbbTranslate.transform('Week')}`);
120
+ }
121
+ return of(this._bbbTranslate.transform(this._titleCase.transform(mode)));
122
+ }));
123
+ this.weekModeDays$ = this._calendarService.weekModeDays$;
124
+ this._calendarService.calendars$.pipe(takeUntil(this._onDestroy$)).subscribe((calendars) => {
125
+ const eventCalendars = [...calendars];
126
+ // eventCalendars = eventCalendars.splice(this.selectedIndex, 3);
127
+ this.calendars = eventCalendars;
128
+ // if (this.monthCarouselView) {
129
+ // this.monthCarouselView.nativeElement.selectedPage = 1;
130
+ // }
131
+ });
132
+ // .pipe(takeUntil(this._onDestroy$))
133
+ // .subscribe((todayIndex) => {
134
+ // this.selectedIndex = this.todayIndex = todayIndex;
135
+ // this.gotoPage(this.todayIndex);
136
+ // });
137
+ this.title$ = combineLatest([this.weekModeDays$, this.selectedMonth$, this.days$, this.mode$]).pipe(takeUntil(this._onDestroy$), switchMap(([weekModeDays, monthInfo, days, mode]) => {
138
+ let monthName = monthInfo.dateInfo.monthName;
139
+ const year = monthInfo.dateInfo.strYear;
140
+ if (mode !== 'month') {
141
+ let firstDayInfo;
142
+ let lastDayInfo;
143
+ const daysTemp = mode === 'customMonth' ? days : weekModeDays;
144
+ if (daysTemp.length > 0) {
145
+ firstDayInfo = daysTemp[0];
146
+ lastDayInfo = daysTemp[daysTemp.length - 1];
147
+ monthName = firstDayInfo.monthName;
148
+ if (firstDayInfo.month !== lastDayInfo.month) {
149
+ monthName = `${firstDayInfo.monthName} -
150
+ ${lastDayInfo.monthName}`;
151
+ }
152
+ }
153
+ }
154
+ return of(`${monthName} ${year}`);
155
+ }));
156
+ }
157
+ _setWidthAndHeight() {
158
+ this.width = this._el.nativeElement.offsetWidth;
159
+ this.height = this._el.nativeElement.offsetHeight - 45;
160
+ }
161
+ }
162
+ CalendarContainerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: CalendarContainerComponent, deps: [{ token: i1.TitleCasePipe }, { token: i2.BbbTranslatePipe }, { token: i3.CalendarService }, { token: i2.DateService }, { token: i0.ElementRef }, { token: i0.ChangeDetectorRef }, { token: i0.Renderer2 }, { token: i2.FindColumnByDbNamePipe }, { token: i2.UlvMainService }, { token: i2.PortalService }], target: i0.ɵɵFactoryTarget.Component });
163
+ CalendarContainerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: CalendarContainerComponent, selector: "bc-calendar-container", inputs: { calendarFields: "calendarFields" }, outputs: { deleteTask: "deleteTask", editTask: "editTask", daySelect: "daySelect", loadData: "loadData" }, providers: [
164
+ {
165
+ provide: DateService,
166
+ useFactory: getDateService,
167
+ deps: [LogService]
168
+ }
169
+ ], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<bc-calendar-header\n [monthInfo]=\"(selectedMonth$ | async)!!\"\n [weekModeDays]=\"(weekModeDays$ | async)!!\"\n [rtl]=\"rtl\"\n [mode]=\"(mode$ | async)!!\"\n [modeTitle]=\"(modeTitle$ | async)!!\"\n [title]=\"(title$ | async)!!\"\n (modeChange)=\"onModeChange($event)\"\n (prevTap)=\"onPrevTap()\"\n (nextTap)=\"onNextTap()\"\n (today)=\"onToday()\"\n (rangeChange)=\"onRangeChange($event)\"\n>\n</bc-calendar-header>\n\n<ng-container [ngSwitch]=\"mode$ | async\">\n <ng-container *ngSwitchCase=\"'week'\">\n <ng-container\n *ngTemplateOutlet=\"\n weekCalendar;\n context: {\n $implicit: selectedMonth$ | async,\n moDataList: eventMoDataList$ | async,\n width: width,\n height: height,\n rtl: rtl,\n showEvents: showEvents,\n weekModeDays: weekModeDays$ | async,\n today: today,\n deviceSize: deviceSize,\n calendarFields: calendarFields,\n access: access\n }\n \"\n ></ng-container>\n </ng-container>\n <ng-container *ngSwitchCase=\"'day'\">\n <ng-container\n *ngTemplateOutlet=\"\n weekCalendar;\n context: {\n $implicit: selectedMonth$ | async,\n moDataList: eventMoDataList$ | async,\n width: width,\n height: height,\n rtl: rtl,\n showEvents: showEvents,\n weekModeDays: weekModeDays$ | async,\n today: today,\n deviceSize: deviceSize,\n calendarFields: calendarFields,\n access: access\n }\n \"\n ></ng-container>\n </ng-container>\n <ng-container *ngSwitchCase=\"'list'\"></ng-container>\n <ng-container *ngSwitchDefault>\n <ng-container\n *ngTemplateOutlet=\"\n monthCalendar;\n context: {\n $implicit: days$ | async,\n moDataList: eventMoDataList$ | async,\n width: width,\n height: height,\n rtl: rtl,\n showEvents: showEvents,\n today: today,\n deviceSize: deviceSize,\n calendarFields: calendarFields,\n monthWeeksCount: monthWeeksCount$ | async,\n access: access\n }\n \"\n ></ng-container>\n </ng-container>\n</ng-container>\n\n<ng-template\n #monthCalendar\n let-days\n let-moDataList=\"moDataList\"\n let-width=\"width\"\n let-height=\"height\"\n let-calendarFields=\"calendarFields\"\n let-rtl=\"rtl\"\n let-today=\"today\"\n let-showEvents=\"showEvents\"\n let-deviceSize=\"deviceSize\"\n let-monthWeeksCount=\"monthWeeksCount\"\n let-access=\"access\"\n>\n <bc-calendar-month\n [style.width]=\"width\"\n [containerHeight]=\"parentHeight !== 0 ? parentHeight : height\"\n [containerWidth]=\"width\"\n [calendarFields]=\"calendarFields\"\n [moDataList]=\"moDataList\"\n [monthWeeksCount]=\"monthWeeksCount\"\n [rtl]=\"rtl\"\n [weekDays]=\"weekDays\"\n [weekDaysMin]=\"weekDaysMin\"\n [today]=\"today\"\n [showEvents]=\"showEvents\"\n [days]=\"days\"\n [canAdd]=\"access.Add\"\n [canEdit]=\"access.Edit\"\n [canDelete]=\"access.Delete\"\n [deviceSize]=\"deviceSize\"\n (dayClick)=\"onDayClick($event)\"\n (showEvent)=\"onShowTask()\"\n (deleteEvent)=\"deleteTask.emit($event)\"\n (editEvent)=\"editTask.emit($event)\"\n (daySelect)=\"daySelect.emit($event)\"\n ></bc-calendar-month>\n</ng-template>\n\n<ng-template #listCalendar>\n <bc-calendar-list-container\n [showEvents]=\"showEvents\"\n [selectedDay]=\"selectedDay\"\n [calendarFields]=\"calendarFields\"\n (showEventsTap)=\"showEvents = !showEvents\"\n ></bc-calendar-list-container>\n</ng-template>\n\n<ng-template\n #weekCalendar\n let-selectedMonth\n let-moDataList=\"moDataList\"\n let-width=\"width\"\n let-height=\"height\"\n let-calendarFields=\"calendarFields\"\n let-rtl=\"rtl\"\n let-today=\"today\"\n let-showEvents=\"showEvents\"\n let-deviceSize=\"deviceSize\"\n let-weekModeDays=\"weekModeDays\"\n let-access=\"access\"\n>\n <bc-calendar-week\n [style.width]=\"width\"\n [containerHeight]=\"parentHeight !== 0 ? parentHeight : height\"\n [containerWidth]=\"width\"\n [inDialog]=\"inDialog\"\n [calendarFields]=\"calendarFields\"\n [moDataList]=\"moDataList\"\n [rtl]=\"rtl\"\n [canAdd]=\"access.Add\"\n [canEdit]=\"access.Edit\"\n [canDelete]=\"access.Delete\"\n [weekDays]=\"weekDays\"\n [weekDaysMin]=\"weekDaysMin\"\n [today]=\"today\"\n [showEvents]=\"showEvents\"\n [days]=\"weekModeDays\"\n [deviceSize]=\"deviceSize\"\n (dayClick)=\"onDayClick($event)\"\n (showEvent)=\"onShowTask()\"\n (deleteEvent)=\"deleteTask.emit($event)\"\n (editEvent)=\"editTask.emit($event)\"\n (daySelect)=\"daySelect.emit($event)\"\n ></bc-calendar-week>\n</ng-template>\n", styles: [":host{display:block;width:100%;height:100%}\n"], dependencies: [{ kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i1.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i1.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i1.NgSwitchDefault, selector: "[ngSwitchDefault]" }, { kind: "component", type: i4.CalendarListContainerComponent, selector: "bc-calendar-list-container", inputs: ["view", "reportItemComponentName", "showEvents", "selectedDay", "calendarFields"], outputs: ["showEventsTap"] }, { kind: "component", type: i5.CalendarWeekComponent, selector: "bc-calendar-week", inputs: ["weekDays", "weekDaysMin", "today", "containerHeight", "calendarFields", "rtl", "inDialog", "deviceSize", "moDataList", "days", "canDelete", "canAdd", "canEdit"], outputs: ["editEvent", "deleteEvent", "showEvent", "daySelect", "dayClick"] }, { kind: "component", type: i6.CalendarMonthComponent, selector: "bc-calendar-month", inputs: ["monthWeeksCount", "weekDays", "weekDaysMin", "today", "containerHeight", "days", "calendarFields", "rtl", "deviceSize", "moDataList", "datePicker", "rangePicker", "canDelete", "canAdd", "canEdit", "selectedDate", "startSelectedDayIndex", "endSelectedDayIndex"], outputs: ["editEvent", "deleteEvent", "daySelect", "dayClick", "dayMouseMove", "dayMouseUp", "dayMouseDown", "showEvent"] }, { kind: "component", type: i7.CalendarHeaderComponent, selector: "bc-calendar-header", inputs: ["monthInfo", "weekModeDays", "hideMode", "modeTitle", "title", "rtl", "mode"], outputs: ["prevTap", "nextTap", "modeChange", "rangeChange", "today"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
170
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: CalendarContainerComponent, decorators: [{
171
+ type: Component,
172
+ args: [{ selector: 'bc-calendar-container', changeDetection: ChangeDetectionStrategy.OnPush, providers: [
173
+ {
174
+ provide: DateService,
175
+ useFactory: getDateService,
176
+ deps: [LogService]
177
+ }
178
+ ], template: "<bc-calendar-header\n [monthInfo]=\"(selectedMonth$ | async)!!\"\n [weekModeDays]=\"(weekModeDays$ | async)!!\"\n [rtl]=\"rtl\"\n [mode]=\"(mode$ | async)!!\"\n [modeTitle]=\"(modeTitle$ | async)!!\"\n [title]=\"(title$ | async)!!\"\n (modeChange)=\"onModeChange($event)\"\n (prevTap)=\"onPrevTap()\"\n (nextTap)=\"onNextTap()\"\n (today)=\"onToday()\"\n (rangeChange)=\"onRangeChange($event)\"\n>\n</bc-calendar-header>\n\n<ng-container [ngSwitch]=\"mode$ | async\">\n <ng-container *ngSwitchCase=\"'week'\">\n <ng-container\n *ngTemplateOutlet=\"\n weekCalendar;\n context: {\n $implicit: selectedMonth$ | async,\n moDataList: eventMoDataList$ | async,\n width: width,\n height: height,\n rtl: rtl,\n showEvents: showEvents,\n weekModeDays: weekModeDays$ | async,\n today: today,\n deviceSize: deviceSize,\n calendarFields: calendarFields,\n access: access\n }\n \"\n ></ng-container>\n </ng-container>\n <ng-container *ngSwitchCase=\"'day'\">\n <ng-container\n *ngTemplateOutlet=\"\n weekCalendar;\n context: {\n $implicit: selectedMonth$ | async,\n moDataList: eventMoDataList$ | async,\n width: width,\n height: height,\n rtl: rtl,\n showEvents: showEvents,\n weekModeDays: weekModeDays$ | async,\n today: today,\n deviceSize: deviceSize,\n calendarFields: calendarFields,\n access: access\n }\n \"\n ></ng-container>\n </ng-container>\n <ng-container *ngSwitchCase=\"'list'\"></ng-container>\n <ng-container *ngSwitchDefault>\n <ng-container\n *ngTemplateOutlet=\"\n monthCalendar;\n context: {\n $implicit: days$ | async,\n moDataList: eventMoDataList$ | async,\n width: width,\n height: height,\n rtl: rtl,\n showEvents: showEvents,\n today: today,\n deviceSize: deviceSize,\n calendarFields: calendarFields,\n monthWeeksCount: monthWeeksCount$ | async,\n access: access\n }\n \"\n ></ng-container>\n </ng-container>\n</ng-container>\n\n<ng-template\n #monthCalendar\n let-days\n let-moDataList=\"moDataList\"\n let-width=\"width\"\n let-height=\"height\"\n let-calendarFields=\"calendarFields\"\n let-rtl=\"rtl\"\n let-today=\"today\"\n let-showEvents=\"showEvents\"\n let-deviceSize=\"deviceSize\"\n let-monthWeeksCount=\"monthWeeksCount\"\n let-access=\"access\"\n>\n <bc-calendar-month\n [style.width]=\"width\"\n [containerHeight]=\"parentHeight !== 0 ? parentHeight : height\"\n [containerWidth]=\"width\"\n [calendarFields]=\"calendarFields\"\n [moDataList]=\"moDataList\"\n [monthWeeksCount]=\"monthWeeksCount\"\n [rtl]=\"rtl\"\n [weekDays]=\"weekDays\"\n [weekDaysMin]=\"weekDaysMin\"\n [today]=\"today\"\n [showEvents]=\"showEvents\"\n [days]=\"days\"\n [canAdd]=\"access.Add\"\n [canEdit]=\"access.Edit\"\n [canDelete]=\"access.Delete\"\n [deviceSize]=\"deviceSize\"\n (dayClick)=\"onDayClick($event)\"\n (showEvent)=\"onShowTask()\"\n (deleteEvent)=\"deleteTask.emit($event)\"\n (editEvent)=\"editTask.emit($event)\"\n (daySelect)=\"daySelect.emit($event)\"\n ></bc-calendar-month>\n</ng-template>\n\n<ng-template #listCalendar>\n <bc-calendar-list-container\n [showEvents]=\"showEvents\"\n [selectedDay]=\"selectedDay\"\n [calendarFields]=\"calendarFields\"\n (showEventsTap)=\"showEvents = !showEvents\"\n ></bc-calendar-list-container>\n</ng-template>\n\n<ng-template\n #weekCalendar\n let-selectedMonth\n let-moDataList=\"moDataList\"\n let-width=\"width\"\n let-height=\"height\"\n let-calendarFields=\"calendarFields\"\n let-rtl=\"rtl\"\n let-today=\"today\"\n let-showEvents=\"showEvents\"\n let-deviceSize=\"deviceSize\"\n let-weekModeDays=\"weekModeDays\"\n let-access=\"access\"\n>\n <bc-calendar-week\n [style.width]=\"width\"\n [containerHeight]=\"parentHeight !== 0 ? parentHeight : height\"\n [containerWidth]=\"width\"\n [inDialog]=\"inDialog\"\n [calendarFields]=\"calendarFields\"\n [moDataList]=\"moDataList\"\n [rtl]=\"rtl\"\n [canAdd]=\"access.Add\"\n [canEdit]=\"access.Edit\"\n [canDelete]=\"access.Delete\"\n [weekDays]=\"weekDays\"\n [weekDaysMin]=\"weekDaysMin\"\n [today]=\"today\"\n [showEvents]=\"showEvents\"\n [days]=\"weekModeDays\"\n [deviceSize]=\"deviceSize\"\n (dayClick)=\"onDayClick($event)\"\n (showEvent)=\"onShowTask()\"\n (deleteEvent)=\"deleteTask.emit($event)\"\n (editEvent)=\"editTask.emit($event)\"\n (daySelect)=\"daySelect.emit($event)\"\n ></bc-calendar-week>\n</ng-template>\n", styles: [":host{display:block;width:100%;height:100%}\n"] }]
179
+ }], ctorParameters: function () { return [{ type: i1.TitleCasePipe }, { type: i2.BbbTranslatePipe }, { type: i3.CalendarService }, { type: i2.DateService }, { type: i0.ElementRef }, { type: i0.ChangeDetectorRef }, { type: i0.Renderer2 }, { type: i2.FindColumnByDbNamePipe }, { type: i2.UlvMainService }, { type: i2.PortalService }]; }, propDecorators: { calendarFields: [{
180
+ type: Input
181
+ }], deleteTask: [{
182
+ type: Output
183
+ }], editTask: [{
184
+ type: Output
185
+ }], daySelect: [{
186
+ type: Output
187
+ }], loadData: [{
188
+ type: Output
189
+ }] } });
190
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar-container.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-calendar/src/lib/calendar-container/calendar-container.component.ts","../../../../../projects/barsa-calendar/src/lib/calendar-container/calendar-container.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    EventEmitter,\n    Input,\n    OnChanges,\n    OnInit,\n    Output,\n    Renderer2,\n    SimpleChanges\n} from '@angular/core';\nimport { TitleCasePipe } from '@angular/common';\n\nimport { BehaviorSubject, combineLatest, Observable, of } from 'rxjs';\nimport { map, switchMap, takeUntil } from 'rxjs/operators';\n\nimport {\n    UiReportViewBaseSetting,\n    ReportViewBaseComponent,\n    DateService,\n    LogService,\n    getDateService,\n    MetaobjectDataModel,\n    CalendarMetaobjectDataModel,\n    BbbTranslatePipe,\n    FindColumnByDbNamePipe,\n    UlvMainService,\n    PortalService\n} from 'barsa-novin-ray-core';\nimport { CalendarMode, CalendarMonthInfo, Day } from '../models';\nimport { CalendarService } from '../services/calendar.service';\n\n@Component({\n    selector: 'bc-calendar-container',\n    templateUrl: './calendar-container.component.html',\n    styleUrls: ['./calendar-container.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        {\n            provide: DateService,\n            useFactory: getDateService,\n            deps: [LogService]\n        }\n    ]\n})\nexport class CalendarContainerComponent\n    extends ReportViewBaseComponent<UiReportViewBaseSetting>\n    implements OnInit, OnChanges\n{\n    @Input() calendarFields;\n    @Output() deleteTask = new EventEmitter<MetaobjectDataModel>();\n    @Output() editTask = new EventEmitter<MetaobjectDataModel>();\n    @Output() daySelect = new EventEmitter<Date>();\n    @Output() loadData = new EventEmitter<{ start: Date; end: any }>();\n    selectedDay: Day;\n    todayIndex = -1;\n    selectedIndex: any;\n    calendars: CalendarMonthInfo[];\n    showEvents: boolean;\n    width: number;\n    height: number;\n    selectedMonth$: Observable<CalendarMonthInfo>;\n    today: Date;\n    weekDaysMin: string[];\n    weekDays: string[];\n    mode$: Observable<CalendarMode>;\n    selectedWeek$: Observable<number>;\n    weekModeDays$: Observable<Day[]>;\n    days$: Observable<Day[]>;\n    weeksCount: number;\n    firstWeekIndex: number;\n    monthWeeksCount$: Observable<number>;\n    modeTitle$: Observable<string>;\n    title$: Observable<string>;\n    eventMoDataList$ = new BehaviorSubject<MetaobjectDataModel[]>([]);\n    constructor(\n        private _titleCase: TitleCasePipe,\n        private _bbbTranslate: BbbTranslatePipe,\n        private _calendarService: CalendarService,\n        private _dateService: DateService,\n        protected _el: ElementRef,\n        protected _cdr: ChangeDetectorRef,\n        protected _renderer2: Renderer2,\n        protected _findColumnByDbName: FindColumnByDbNamePipe,\n        protected _ulvMainService: UlvMainService,\n        protected _portalService: PortalService\n    ) {\n        super(_el, _cdr, _renderer2, _findColumnByDbName, _ulvMainService, _portalService);\n    }\n    ngOnInit(): void {\n        super.ngOnInit();\n        this.prepare();\n        this._setWidthAndHeight();\n        this.prepareMoDataList(this.moDataList);\n        this.selectedMonth$.pipe(takeUntil(this._onDestroy$)).subscribe((month: CalendarMonthInfo) => {\n            this.loadData.emit({\n                start: month.days[0].date,\n                end: month.days[month.days.length - 1].date\n            });\n        });\n        // this.setTasks(this.calendars, this.moDataList, this.calendarFields);\n    }\n    ngOnChanges(changes: SimpleChanges): void {\n        super.ngOnChanges(changes);\n        const { moDataList, deviceSize } = changes;\n        if (moDataList && !moDataList.firstChange) {\n            this.prepareMoDataList(changes.moDataList.currentValue);\n            this._cdr.detectChanges();\n        }\n        if (deviceSize && !deviceSize.firstChange) {\n            this._setWidthAndHeight();\n            this._cdr.detectChanges();\n        }\n    }\n\n    onDayClick(day: Day): void {\n        this._calendarService.setMode('day', day);\n    }\n    onShowTask(): void {}\n    onSlideChange(selected: CalendarMonthInfo): void {\n        this._calendarService.setSelected(selected);\n    }\n    onMonthCarouselLoaded({ object }): void {\n        object.selectedPage = 1;\n    }\n\n    onToday(): void {\n        this._calendarService.gotoToday();\n    }\n    onModeChange(mode: CalendarMode): void {\n        this._calendarService.setMode(mode);\n    }\n    onRangeChange(e: { startDay: Day; endDay: Day; monthInfo: CalendarMonthInfo }): void {\n        this._calendarService.rangeSelect(e.startDay, e.endDay, e.monthInfo);\n    }\n    onPrevTap(): void {\n        //   this.gotoPage(this.monthCarouselView.nativeElement.selectedPage - 1);\n        this._calendarService.loadPrevious();\n    }\n\n    onNextTap(): void {\n        this._calendarService.loadNext();\n        // this.gotoPage(this.monthCarouselView.nativeElement.selectedPage + 1);\n    }\n\n    onSelectedChange(day: Day): void {\n        this.selectedDay = { ...day };\n    }\n\n    prepareMoDataList(moDataList: MetaobjectDataModel[]): void {\n        this.eventMoDataList$.next(\n            moDataList.map((event) => ({\n                ...event,\n                id: event.Id, // because in core.js calendar selection adapter read id with lowercase\n                $StartDateInfo: this._dateService.getDateInfo(event[this.calendarFields.StartDate]),\n                $EndDateInfo: this._dateService.getDateInfo(event[this.calendarFields.EndDate])\n            }))\n        );\n    }\n\n    addTd(table: any[], tr: any[], event: CalendarMetaobjectDataModel, colSpan: number): void {\n        const colSpanCount = tr.length > 0 ? tr.map((c) => c.colSpan).reduce((a, b) => a + b) > 6 : 0;\n        if (colSpanCount) {\n            table.push(tr);\n            tr = [];\n        }\n        tr.push({ type: 'td', colSpan, event });\n    }\n    private prepare(): void {\n        this.weekDaysMin = this._calendarService.weekDaysMin();\n        this.weekDays = this._calendarService.weekDays();\n        this.selectedMonth$ = this._calendarService.selected$;\n        this.days$ = this._calendarService.days$;\n        this.today = this._calendarService.today;\n        this.mode$ = this._calendarService.mode$;\n\n        this.monthWeeksCount$ = this.mode$.pipe(\n            map((mode) => {\n                if (mode === 'month') {\n                    return this._calendarService.selectedMonth.weeksCount;\n                }\n                return 0;\n            })\n        );\n        this.modeTitle$ = combineLatest([this.days$, this.mode$]).pipe(\n            takeUntil(this._onDestroy$),\n            switchMap(([, mode]) => {\n                if (mode === 'customMonth') {\n                    return of(`${this._calendarService.weeksCount}  ${this._bbbTranslate.transform('Week')}`);\n                }\n                return of(this._bbbTranslate.transform(this._titleCase.transform(mode)));\n            })\n        );\n\n        this.weekModeDays$ = this._calendarService.weekModeDays$;\n        this._calendarService.calendars$.pipe(takeUntil(this._onDestroy$)).subscribe((calendars) => {\n            const eventCalendars = [...calendars];\n            // eventCalendars = eventCalendars.splice(this.selectedIndex, 3);\n            this.calendars = eventCalendars;\n            // if (this.monthCarouselView) {\n            //   this.monthCarouselView.nativeElement.selectedPage = 1;\n            // }\n        });\n\n        // .pipe(takeUntil(this._onDestroy$))\n        //   .subscribe((todayIndex) => {\n        //     this.selectedIndex = this.todayIndex = todayIndex;\n        //     this.gotoPage(this.todayIndex);\n        //   });\n        this.title$ = combineLatest([this.weekModeDays$, this.selectedMonth$, this.days$, this.mode$]).pipe(\n            takeUntil(this._onDestroy$),\n            switchMap(([weekModeDays, monthInfo, days, mode]) => {\n                let monthName = monthInfo.dateInfo.monthName;\n                const year = monthInfo.dateInfo.strYear;\n\n                if (mode !== 'month') {\n                    let firstDayInfo: Day;\n                    let lastDayInfo: Day;\n                    const daysTemp = mode === 'customMonth' ? days : weekModeDays;\n                    if (daysTemp.length > 0) {\n                        firstDayInfo = daysTemp[0];\n                        lastDayInfo = daysTemp[daysTemp.length - 1];\n                        monthName = firstDayInfo.monthName;\n                        if (firstDayInfo.month !== lastDayInfo.month) {\n                            monthName = `${firstDayInfo.monthName} -\n              ${lastDayInfo.monthName}`;\n                        }\n                    }\n                }\n                return of(`${monthName}  ${year}`);\n            })\n        );\n    }\n\n    private _setWidthAndHeight(): void {\n        this.width = this._el.nativeElement.offsetWidth;\n        this.height = this._el.nativeElement.offsetHeight - 45;\n    }\n}\n","<bc-calendar-header\n    [monthInfo]=\"(selectedMonth$ | async)!!\"\n    [weekModeDays]=\"(weekModeDays$ | async)!!\"\n    [rtl]=\"rtl\"\n    [mode]=\"(mode$ | async)!!\"\n    [modeTitle]=\"(modeTitle$ | async)!!\"\n    [title]=\"(title$ | async)!!\"\n    (modeChange)=\"onModeChange($event)\"\n    (prevTap)=\"onPrevTap()\"\n    (nextTap)=\"onNextTap()\"\n    (today)=\"onToday()\"\n    (rangeChange)=\"onRangeChange($event)\"\n>\n</bc-calendar-header>\n\n<ng-container [ngSwitch]=\"mode$ | async\">\n    <ng-container *ngSwitchCase=\"'week'\">\n        <ng-container\n            *ngTemplateOutlet=\"\n                weekCalendar;\n                context: {\n                    $implicit: selectedMonth$ | async,\n                    moDataList: eventMoDataList$ | async,\n                    width: width,\n                    height: height,\n                    rtl: rtl,\n                    showEvents: showEvents,\n                    weekModeDays: weekModeDays$ | async,\n                    today: today,\n                    deviceSize: deviceSize,\n                    calendarFields: calendarFields,\n                    access: access\n                }\n            \"\n        ></ng-container>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'day'\">\n        <ng-container\n            *ngTemplateOutlet=\"\n                weekCalendar;\n                context: {\n                    $implicit: selectedMonth$ | async,\n                    moDataList: eventMoDataList$ | async,\n                    width: width,\n                    height: height,\n                    rtl: rtl,\n                    showEvents: showEvents,\n                    weekModeDays: weekModeDays$ | async,\n                    today: today,\n                    deviceSize: deviceSize,\n                    calendarFields: calendarFields,\n                    access: access\n                }\n            \"\n        ></ng-container>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'list'\"></ng-container>\n    <ng-container *ngSwitchDefault>\n        <ng-container\n            *ngTemplateOutlet=\"\n                monthCalendar;\n                context: {\n                    $implicit: days$ | async,\n                    moDataList: eventMoDataList$ | async,\n                    width: width,\n                    height: height,\n                    rtl: rtl,\n                    showEvents: showEvents,\n                    today: today,\n                    deviceSize: deviceSize,\n                    calendarFields: calendarFields,\n                    monthWeeksCount: monthWeeksCount$ | async,\n                    access: access\n                }\n            \"\n        ></ng-container>\n    </ng-container>\n</ng-container>\n\n<ng-template\n    #monthCalendar\n    let-days\n    let-moDataList=\"moDataList\"\n    let-width=\"width\"\n    let-height=\"height\"\n    let-calendarFields=\"calendarFields\"\n    let-rtl=\"rtl\"\n    let-today=\"today\"\n    let-showEvents=\"showEvents\"\n    let-deviceSize=\"deviceSize\"\n    let-monthWeeksCount=\"monthWeeksCount\"\n    let-access=\"access\"\n>\n    <bc-calendar-month\n        [style.width]=\"width\"\n        [containerHeight]=\"parentHeight !== 0 ? parentHeight : height\"\n        [containerWidth]=\"width\"\n        [calendarFields]=\"calendarFields\"\n        [moDataList]=\"moDataList\"\n        [monthWeeksCount]=\"monthWeeksCount\"\n        [rtl]=\"rtl\"\n        [weekDays]=\"weekDays\"\n        [weekDaysMin]=\"weekDaysMin\"\n        [today]=\"today\"\n        [showEvents]=\"showEvents\"\n        [days]=\"days\"\n        [canAdd]=\"access.Add\"\n        [canEdit]=\"access.Edit\"\n        [canDelete]=\"access.Delete\"\n        [deviceSize]=\"deviceSize\"\n        (dayClick)=\"onDayClick($event)\"\n        (showEvent)=\"onShowTask()\"\n        (deleteEvent)=\"deleteTask.emit($event)\"\n        (editEvent)=\"editTask.emit($event)\"\n        (daySelect)=\"daySelect.emit($event)\"\n    ></bc-calendar-month>\n</ng-template>\n\n<ng-template #listCalendar>\n    <bc-calendar-list-container\n        [showEvents]=\"showEvents\"\n        [selectedDay]=\"selectedDay\"\n        [calendarFields]=\"calendarFields\"\n        (showEventsTap)=\"showEvents = !showEvents\"\n    ></bc-calendar-list-container>\n</ng-template>\n\n<ng-template\n    #weekCalendar\n    let-selectedMonth\n    let-moDataList=\"moDataList\"\n    let-width=\"width\"\n    let-height=\"height\"\n    let-calendarFields=\"calendarFields\"\n    let-rtl=\"rtl\"\n    let-today=\"today\"\n    let-showEvents=\"showEvents\"\n    let-deviceSize=\"deviceSize\"\n    let-weekModeDays=\"weekModeDays\"\n    let-access=\"access\"\n>\n    <bc-calendar-week\n        [style.width]=\"width\"\n        [containerHeight]=\"parentHeight !== 0 ? parentHeight : height\"\n        [containerWidth]=\"width\"\n        [inDialog]=\"inDialog\"\n        [calendarFields]=\"calendarFields\"\n        [moDataList]=\"moDataList\"\n        [rtl]=\"rtl\"\n        [canAdd]=\"access.Add\"\n        [canEdit]=\"access.Edit\"\n        [canDelete]=\"access.Delete\"\n        [weekDays]=\"weekDays\"\n        [weekDaysMin]=\"weekDaysMin\"\n        [today]=\"today\"\n        [showEvents]=\"showEvents\"\n        [days]=\"weekModeDays\"\n        [deviceSize]=\"deviceSize\"\n        (dayClick)=\"onDayClick($event)\"\n        (showEvent)=\"onShowTask()\"\n        (deleteEvent)=\"deleteTask.emit($event)\"\n        (editEvent)=\"editTask.emit($event)\"\n        (daySelect)=\"daySelect.emit($event)\"\n    ></bc-calendar-week>\n</ng-template>\n"]}
@@ -0,0 +1,61 @@
1
+ import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output } from '@angular/core';
2
+ import { BaseComponent } from 'barsa-novin-ray-core';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "@angular/common";
5
+ import * as i2 from "@fundamental-ngx/core/menu";
6
+ import * as i3 from "@fundamental-ngx/core/title";
7
+ import * as i4 from "@fundamental-ngx/core/split-button";
8
+ import * as i5 from "@fundamental-ngx/core/toolbar";
9
+ import * as i6 from "@fundamental-ngx/platform/button";
10
+ import * as i7 from "../calendar-selection-days/calendar-selection-days.component";
11
+ import * as i8 from "barsa-novin-ray-core";
12
+ export class CalendarHeaderComponent extends BaseComponent {
13
+ constructor() {
14
+ super(...arguments);
15
+ this.hideMode = false;
16
+ this.prevTap = new EventEmitter();
17
+ this.nextTap = new EventEmitter();
18
+ this.modeChange = new EventEmitter();
19
+ this.rangeChange = new EventEmitter();
20
+ this.today = new EventEmitter();
21
+ this.monthName = '';
22
+ }
23
+ onModeChange(mode) {
24
+ this.modeChange.emit(mode);
25
+ }
26
+ onRangeChange(range) {
27
+ this.rangeChange.emit(range);
28
+ }
29
+ onPrint() { }
30
+ }
31
+ CalendarHeaderComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: CalendarHeaderComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
32
+ CalendarHeaderComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: CalendarHeaderComponent, selector: "bc-calendar-header", inputs: { monthInfo: "monthInfo", weekModeDays: "weekModeDays", hideMode: "hideMode", modeTitle: "modeTitle", title: "title", rtl: "rtl", mode: "mode" }, outputs: { prevTap: "prevTap", nextTap: "nextTap", modeChange: "modeChange", rangeChange: "rangeChange", today: "today" }, usesInheritance: true, ngImport: i0, template: "<fd-toolbar [shouldOverflow]=\"true\" [fdType]=\"'transparent'\">\r\n <fdp-button fd-toolbar-item [label]=\"'DateR_Today' | bbbTranslate\" (click)=\"today.emit()\"></fdp-button>\r\n <fdp-button\r\n buttonType=\"transparent\"\r\n fd-toolbar-item\r\n [glyph]=\"rtl ? 'navigation-right-arrow' : 'navigation-left-arrow'\"\r\n (click)=\"prevTap.emit()\"\r\n ></fdp-button>\r\n <fdp-button\r\n buttonType=\"transparent\"\r\n fd-toolbar-item\r\n [glyph]=\"rtl ? 'navigation-left-arrow' : 'navigation-right-arrow'\"\r\n (click)=\"nextTap.emit()\"\r\n ></fdp-button>\r\n <h3 fd-title fd-toolbar-item>{{ title }}</h3>\r\n <fd-toolbar-spacer></fd-toolbar-spacer>\r\n <fdp-button fd-toolbar-item glyph=\"print\" (click)=\"onPrint()\" buttonType=\"transparent\"></fdp-button>\r\n <bc-calendar-selection-days\r\n fd-toolbar-item\r\n [monthInfo]=\"monthInfo\"\r\n (rangeChange)=\"onRangeChange($event)\"\r\n ></bc-calendar-selection-days>\r\n\r\n <fd-split-button\r\n *ngIf=\"!hideMode\"\r\n fd-toolbar-item\r\n [fixedWidth]=\"false\"\r\n [mainAction]=\"{\r\n mainActionTitle: modeTitle,\r\n keepMainAction: true\r\n }\"\r\n >\r\n <fd-menu>\r\n <li fd-menu-item (click)=\"onModeChange('day')\">\r\n <div fd-menu-interactive>\r\n <span fd-menu-title>{{ 'Day' | bbbTranslate }}</span>\r\n </div>\r\n </li>\r\n <li fd-menu-item (click)=\"onModeChange('week')\">\r\n <div fd-menu-interactive>\r\n <span fd-menu-title>{{ 'Week' | bbbTranslate }} </span>\r\n </div>\r\n </li>\r\n <li fd-menu-item (click)=\"onModeChange('month')\">\r\n <div fd-menu-interactive>\r\n <span fd-menu-title>{{ 'Month' | bbbTranslate }}</span>\r\n </div>\r\n </li>\r\n <!-- <li fd-menu-item (click)=\"onModeChange('year')\">\r\n <div fd-menu-interactive>\r\n <span fd-menu-title>{{ \"Year\" | bbbTranslate }}</span>\r\n </div>\r\n </li> -->\r\n </fd-menu>\r\n </fd-split-button>\r\n</fd-toolbar>\r\n", styles: [":host{display:block;background-color:var(--sapList_Background, #fff)}::ng-deep span.fd-toolbar__spacer{display:none}::ng-deep .fd-toolbar{border:none}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.MenuComponent, selector: "fd-menu", inputs: ["mobile", "disabled", "focusTrapped", "openOnHoverTime", "mobileConfig", "ariaLabel", "ariaLabelledby", "id"], outputs: ["activePath"] }, { kind: "component", type: i2.MenuItemComponent, selector: "li[fd-menu-item]", inputs: ["disabled", "itemId", "submenu"], outputs: ["onSelect"], exportAs: ["fd-menu-item"] }, { kind: "directive", type: i2.MenuInteractiveDirective, selector: "[fd-menu-interactive]" }, { kind: "directive", type: i2.MenuTitleDirective, selector: "[fd-menu-title]" }, { kind: "component", type: i3.TitleComponent, selector: "h1[fd-title], h2[fd-title], h3[fd-title], h4[fd-title], h5[fd-title], h6[fd-title]", inputs: ["headerSize", "wrap"], exportAs: ["fd-title"] }, { kind: "component", type: i4.SplitButtonComponent, selector: "fd-split-button", inputs: ["glyph", "disabled", "mainActionTitle", "fdType", "expandButtonAriaLabel", "expandButtonTitle", "selected", "fixedWidth", "mainAction", "arialLabel"], outputs: ["primaryButtonClicked"] }, { kind: "component", type: i5.ToolbarComponent, selector: "fd-toolbar", inputs: ["class", "shouldOverflow", "fdType", "hasTitle", "title", "active", "clearBorder", "forceOverflow", "tabindex"] }, { kind: "directive", type: i5.ToolbarItemDirective, selector: "[fd-toolbar-item]" }, { kind: "component", type: i5.ToolbarSpacerComponent, selector: "fd-toolbar-spacer", inputs: ["width", "class", "fixed"] }, { kind: "component", type: i6.ButtonComponent, selector: "fdp-button", inputs: ["glyphPosition", "label", "glyph", "buttonType", "title", "ariaSelected", "ariaDisabled", "ariaExpanded", "ariaControlsId", "ariaPressed", "name", "type", "value"], outputs: ["buttonClicked"] }, { kind: "component", type: i7.CalendarSelectionDaysComponent, selector: "bc-calendar-selection-days", inputs: ["startSelectedDayIndex", "endSelectedDayIndex", "monthInfo"], outputs: ["rangeChange"] }, { kind: "pipe", type: i8.BbbTranslatePipe, name: "bbbTranslate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
33
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: CalendarHeaderComponent, decorators: [{
34
+ type: Component,
35
+ args: [{ selector: 'bc-calendar-header', changeDetection: ChangeDetectionStrategy.OnPush, template: "<fd-toolbar [shouldOverflow]=\"true\" [fdType]=\"'transparent'\">\r\n <fdp-button fd-toolbar-item [label]=\"'DateR_Today' | bbbTranslate\" (click)=\"today.emit()\"></fdp-button>\r\n <fdp-button\r\n buttonType=\"transparent\"\r\n fd-toolbar-item\r\n [glyph]=\"rtl ? 'navigation-right-arrow' : 'navigation-left-arrow'\"\r\n (click)=\"prevTap.emit()\"\r\n ></fdp-button>\r\n <fdp-button\r\n buttonType=\"transparent\"\r\n fd-toolbar-item\r\n [glyph]=\"rtl ? 'navigation-left-arrow' : 'navigation-right-arrow'\"\r\n (click)=\"nextTap.emit()\"\r\n ></fdp-button>\r\n <h3 fd-title fd-toolbar-item>{{ title }}</h3>\r\n <fd-toolbar-spacer></fd-toolbar-spacer>\r\n <fdp-button fd-toolbar-item glyph=\"print\" (click)=\"onPrint()\" buttonType=\"transparent\"></fdp-button>\r\n <bc-calendar-selection-days\r\n fd-toolbar-item\r\n [monthInfo]=\"monthInfo\"\r\n (rangeChange)=\"onRangeChange($event)\"\r\n ></bc-calendar-selection-days>\r\n\r\n <fd-split-button\r\n *ngIf=\"!hideMode\"\r\n fd-toolbar-item\r\n [fixedWidth]=\"false\"\r\n [mainAction]=\"{\r\n mainActionTitle: modeTitle,\r\n keepMainAction: true\r\n }\"\r\n >\r\n <fd-menu>\r\n <li fd-menu-item (click)=\"onModeChange('day')\">\r\n <div fd-menu-interactive>\r\n <span fd-menu-title>{{ 'Day' | bbbTranslate }}</span>\r\n </div>\r\n </li>\r\n <li fd-menu-item (click)=\"onModeChange('week')\">\r\n <div fd-menu-interactive>\r\n <span fd-menu-title>{{ 'Week' | bbbTranslate }} </span>\r\n </div>\r\n </li>\r\n <li fd-menu-item (click)=\"onModeChange('month')\">\r\n <div fd-menu-interactive>\r\n <span fd-menu-title>{{ 'Month' | bbbTranslate }}</span>\r\n </div>\r\n </li>\r\n <!-- <li fd-menu-item (click)=\"onModeChange('year')\">\r\n <div fd-menu-interactive>\r\n <span fd-menu-title>{{ \"Year\" | bbbTranslate }}</span>\r\n </div>\r\n </li> -->\r\n </fd-menu>\r\n </fd-split-button>\r\n</fd-toolbar>\r\n", styles: [":host{display:block;background-color:var(--sapList_Background, #fff)}::ng-deep span.fd-toolbar__spacer{display:none}::ng-deep .fd-toolbar{border:none}\n"] }]
36
+ }], propDecorators: { monthInfo: [{
37
+ type: Input
38
+ }], weekModeDays: [{
39
+ type: Input
40
+ }], hideMode: [{
41
+ type: Input
42
+ }], modeTitle: [{
43
+ type: Input
44
+ }], title: [{
45
+ type: Input
46
+ }], rtl: [{
47
+ type: Input
48
+ }], mode: [{
49
+ type: Input
50
+ }], prevTap: [{
51
+ type: Output
52
+ }], nextTap: [{
53
+ type: Output
54
+ }], modeChange: [{
55
+ type: Output
56
+ }], rangeChange: [{
57
+ type: Output
58
+ }], today: [{
59
+ type: Output
60
+ }] } });
61
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FsZW5kYXItaGVhZGVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2JhcnNhLWNhbGVuZGFyL3NyYy9saWIvY2FsZW5kYXItaGVhZGVyL2NhbGVuZGFyLWhlYWRlci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9iYXJzYS1jYWxlbmRhci9zcmMvbGliL2NhbGVuZGFyLWhlYWRlci9jYWxlbmRhci1oZWFkZXIuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUVoRyxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sc0JBQXNCLENBQUM7Ozs7Ozs7Ozs7QUFRckQsTUFBTSxPQUFPLHVCQUF3QixTQUFRLGFBQWE7SUFOMUQ7O1FBU2EsYUFBUSxHQUFHLEtBQUssQ0FBQztRQUtoQixZQUFPLEdBQUcsSUFBSSxZQUFZLEVBQUUsQ0FBQztRQUM3QixZQUFPLEdBQUcsSUFBSSxZQUFZLEVBQUUsQ0FBQztRQUM3QixlQUFVLEdBQUcsSUFBSSxZQUFZLEVBQWdCLENBQUM7UUFDOUMsZ0JBQVcsR0FBRyxJQUFJLFlBQVksRUFJcEMsQ0FBQztRQUNLLFVBQUssR0FBRyxJQUFJLFlBQVksRUFBRSxDQUFDO1FBRXJDLGNBQVMsR0FBRyxFQUFFLENBQUM7S0FTbEI7SUFQRyxZQUFZLENBQUMsSUFBa0I7UUFDM0IsSUFBSSxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDL0IsQ0FBQztJQUNELGFBQWEsQ0FBQyxLQUFLO1FBQ2YsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDakMsQ0FBQztJQUNELE9BQU8sS0FBVSxDQUFDOztvSEExQlQsdUJBQXVCO3dHQUF2Qix1QkFBdUIsc1dDVnBDLHl2RUF3REE7MkZEOUNhLHVCQUF1QjtrQkFObkMsU0FBUzsrQkFDSSxvQkFBb0IsbUJBR2IsdUJBQXVCLENBQUMsTUFBTTs4QkFHdEMsU0FBUztzQkFBakIsS0FBSztnQkFDRyxZQUFZO3NCQUFwQixLQUFLO2dCQUNHLFFBQVE7c0JBQWhCLEtBQUs7Z0JBQ0csU0FBUztzQkFBakIsS0FBSztnQkFDRyxLQUFLO3NCQUFiLEtBQUs7Z0JBQ0csR0FBRztzQkFBWCxLQUFLO2dCQUNHLElBQUk7c0JBQVosS0FBSztnQkFDSSxPQUFPO3NCQUFoQixNQUFNO2dCQUNHLE9BQU87c0JBQWhCLE1BQU07Z0JBQ0csVUFBVTtzQkFBbkIsTUFBTTtnQkFDRyxXQUFXO3NCQUFwQixNQUFNO2dCQUtHLEtBQUs7c0JBQWQsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5cclxuaW1wb3J0IHsgQmFzZUNvbXBvbmVudCB9IGZyb20gJ2JhcnNhLW5vdmluLXJheS1jb3JlJztcclxuaW1wb3J0IHsgQ2FsZW5kYXJNb2RlLCBDYWxlbmRhck1vbnRoSW5mbywgRGF5IH0gZnJvbSAnLi4vbW9kZWxzJztcclxuQENvbXBvbmVudCh7XHJcbiAgICBzZWxlY3RvcjogJ2JjLWNhbGVuZGFyLWhlYWRlcicsXHJcbiAgICB0ZW1wbGF0ZVVybDogJy4vY2FsZW5kYXItaGVhZGVyLmNvbXBvbmVudC5odG1sJyxcclxuICAgIHN0eWxlVXJsczogWycuL2NhbGVuZGFyLWhlYWRlci5jb21wb25lbnQuc2NzcyddLFxyXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2hcclxufSlcclxuZXhwb3J0IGNsYXNzIENhbGVuZGFySGVhZGVyQ29tcG9uZW50IGV4dGVuZHMgQmFzZUNvbXBvbmVudCB7XHJcbiAgICBASW5wdXQoKSBtb250aEluZm86IENhbGVuZGFyTW9udGhJbmZvO1xyXG4gICAgQElucHV0KCkgd2Vla01vZGVEYXlzOiBEYXlbXTtcclxuICAgIEBJbnB1dCgpIGhpZGVNb2RlID0gZmFsc2U7XHJcbiAgICBASW5wdXQoKSBtb2RlVGl0bGU6IHN0cmluZztcclxuICAgIEBJbnB1dCgpIHRpdGxlOiBzdHJpbmc7XHJcbiAgICBASW5wdXQoKSBydGw6IGJvb2xlYW47XHJcbiAgICBASW5wdXQoKSBtb2RlOiBDYWxlbmRhck1vZGU7XHJcbiAgICBAT3V0cHV0KCkgcHJldlRhcCA9IG5ldyBFdmVudEVtaXR0ZXIoKTtcclxuICAgIEBPdXRwdXQoKSBuZXh0VGFwID0gbmV3IEV2ZW50RW1pdHRlcigpO1xyXG4gICAgQE91dHB1dCgpIG1vZGVDaGFuZ2UgPSBuZXcgRXZlbnRFbWl0dGVyPENhbGVuZGFyTW9kZT4oKTtcclxuICAgIEBPdXRwdXQoKSByYW5nZUNoYW5nZSA9IG5ldyBFdmVudEVtaXR0ZXI8e1xyXG4gICAgICAgIHN0YXJ0RGF5OiBEYXk7XHJcbiAgICAgICAgZW5kRGF5OiBEYXk7XHJcbiAgICAgICAgbW9udGhJbmZvOiBDYWxlbmRhck1vbnRoSW5mbztcclxuICAgIH0+KCk7XHJcbiAgICBAT3V0cHV0KCkgdG9kYXkgPSBuZXcgRXZlbnRFbWl0dGVyKCk7XHJcbiAgICB5ZWFyOiBzdHJpbmc7XHJcbiAgICBtb250aE5hbWUgPSAnJztcclxuXHJcbiAgICBvbk1vZGVDaGFuZ2UobW9kZTogQ2FsZW5kYXJNb2RlKTogdm9pZCB7XHJcbiAgICAgICAgdGhpcy5tb2RlQ2hhbmdlLmVtaXQobW9kZSk7XHJcbiAgICB9XHJcbiAgICBvblJhbmdlQ2hhbmdlKHJhbmdlKTogdm9pZCB7XHJcbiAgICAgICAgdGhpcy5yYW5nZUNoYW5nZS5lbWl0KHJhbmdlKTtcclxuICAgIH1cclxuICAgIG9uUHJpbnQoKTogdm9pZCB7fVxyXG59XHJcbiIsIjxmZC10b29sYmFyIFtzaG91bGRPdmVyZmxvd109XCJ0cnVlXCIgW2ZkVHlwZV09XCIndHJhbnNwYXJlbnQnXCI+XHJcbiAgICA8ZmRwLWJ1dHRvbiBmZC10b29sYmFyLWl0ZW0gW2xhYmVsXT1cIidEYXRlUl9Ub2RheScgfCBiYmJUcmFuc2xhdGVcIiAoY2xpY2spPVwidG9kYXkuZW1pdCgpXCI+PC9mZHAtYnV0dG9uPlxyXG4gICAgPGZkcC1idXR0b25cclxuICAgICAgICBidXR0b25UeXBlPVwidHJhbnNwYXJlbnRcIlxyXG4gICAgICAgIGZkLXRvb2xiYXItaXRlbVxyXG4gICAgICAgIFtnbHlwaF09XCJydGwgPyAnbmF2aWdhdGlvbi1yaWdodC1hcnJvdycgOiAnbmF2aWdhdGlvbi1sZWZ0LWFycm93J1wiXHJcbiAgICAgICAgKGNsaWNrKT1cInByZXZUYXAuZW1pdCgpXCJcclxuICAgID48L2ZkcC1idXR0b24+XHJcbiAgICA8ZmRwLWJ1dHRvblxyXG4gICAgICAgIGJ1dHRvblR5cGU9XCJ0cmFuc3BhcmVudFwiXHJcbiAgICAgICAgZmQtdG9vbGJhci1pdGVtXHJcbiAgICAgICAgW2dseXBoXT1cInJ0bCA/ICduYXZpZ2F0aW9uLWxlZnQtYXJyb3cnIDogJ25hdmlnYXRpb24tcmlnaHQtYXJyb3cnXCJcclxuICAgICAgICAoY2xpY2spPVwibmV4dFRhcC5lbWl0KClcIlxyXG4gICAgPjwvZmRwLWJ1dHRvbj5cclxuICAgIDxoMyBmZC10aXRsZSBmZC10b29sYmFyLWl0ZW0+e3sgdGl0bGUgfX08L2gzPlxyXG4gICAgPGZkLXRvb2xiYXItc3BhY2VyPjwvZmQtdG9vbGJhci1zcGFjZXI+XHJcbiAgICA8ZmRwLWJ1dHRvbiBmZC10b29sYmFyLWl0ZW0gZ2x5cGg9XCJwcmludFwiIChjbGljayk9XCJvblByaW50KClcIiBidXR0b25UeXBlPVwidHJhbnNwYXJlbnRcIj48L2ZkcC1idXR0b24+XHJcbiAgICA8YmMtY2FsZW5kYXItc2VsZWN0aW9uLWRheXNcclxuICAgICAgICBmZC10b29sYmFyLWl0ZW1cclxuICAgICAgICBbbW9udGhJbmZvXT1cIm1vbnRoSW5mb1wiXHJcbiAgICAgICAgKHJhbmdlQ2hhbmdlKT1cIm9uUmFuZ2VDaGFuZ2UoJGV2ZW50KVwiXHJcbiAgICA+PC9iYy1jYWxlbmRhci1zZWxlY3Rpb24tZGF5cz5cclxuXHJcbiAgICA8ZmQtc3BsaXQtYnV0dG9uXHJcbiAgICAgICAgKm5nSWY9XCIhaGlkZU1vZGVcIlxyXG4gICAgICAgIGZkLXRvb2xiYXItaXRlbVxyXG4gICAgICAgIFtmaXhlZFdpZHRoXT1cImZhbHNlXCJcclxuICAgICAgICBbbWFpbkFjdGlvbl09XCJ7XHJcbiAgICAgICAgICAgIG1haW5BY3Rpb25UaXRsZTogbW9kZVRpdGxlLFxyXG4gICAgICAgICAgICBrZWVwTWFpbkFjdGlvbjogdHJ1ZVxyXG4gICAgICAgIH1cIlxyXG4gICAgPlxyXG4gICAgICAgIDxmZC1tZW51PlxyXG4gICAgICAgICAgICA8bGkgZmQtbWVudS1pdGVtIChjbGljayk9XCJvbk1vZGVDaGFuZ2UoJ2RheScpXCI+XHJcbiAgICAgICAgICAgICAgICA8ZGl2IGZkLW1lbnUtaW50ZXJhY3RpdmU+XHJcbiAgICAgICAgICAgICAgICAgICAgPHNwYW4gZmQtbWVudS10aXRsZT57eyAnRGF5JyB8IGJiYlRyYW5zbGF0ZSB9fTwvc3Bhbj5cclxuICAgICAgICAgICAgICAgIDwvZGl2PlxyXG4gICAgICAgICAgICA8L2xpPlxyXG4gICAgICAgICAgICA8bGkgZmQtbWVudS1pdGVtIChjbGljayk9XCJvbk1vZGVDaGFuZ2UoJ3dlZWsnKVwiPlxyXG4gICAgICAgICAgICAgICAgPGRpdiBmZC1tZW51LWludGVyYWN0aXZlPlxyXG4gICAgICAgICAgICAgICAgICAgIDxzcGFuIGZkLW1lbnUtdGl0bGU+e3sgJ1dlZWsnIHwgYmJiVHJhbnNsYXRlIH19IDwvc3Bhbj5cclxuICAgICAgICAgICAgICAgIDwvZGl2PlxyXG4gICAgICAgICAgICA8L2xpPlxyXG4gICAgICAgICAgICA8bGkgZmQtbWVudS1pdGVtIChjbGljayk9XCJvbk1vZGVDaGFuZ2UoJ21vbnRoJylcIj5cclxuICAgICAgICAgICAgICAgIDxkaXYgZmQtbWVudS1pbnRlcmFjdGl2ZT5cclxuICAgICAgICAgICAgICAgICAgICA8c3BhbiBmZC1tZW51LXRpdGxlPnt7ICdNb250aCcgfCBiYmJUcmFuc2xhdGUgfX08L3NwYW4+XHJcbiAgICAgICAgICAgICAgICA8L2Rpdj5cclxuICAgICAgICAgICAgPC9saT5cclxuICAgICAgICAgICAgPCEtLSA8bGkgZmQtbWVudS1pdGVtIChjbGljayk9XCJvbk1vZGVDaGFuZ2UoJ3llYXInKVwiPlxyXG4gICAgICAgIDxkaXYgZmQtbWVudS1pbnRlcmFjdGl2ZT5cclxuICAgICAgICAgIDxzcGFuIGZkLW1lbnUtdGl0bGU+e3sgXCJZZWFyXCIgfCBiYmJUcmFuc2xhdGUgfX08L3NwYW4+XHJcbiAgICAgICAgPC9kaXY+XHJcbiAgICAgIDwvbGk+IC0tPlxyXG4gICAgICAgIDwvZmQtbWVudT5cclxuICAgIDwvZmQtc3BsaXQtYnV0dG9uPlxyXG48L2ZkLXRvb2xiYXI+XHJcbiJdfQ==
@@ -0,0 +1,19 @@
1
+ import { ChangeDetectionStrategy, Component, Input } from '@angular/core';
2
+ import { BaseComponent } from 'barsa-novin-ray-core';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "@angular/common";
5
+ import * as i2 from "../calendar-list-item/calendar-list-item.component";
6
+ export class CalendarListComponent extends BaseComponent {
7
+ trackById(index, item) {
8
+ return item.Id;
9
+ }
10
+ }
11
+ CalendarListComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: CalendarListComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
12
+ CalendarListComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: CalendarListComponent, selector: "bc-calendar-list", inputs: { moDataList: "moDataList" }, usesInheritance: true, ngImport: i0, template: "<bc-calendar-list-item *ngFor=\"let item of moDataList; trackBy: trackById\" [mo]=\"item\"> </bc-calendar-list-item>\r\n", styles: [""], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: i2.CalendarListItemComponent, selector: "bc-calendar-list-item", inputs: ["mo"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
13
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: CalendarListComponent, decorators: [{
14
+ type: Component,
15
+ args: [{ selector: 'bc-calendar-list', changeDetection: ChangeDetectionStrategy.OnPush, template: "<bc-calendar-list-item *ngFor=\"let item of moDataList; trackBy: trackById\" [mo]=\"item\"> </bc-calendar-list-item>\r\n" }]
16
+ }], propDecorators: { moDataList: [{
17
+ type: Input
18
+ }] } });
19
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FsZW5kYXItbGlzdC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9iYXJzYS1jYWxlbmRhci9zcmMvbGliL2NhbGVuZGFyLWxpc3QvY2FsZW5kYXItbGlzdC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9iYXJzYS1jYWxlbmRhci9zcmMvbGliL2NhbGVuZGFyLWxpc3QvY2FsZW5kYXItbGlzdC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUUxRSxPQUFPLEVBQUUsYUFBYSxFQUFvRCxNQUFNLHNCQUFzQixDQUFDOzs7O0FBT3ZHLE1BQU0sT0FBTyxxQkFBc0IsU0FBUSxhQUFhO0lBRTdDLFNBQVMsQ0FBQyxLQUFhLEVBQUUsSUFBeUI7UUFDckQsT0FBTyxJQUFJLENBQUMsRUFBRSxDQUFDO0lBQ25CLENBQUM7O2tIQUpRLHFCQUFxQjtzR0FBckIscUJBQXFCLHFIQ1RsQywwSEFDQTsyRkRRYSxxQkFBcUI7a0JBTmpDLFNBQVM7K0JBQ0ksa0JBQWtCLG1CQUdYLHVCQUF1QixDQUFDLE1BQU07OEJBR3RDLFVBQVU7c0JBQWxCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBCYXNlQ29tcG9uZW50LCBNZXRhb2JqZWN0RGF0YU1vZGVsLCBDYWxlbmRhck1ldGFvYmplY3REYXRhTW9kZWwgfSBmcm9tICdiYXJzYS1ub3Zpbi1yYXktY29yZSc7XG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ2JjLWNhbGVuZGFyLWxpc3QnLFxuICAgIHRlbXBsYXRlVXJsOiAnLi9jYWxlbmRhci1saXN0LmNvbXBvbmVudC5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnLi9jYWxlbmRhci1saXN0LmNvbXBvbmVudC5zY3NzJ10sXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2hcbn0pXG5leHBvcnQgY2xhc3MgQ2FsZW5kYXJMaXN0Q29tcG9uZW50IGV4dGVuZHMgQmFzZUNvbXBvbmVudCB7XG4gICAgQElucHV0KCkgbW9EYXRhTGlzdDogQ2FsZW5kYXJNZXRhb2JqZWN0RGF0YU1vZGVsW107XG4gICAgcHVibGljIHRyYWNrQnlJZChpbmRleDogbnVtYmVyLCBpdGVtOiBNZXRhb2JqZWN0RGF0YU1vZGVsKTogc3RyaW5nIHtcbiAgICAgICAgcmV0dXJuIGl0ZW0uSWQ7XG4gICAgfVxufVxuIiwiPGJjLWNhbGVuZGFyLWxpc3QtaXRlbSAqbmdGb3I9XCJsZXQgaXRlbSBvZiBtb0RhdGFMaXN0OyB0cmFja0J5OiB0cmFja0J5SWRcIiBbbW9dPVwiaXRlbVwiPiA8L2JjLWNhbGVuZGFyLWxpc3QtaXRlbT5cclxuIl19
@@ -0,0 +1,30 @@
1
+ import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output } from '@angular/core';
2
+ import { BaseComponent } from 'barsa-novin-ray-core';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "@angular/common";
5
+ import * as i2 from "../calendar-list/calendar-list.component";
6
+ export class CalendarListContainerComponent extends BaseComponent {
7
+ constructor() {
8
+ super(...arguments);
9
+ this.showEventsTap = new EventEmitter();
10
+ }
11
+ }
12
+ CalendarListContainerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: CalendarListContainerComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
13
+ CalendarListContainerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: CalendarListContainerComponent, selector: "bc-calendar-list-container", inputs: { view: "view", reportItemComponentName: "reportItemComponentName", showEvents: "showEvents", selectedDay: "selectedDay", calendarFields: "calendarFields" }, outputs: { showEventsTap: "showEventsTap" }, usesInheritance: true, ngImport: i0, template: "<bc-calendar-list *ngIf=\"selectedDay\" [moDataList]=\"selectedDay.tasks\"></bc-calendar-list>\r\n", styles: [""], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.CalendarListComponent, selector: "bc-calendar-list", inputs: ["moDataList"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
14
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: CalendarListContainerComponent, decorators: [{
15
+ type: Component,
16
+ args: [{ selector: 'bc-calendar-list-container', changeDetection: ChangeDetectionStrategy.OnPush, template: "<bc-calendar-list *ngIf=\"selectedDay\" [moDataList]=\"selectedDay.tasks\"></bc-calendar-list>\r\n" }]
17
+ }], propDecorators: { view: [{
18
+ type: Input
19
+ }], reportItemComponentName: [{
20
+ type: Input
21
+ }], showEvents: [{
22
+ type: Input
23
+ }], selectedDay: [{
24
+ type: Input
25
+ }], calendarFields: [{
26
+ type: Input
27
+ }], showEventsTap: [{
28
+ type: Output
29
+ }] } });
30
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FsZW5kYXItbGlzdC1jb250YWluZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFyc2EtY2FsZW5kYXIvc3JjL2xpYi9jYWxlbmRhci1saXN0LWNvbnRhaW5lci9jYWxlbmRhci1saXN0LWNvbnRhaW5lci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9iYXJzYS1jYWxlbmRhci9zcmMvbGliL2NhbGVuZGFyLWxpc3QtY29udGFpbmVyL2NhbGVuZGFyLWxpc3QtY29udGFpbmVyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFaEcsT0FBTyxFQUFFLGFBQWEsRUFBa0IsTUFBTSxzQkFBc0IsQ0FBQzs7OztBQVFyRSxNQUFNLE9BQU8sOEJBQStCLFNBQVEsYUFBYTtJQU5qRTs7UUFZYyxrQkFBYSxHQUFHLElBQUksWUFBWSxFQUFFLENBQUM7S0FDaEQ7OzJIQVBZLDhCQUE4QjsrR0FBOUIsOEJBQThCLDRTQ1YzQyxvR0FDQTsyRkRTYSw4QkFBOEI7a0JBTjFDLFNBQVM7K0JBQ0ksNEJBQTRCLG1CQUdyQix1QkFBdUIsQ0FBQyxNQUFNOzhCQUd0QyxJQUFJO3NCQUFaLEtBQUs7Z0JBQ0csdUJBQXVCO3NCQUEvQixLQUFLO2dCQUNHLFVBQVU7c0JBQWxCLEtBQUs7Z0JBQ0csV0FBVztzQkFBbkIsS0FBSztnQkFDRyxjQUFjO3NCQUF0QixLQUFLO2dCQUNJLGFBQWE7c0JBQXRCLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIElucHV0LCBPdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgQmFzZUNvbXBvbmVudCwgQ2FsZW5kYXJGaWVsZHMgfSBmcm9tICdiYXJzYS1ub3Zpbi1yYXktY29yZSc7XG5pbXBvcnQgeyBEYXkgfSBmcm9tICcuLi9tb2RlbHMnO1xuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICdiYy1jYWxlbmRhci1saXN0LWNvbnRhaW5lcicsXG4gICAgdGVtcGxhdGVVcmw6ICcuL2NhbGVuZGFyLWxpc3QtY29udGFpbmVyLmNvbXBvbmVudC5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnLi9jYWxlbmRhci1saXN0LWNvbnRhaW5lci5jb21wb25lbnQuc2NzcyddLFxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoXG59KVxuZXhwb3J0IGNsYXNzIENhbGVuZGFyTGlzdENvbnRhaW5lckNvbXBvbmVudCBleHRlbmRzIEJhc2VDb21wb25lbnQge1xuICAgIEBJbnB1dCgpIHZpZXc6IGFueTtcbiAgICBASW5wdXQoKSByZXBvcnRJdGVtQ29tcG9uZW50TmFtZTogc3RyaW5nO1xuICAgIEBJbnB1dCgpIHNob3dFdmVudHM6IGJvb2xlYW47XG4gICAgQElucHV0KCkgc2VsZWN0ZWREYXk6IERheTtcbiAgICBASW5wdXQoKSBjYWxlbmRhckZpZWxkczogQ2FsZW5kYXJGaWVsZHM7XG4gICAgQE91dHB1dCgpIHNob3dFdmVudHNUYXAgPSBuZXcgRXZlbnRFbWl0dGVyKCk7XG59XG4iLCI8YmMtY2FsZW5kYXItbGlzdCAqbmdJZj1cInNlbGVjdGVkRGF5XCIgW21vRGF0YUxpc3RdPVwic2VsZWN0ZWREYXkudGFza3NcIj48L2JjLWNhbGVuZGFyLWxpc3Q+XHJcbiJdfQ==
@@ -0,0 +1,14 @@
1
+ import { ChangeDetectionStrategy, Component, Input } from '@angular/core';
2
+ import { BaseComponent } from 'barsa-novin-ray-core';
3
+ import * as i0 from "@angular/core";
4
+ export class CalendarListItemComponent extends BaseComponent {
5
+ }
6
+ CalendarListItemComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: CalendarListItemComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
7
+ CalendarListItemComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: CalendarListItemComponent, selector: "bc-calendar-list-item", inputs: { mo: "mo" }, usesInheritance: true, ngImport: i0, template: "<div class=\"wrapper\">\r\n <div flexShrink=\"1\" class=\"day-wrapper\">\r\n <Label [text]=\"mo.$StartTimes\"></Label>\r\n <Label class=\"ela\" [text]=\"'\u0627\u0644\u06CC'\"></Label>\r\n <Label [text]=\"mo.$EndTimes\"></Label>\r\n </div>\r\n <div class=\"color\" [style.background-color]=\"mo.$Color\"></div>\r\n <div class=\"event-wrapper\">\r\n <Label class=\"title\" [text]=\"mo.$Title\"></Label>\r\n <Label class=\"desc\" [text]=\"mo.$Notes\"></Label>\r\n </div>\r\n</div>\r\n", styles: [".wrapper{display:flex;flex-direction:row}.day-wrapper{display:flex;flex-shrink:1}.color{width:1}.event-wrapper{display:flex;flex-grow:1}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush });
8
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: CalendarListItemComponent, decorators: [{
9
+ type: Component,
10
+ args: [{ selector: 'bc-calendar-list-item', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"wrapper\">\r\n <div flexShrink=\"1\" class=\"day-wrapper\">\r\n <Label [text]=\"mo.$StartTimes\"></Label>\r\n <Label class=\"ela\" [text]=\"'\u0627\u0644\u06CC'\"></Label>\r\n <Label [text]=\"mo.$EndTimes\"></Label>\r\n </div>\r\n <div class=\"color\" [style.background-color]=\"mo.$Color\"></div>\r\n <div class=\"event-wrapper\">\r\n <Label class=\"title\" [text]=\"mo.$Title\"></Label>\r\n <Label class=\"desc\" [text]=\"mo.$Notes\"></Label>\r\n </div>\r\n</div>\r\n", styles: [".wrapper{display:flex;flex-direction:row}.day-wrapper{display:flex;flex-shrink:1}.color{width:1}.event-wrapper{display:flex;flex-grow:1}\n"] }]
11
+ }], propDecorators: { mo: [{
12
+ type: Input
13
+ }] } });
14
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FsZW5kYXItbGlzdC1pdGVtLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2JhcnNhLWNhbGVuZGFyL3NyYy9saWIvY2FsZW5kYXItbGlzdC1pdGVtL2NhbGVuZGFyLWxpc3QtaXRlbS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9iYXJzYS1jYWxlbmRhci9zcmMvbGliL2NhbGVuZGFyLWxpc3QtaXRlbS9jYWxlbmRhci1saXN0LWl0ZW0uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFMUUsT0FBTyxFQUFFLGFBQWEsRUFBK0IsTUFBTSxzQkFBc0IsQ0FBQzs7QUFPbEYsTUFBTSxPQUFPLHlCQUEwQixTQUFRLGFBQWE7O3NIQUEvQyx5QkFBeUI7MEdBQXpCLHlCQUF5QiwwR0NUdEMsc2hCQVlBOzJGREhhLHlCQUF5QjtrQkFOckMsU0FBUzsrQkFDSSx1QkFBdUIsbUJBR2hCLHVCQUF1QixDQUFDLE1BQU07OEJBR3RDLEVBQUU7c0JBQVYsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IEJhc2VDb21wb25lbnQsIENhbGVuZGFyTWV0YW9iamVjdERhdGFNb2RlbCB9IGZyb20gJ2JhcnNhLW5vdmluLXJheS1jb3JlJztcbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAnYmMtY2FsZW5kYXItbGlzdC1pdGVtJyxcbiAgICB0ZW1wbGF0ZVVybDogJy4vY2FsZW5kYXItbGlzdC1pdGVtLmNvbXBvbmVudC5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnLi9jYWxlbmRhci1saXN0LWl0ZW0uY29tcG9uZW50LnNjc3MnXSxcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxufSlcbmV4cG9ydCBjbGFzcyBDYWxlbmRhckxpc3RJdGVtQ29tcG9uZW50IGV4dGVuZHMgQmFzZUNvbXBvbmVudCB7XG4gICAgQElucHV0KCkgbW86IENhbGVuZGFyTWV0YW9iamVjdERhdGFNb2RlbDtcbn1cbiIsIjxkaXYgY2xhc3M9XCJ3cmFwcGVyXCI+XHJcbiAgICA8ZGl2IGZsZXhTaHJpbms9XCIxXCIgY2xhc3M9XCJkYXktd3JhcHBlclwiPlxyXG4gICAgICAgIDxMYWJlbCBbdGV4dF09XCJtby4kU3RhcnRUaW1lc1wiPjwvTGFiZWw+XHJcbiAgICAgICAgPExhYmVsIGNsYXNzPVwiZWxhXCIgW3RleHRdPVwiJ9in2YTbjCdcIj48L0xhYmVsPlxyXG4gICAgICAgIDxMYWJlbCBbdGV4dF09XCJtby4kRW5kVGltZXNcIj48L0xhYmVsPlxyXG4gICAgPC9kaXY+XHJcbiAgICA8ZGl2IGNsYXNzPVwiY29sb3JcIiBbc3R5bGUuYmFja2dyb3VuZC1jb2xvcl09XCJtby4kQ29sb3JcIj48L2Rpdj5cclxuICAgIDxkaXYgY2xhc3M9XCJldmVudC13cmFwcGVyXCI+XHJcbiAgICAgICAgPExhYmVsIGNsYXNzPVwidGl0bGVcIiBbdGV4dF09XCJtby4kVGl0bGVcIj48L0xhYmVsPlxyXG4gICAgICAgIDxMYWJlbCBjbGFzcz1cImRlc2NcIiBbdGV4dF09XCJtby4kTm90ZXNcIj48L0xhYmVsPlxyXG4gICAgPC9kaXY+XHJcbjwvZGl2PlxyXG4iXX0=