@colijnit/sharedcomponents 260.1.11 → 260.1.13

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 (31) hide show
  1. package/bundles/colijnit-sharedcomponents.umd.js +116 -12
  2. package/bundles/colijnit-sharedcomponents.umd.js.map +1 -1
  3. package/colijnit-sharedcomponents.metadata.json +1 -1
  4. package/esm2015/lib/components/date-planning/component/agenda/agenda-header.component.js +83 -18
  5. package/esm2015/lib/components/date-planning/component/agenda/view-select.component.js +37 -4
  6. package/esm2015/lib/components/date-planning/component/calendar/calendar-view.component.js +2 -2
  7. package/esm2015/lib/components/date-planning/component/calendar/calendar.component.js +2 -2
  8. package/esm2015/lib/components/date-planning/date-planning.component.js +3 -3
  9. package/esm2015/lib/components/send-method-dialog/send-method-dialog.component.js +4 -1
  10. package/esm2015/lib/enum/calendar-view.enum.js +3 -1
  11. package/esm2015/lib/enum/icon.enum.js +1 -1
  12. package/esm2015/lib/model/icon-svg.js +1 -1
  13. package/esm2015/lib/res/dictionary/dictionaries.js +1 -7
  14. package/esm2015/lib/utils/calendar.utils.js +73 -1
  15. package/fesm2015/colijnit-sharedcomponents.js +199 -30
  16. package/fesm2015/colijnit-sharedcomponents.js.map +1 -1
  17. package/lib/components/date-planning/component/agenda/view-select.component.d.ts +2 -0
  18. package/lib/enum/calendar-view.enum.d.ts +2 -0
  19. package/lib/res/dictionary/dictionaries.d.ts +0 -31885
  20. package/lib/utils/calendar.utils.d.ts +3 -0
  21. package/package.json +1 -1
  22. package/358.645812766f7a400d0d38.js +0 -1
  23. package/3rdpartylicenses.txt +0 -2017
  24. package/7.3142e473803d1a7f9729.js +0 -1
  25. package/977.bd6291f9ee6f6ddf91f1.js +0 -1
  26. package/favicon.ico +0 -0
  27. package/index.html +0 -12
  28. package/main.0245847a0061efd03ea1.js +0 -1
  29. package/polyfills.907fe9d1887c5de17993.js +0 -1
  30. package/runtime.023dce2502cba6970a33.js +0 -1
  31. package/styles.1eab293def3e726bfaa4.css +0 -1
@@ -72,9 +72,15 @@ export class AgendaHeaderComponent {
72
72
  case CalendarView.DaysAround:
73
73
  newDate.setDate(this.selectedDate.getDate() - 1);
74
74
  break;
75
- case CalendarView.WeekView:
75
+ case CalendarView.ThreeDaysView:
76
76
  newDate.setDate(this.selectedDate.getDate() - 3);
77
77
  break;
78
+ case CalendarView.WeekView:
79
+ newDate.setDate(this.selectedDate.getDate() - 7);
80
+ break;
81
+ case CalendarView.WeekWorkView:
82
+ newDate.setDate(this.selectedDate.getDate() - 5);
83
+ break;
78
84
  case CalendarView.WeekSelectView:
79
85
  newDate.setDate(this.selectedDate.getDate() - 7);
80
86
  break;
@@ -96,9 +102,15 @@ export class AgendaHeaderComponent {
96
102
  case CalendarView.DaysAround:
97
103
  newDate.setDate(this.selectedDate.getDate() + 1);
98
104
  break;
99
- case CalendarView.WeekView:
105
+ case CalendarView.ThreeDaysView:
100
106
  newDate.setDate(this.selectedDate.getDate() + 3);
101
107
  break;
108
+ case CalendarView.WeekView:
109
+ newDate.setDate(this.selectedDate.getDate() + 7);
110
+ break;
111
+ case CalendarView.WeekWorkView:
112
+ newDate.setDate(this.selectedDate.getDate() + 5);
113
+ break;
102
114
  case CalendarView.WeekSelectView:
103
115
  newDate.setDate(this.selectedDate.getDate() + 7);
104
116
  break;
@@ -144,6 +156,13 @@ export class AgendaHeaderComponent {
144
156
  this.showBackButton = this.weekDays.find(wd => DateUtils.DatesEqual(this.firstAvailableDate, wd.date)) === undefined;
145
157
  }
146
158
  break;
159
+ case CalendarView.ThreeDaysView:
160
+ const threeDaysView = CalendarUtils.GetThreeDays(this.selectedDate);
161
+ this.weekDays = threeDaysView.weekDays;
162
+ if (this.firstAvailableDate) {
163
+ this.showBackButton = this.weekDays.find(wd => DateUtils.DatesEqual(this.firstAvailableDate, wd.date)) === undefined;
164
+ }
165
+ break;
147
166
  case CalendarView.WeekView:
148
167
  const weekView = CalendarUtils.GetDaysOfWeek(this.selectedDate);
149
168
  this.weekDays = weekView.weekDays;
@@ -151,6 +170,13 @@ export class AgendaHeaderComponent {
151
170
  this.showBackButton = this.weekDays.find(wd => DateUtils.DatesEqual(this.firstAvailableDate, wd.date)) === undefined;
152
171
  }
153
172
  break;
173
+ case CalendarView.WeekWorkView:
174
+ const weekWorkView = CalendarUtils.GetWorkDaysOfWeek(this.selectedDate);
175
+ this.weekDays = weekWorkView.weekDays;
176
+ if (this.firstAvailableDate) {
177
+ this.showBackButton = this.weekDays.find(wd => DateUtils.DatesEqual(this.firstAvailableDate, wd.date)) === undefined;
178
+ }
179
+ break;
154
180
  case CalendarView.WeekSelectView:
155
181
  const weekSelectView = CalendarUtils.GetDaysOfWeek(this.selectedDate);
156
182
  this.weekDays = weekSelectView.weekDays;
@@ -197,10 +223,7 @@ AgendaHeaderComponent.decorators = [
197
223
  { type: Component, args: [{
198
224
  selector: "agenda-header",
199
225
  template: `
200
- <div class="agenda-header-wrapper" *ngIf="view === viewTypes.DayView">
201
- <div class="hour-label-placeholder" *ngIf="viewSelection">
202
- <view-select [selectedView]="view" (selectedViewChange)="changeTheView($event)"></view-select>
203
- </div>
226
+ <div class="agenda-header-wrapper day-view" *ngIf="view === viewTypes.DayView">
204
227
  <div class="week-day-label">
205
228
  <co-icon class="pointer-hover no-user-select sub-unit-icon dark"
206
229
  [iconData]="iconCacheService.getIcon(icons.ArrowPointLeft)" (click)="subUnit()"></co-icon>
@@ -210,9 +233,6 @@ AgendaHeaderComponent.decorators = [
210
233
  </div>
211
234
  </div>
212
235
  <div class="agenda-header-wrapper days-around" *ngIf="view === viewTypes.DaysAround">
213
- <div class="hour-label-placeholder" *ngIf="viewSelection">
214
- <view-select [selectedView]="view" (selectedViewChange)="changeTheView($event)"></view-select>
215
- </div>
216
236
  <div class="month-description" *ngIf="weekDays?.length > 0">
217
237
  {{ (selectedDate | date: 'MMMM') + ' ' + selectedDate.getFullYear() + ' ' + ('WEEK' | sharedLocalize)+ ': ' + getWeekNumber(selectedDate) }}
218
238
  </div>
@@ -228,25 +248,46 @@ AgendaHeaderComponent.decorators = [
228
248
  [iconData]="iconCacheService.getIcon(icons.ArrowPointRight)" (click)="addUnit()"></co-icon>
229
249
  </div>
230
250
  </div>
231
- <div class="agenda-header-wrapper" *ngIf="view === viewTypes.WeekView">
251
+ <div class="agenda-header-wrapper three-days-view" *ngIf="view === viewTypes.ThreeDaysView">
232
252
  <div class="hour-label-placeholder" *ngIf="viewSelection">
233
253
  <view-select [selectedView]="view" (selectedViewChange)="changeTheView($event)"></view-select>
234
254
  </div>
235
- <div class="week-number-header-wrapper">
236
- <span [textContent]="(selectedDate | date: 'MMMM') + ' ' + selectedDate.getFullYear() + ' ' + ('WEEK' | sharedLocalize)+ ': ' + getWeekNumber(selectedDate) "> </span>
255
+ <div class="week-view-header-wrapper">
256
+ <div class="week-day-label" *ngFor="let weekDay of weekDays; let index = index"
257
+ [class.selected]="weekDay.weekdaySelected">
258
+ <co-icon *ngIf="showBackButton && index === 0" class="pointer-hover no-user-select sub-unit-icon dark"
259
+ [iconData]="iconCacheService.getIcon(icons.ArrowPointLeft)" (click)="subUnit()"></co-icon>
260
+ <div *ngIf="weekDay.newMonth"
261
+ class="month-description">
262
+ <span [textContent]="(selectedDate | date: 'MMMM') + ' ' + selectedDate.getFullYear() + ' ' + ('WEEK' | sharedLocalize)+ ': ' + getWeekNumber(selectedDate) "> </span>
263
+ </div>
264
+ <div class="weekday-value"
265
+ [textContent]="capitalizeString(weekDay.weekdayLong) + ' ' + weekDay.weekdayDay + ' ' + capitalizeString(weekDay.weekdayMonthLong) + ' ' + weekDay.weekdayYear "></div>
266
+ <co-icon *ngIf="index === 2" class="pointer-hover no-user-select add-unit-icon dark"
267
+ [iconData]="iconCacheService.getIcon(icons.ArrowPointRight)" (click)="addUnit()"></co-icon>
268
+
237
269
  </div>
238
-
270
+ </div>
271
+
272
+ </div>
273
+ <div class="agenda-header-wrapper week-view" *ngIf="view === viewTypes.WeekView">
274
+ <div class="hour-label-placeholder" *ngIf="viewSelection">
275
+ <view-select [selectedView]="view" (selectedViewChange)="changeTheView($event)"></view-select>
276
+ </div>
239
277
  <div class="week-view-header-wrapper">
240
278
  <div class="week-day-label" *ngFor="let weekDay of weekDays; let index = index"
241
279
  [class.selected]="weekDay.weekdaySelected" (click)="setUnit(weekDay)">
242
280
  <co-icon *ngIf="showBackButton && index === 0" class="pointer-hover no-user-select sub-unit-icon dark"
243
281
  [iconData]="iconCacheService.getIcon(icons.ArrowPointLeft)" (click)="subUnit()"></co-icon>
244
- <div *ngIf="weekDay.newMonth" [textContent]="weekDay.weekdayMonthLong + ' ' + weekDay.weekdayYear"
282
+ <div *ngIf="weekDay.newMonth"
245
283
  class="month-description">
284
+ <span [textContent]="(selectedDate | date: 'MMMM') + ' ' + selectedDate.getFullYear() + ' ' + ('WEEK' | sharedLocalize)+ ': ' + getWeekNumber(selectedDate) "> </span>
246
285
  </div>
247
- <div class="weekday-value"
248
- [textContent]="capitalizeString(weekDay.weekdayLong) + ' ' + weekDay.weekdayDay + ' ' + capitalizeString(weekDay.weekdayMonthLong) + ' ' + weekDay.weekdayYear "></div>
249
- <co-icon *ngIf="index === 2" class="pointer-hover no-user-select add-unit-icon dark"
286
+ <div class="weekday-value">
287
+ <span [textContent]="capitalizeString(weekDay.weekdayLong)"></span>
288
+ <span [textContent]="weekDay.weekdayDay + ' ' + capitalizeString(weekDay.weekdayMonthLong) + ' ' + weekDay.weekdayYear"></span>
289
+ </div>
290
+ <co-icon *ngIf="index === 6" class="pointer-hover no-user-select add-unit-icon dark"
250
291
  [iconData]="iconCacheService.getIcon(icons.ArrowPointRight)" (click)="addUnit()"></co-icon>
251
292
 
252
293
  </div>
@@ -254,6 +295,30 @@ AgendaHeaderComponent.decorators = [
254
295
 
255
296
  </div>
256
297
 
298
+ <div class="agenda-header-wrapper work-week-view" *ngIf="view === viewTypes.WeekWorkView">
299
+ <div class="hour-label-placeholder" *ngIf="viewSelection">
300
+ <view-select [selectedView]="view" (selectedViewChange)="changeTheView($event)"></view-select>
301
+ </div>
302
+ <div class="week-view-header-wrapper">
303
+ <div class="week-day-label" *ngFor="let weekDay of weekDays; let index = index"
304
+ [class.selected]="weekDay.weekdaySelected">
305
+ <co-icon *ngIf="showBackButton && index === 0" class="pointer-hover no-user-select sub-unit-icon dark"
306
+ [iconData]="iconCacheService.getIcon(icons.ArrowPointLeft)" (click)="subUnit()"></co-icon>
307
+ <div *ngIf="weekDay.newMonth"
308
+ class="month-description">
309
+ <span [textContent]="(selectedDate | date: 'MMMM') + ' ' + selectedDate.getFullYear() + ' ' + ('WEEK' | sharedLocalize)+ ': ' + getWeekNumber(selectedDate) "> </span>
310
+ </div>
311
+ <div class="weekday-value">
312
+ <span [textContent]="capitalizeString(weekDay.weekdayLong)"></span>
313
+ <span [textContent]="weekDay.weekdayDay + ' ' + capitalizeString(weekDay.weekdayMonthLong) + ' ' + weekDay.weekdayYear"></span>
314
+ </div>
315
+ <co-icon *ngIf="index === 4" class="pointer-hover no-user-select add-unit-icon dark"
316
+ [iconData]="iconCacheService.getIcon(icons.ArrowPointRight)" (click)="addUnit()"></co-icon>
317
+
318
+ </div>
319
+ </div>
320
+
321
+ </div>
257
322
 
258
323
  <div class="agenda-header-wrapper" *ngIf="view === viewTypes.WeekSelectView">
259
324
  <div class="week-day-label" *ngFor="let weekDay of weekDays; let index = index"
@@ -298,4 +363,4 @@ AgendaHeaderComponent.propDecorators = {
298
363
  selectedDateChange: [{ type: Output }],
299
364
  rangeChange: [{ type: Output }]
300
365
  };
301
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"agenda-header.component.js","sourceRoot":"","sources":["../../../../../../../../projects/sharedcomponents/src/lib/components/date-planning/component/agenda/agenda-header.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterContentChecked,\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  Inject,\r\n  Input,\r\n  LOCALE_ID,\r\n  NgZone,\r\n  OnDestroy,\r\n  OnInit,\r\n  Output,\r\n  Renderer2, ViewEncapsulation\r\n} from \"@angular/core\";\r\nimport {CalendarView} from \"../../../../enum/calendar-view.enum\";\r\nimport {LanguageCode} from \"../../../../enum/language-code.enum\";\r\nimport {Weekday} from \"../../../../model/weekday.model\";\r\nimport {Week} from \"../../../../model/week.model\";\r\nimport {CalendarUtils} from \"../../../../utils/calendar.utils\";\r\nimport {NULL_DAY} from \"../../../../model/agenda-null-objects\";\r\nimport {Day} from \"../../../../model/day.model\"\r\nimport {Icon} from \"../../../../enum/icon.enum\";\r\nimport {AgendaEventPerDay} from \"../../../../model/agenda-event-per-day.model\";\r\nimport {DateUtils} from \"../../../../utils/date-utils\";\r\nimport {IconCacheService} from \"../../../../service/icon-cache.service\";\r\n\r\n@Component({\r\n    selector: \"agenda-header\",\r\n    template: `\r\n      <div class=\"agenda-header-wrapper\" *ngIf=\"view === viewTypes.DayView\">\r\n        <div class=\"hour-label-placeholder\" *ngIf=\"viewSelection\">\r\n          <view-select [selectedView]=\"view\" (selectedViewChange)=\"changeTheView($event)\"></view-select>\r\n        </div>\r\n        <div class=\"week-day-label\">\r\n          <co-icon class=\"pointer-hover no-user-select sub-unit-icon dark\"\r\n                   [iconData]=\"iconCacheService.getIcon(icons.ArrowPointLeft)\" (click)=\"subUnit()\"></co-icon>\r\n          <div class=\"day-description\" [textContent]=\"day.description\"></div>\r\n          <co-icon class=\"pointer-hover no-user-select add-unit-icon dark\"\r\n                   [iconData]=\"iconCacheService.getIcon(icons.ArrowPointRight)\" (click)=\"addUnit()\"></co-icon>\r\n        </div>\r\n      </div>\r\n      <div class=\"agenda-header-wrapper days-around\" *ngIf=\"view === viewTypes.DaysAround\">\r\n        <div class=\"hour-label-placeholder\" *ngIf=\"viewSelection\">\r\n          <view-select [selectedView]=\"view\" (selectedViewChange)=\"changeTheView($event)\"></view-select>\r\n        </div>\r\n        <div class=\"month-description\" *ngIf=\"weekDays?.length > 0\">\r\n          {{ (selectedDate | date: 'MMMM') + ' ' + selectedDate.getFullYear() + ' ' + ('WEEK' | sharedLocalize)+ ': ' +  getWeekNumber(selectedDate) }}\r\n        </div>\r\n        <div class=\"week-day-label days-around\" *ngFor=\"let weekDay of weekDays; let index = index\"\r\n             [class.selected]=\"weekDay.weekdaySelected\" (click)=\"setUnit(weekDay)\">\r\n          <co-icon *ngIf=\"showBackButton && index === 0\" class=\"pointer-hover no-user-select sub-unit-icon dark\"\r\n                   [iconData]=\"iconCacheService.getIcon(icons.ArrowPointLeft)\" (click)=\"subUnit()\"></co-icon>\r\n          <div class=\"weekday-value day\"\r\n               [textContent]=\"capitalizeString(weekDay.weekdayShort)\"></div>\r\n          <div class=\"weekday-value date\"\r\n               [textContent]=\"weekDay.weekdayDay\"></div>\r\n          <co-icon *ngIf=\"index === 6\" class=\"pointer-hover no-user-select add-unit-icon dark\"\r\n                   [iconData]=\"iconCacheService.getIcon(icons.ArrowPointRight)\" (click)=\"addUnit()\"></co-icon>\r\n        </div>\r\n      </div>\r\n      <div class=\"agenda-header-wrapper\" *ngIf=\"view === viewTypes.WeekView\">\r\n        <div class=\"hour-label-placeholder\" *ngIf=\"viewSelection\">\r\n          <view-select [selectedView]=\"view\" (selectedViewChange)=\"changeTheView($event)\"></view-select>\r\n        </div>\r\n          <div class=\"week-number-header-wrapper\">\r\n          <span [textContent]=\"(selectedDate | date: 'MMMM') + ' ' + selectedDate.getFullYear() + ' ' + ('WEEK' | sharedLocalize)+ ': ' +  getWeekNumber(selectedDate) \"> </span>\r\n          </div>\r\n          \r\n          <div class=\"week-view-header-wrapper\">\r\n        <div class=\"week-day-label\" *ngFor=\"let weekDay of weekDays; let index = index\"\r\n             [class.selected]=\"weekDay.weekdaySelected\" (click)=\"setUnit(weekDay)\">\r\n          <co-icon *ngIf=\"showBackButton && index === 0\" class=\"pointer-hover no-user-select sub-unit-icon dark\"\r\n                   [iconData]=\"iconCacheService.getIcon(icons.ArrowPointLeft)\" (click)=\"subUnit()\"></co-icon>\r\n          <div *ngIf=\"weekDay.newMonth\" [textContent]=\"weekDay.weekdayMonthLong + ' ' + weekDay.weekdayYear\"\r\n               class=\"month-description\">\r\n          </div>\r\n          <div class=\"weekday-value\"\r\n               [textContent]=\"capitalizeString(weekDay.weekdayLong) + ' ' + weekDay.weekdayDay + ' ' + capitalizeString(weekDay.weekdayMonthLong) + ' ' + weekDay.weekdayYear \"></div>\r\n          <co-icon *ngIf=\"index === 2\" class=\"pointer-hover no-user-select add-unit-icon dark\"\r\n                   [iconData]=\"iconCacheService.getIcon(icons.ArrowPointRight)\" (click)=\"addUnit()\"></co-icon>\r\n\r\n        </div>\r\n          </div>\r\n\r\n      </div>\r\n\r\n\r\n      <div class=\"agenda-header-wrapper\" *ngIf=\"view === viewTypes.WeekSelectView\">\r\n        <div class=\"week-day-label\" *ngFor=\"let weekDay of weekDays; let index = index\"\r\n             [class.selected]=\"weekDay.weekdaySelected\"\r\n             [class.selectable]=\"weekDay.events && weekDay.events.length > 0\"\r\n             (click)=\"setUnit(weekDay)\">\r\n          <co-icon *ngIf=\"index === 0 && showBackButton\" class=\"pointer-hover no-user-select sub-unit-icon dark\"\r\n                   [iconData]=\"iconCacheService.getIcon(icons.ArrowPointLeft)\" (click)=\"subUnit()\"></co-icon>\r\n          <div class=\"weekday-description\" [textContent]=\"weekDay.weekdayShort\"></div>\r\n          <div class=\"weekday-value\" [textContent]=\"weekDay.weekdayDay + ' ' + weekDay.weekdayMonthShort\"></div>\r\n          <co-icon *ngIf=\"index === 6\" class=\"pointer-hover no-user-select add-unit-icon dark\"\r\n                   [iconData]=\"iconCacheService.getIcon(icons.ArrowPointRight)\" (click)=\"addUnit()\"></co-icon>\r\n        </div>\r\n      </div>\r\n      <div class=\"agenda-header-wrapper\" *ngIf=\"view === viewTypes.MonthView\">\r\n        <div class=\"week-day-label\" *ngFor=\"let weekDay of weekDays; let index = index\">\r\n          <co-icon *ngIf=\"index === 0 && showBackButton\" class=\"pointer-hover no-user-select sub-unit-icon dark\"\r\n                   [iconData]=\"iconCacheService.getIcon(icons.ArrowPointLeft)\" (click)=\"subUnit()\"></co-icon>\r\n          <div class=\"weekday-description\" [textContent]=\"weekDay.weekdayShort\"></div>\r\n          <co-icon *ngIf=\"index === 6\" class=\"pointer-hover no-user-select add-unit-icon dark\"\r\n                   [iconData]=\"iconCacheService.getIcon(icons.ArrowPointRight)\" (click)=\"addUnit()\"></co-icon>\r\n        </div>\r\n      </div>\r\n    `,\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class AgendaHeaderComponent implements OnInit, OnDestroy, AfterContentChecked {\r\n    public readonly icons: typeof Icon = Icon;\r\n    public readonly viewTypes: typeof CalendarView = CalendarView;\r\n\r\n    private readonly scrollbarWidth: number = 15;\r\n\r\n    public today: Date = new Date();\r\n\r\n    @Input()\r\n    public set selectedDate(value: Date) {\r\n        this._selectedDate = new Date(value);\r\n        this._prepareHeaderData();\r\n    }\r\n\r\n    public get selectedDate(): Date {\r\n        return this._selectedDate;\r\n    }\r\n\r\n    @Input()\r\n    public view: CalendarView;\r\n\r\n    @Input()\r\n    public set firstAvailableDate(value: Date) {\r\n        if (value) {\r\n            this._firstAvailableDate = new Date(value);\r\n            this._prepareHeaderData();\r\n        }\r\n    }\r\n\r\n    public get firstAvailableDate(): Date {\r\n        return this._firstAvailableDate;\r\n    }\r\n\r\n    @Input()\r\n    public set eventsPerDay(value: AgendaEventPerDay[]) {\r\n        this._eventsPerDay = value;\r\n        this._prepareHeaderData();\r\n    }\r\n\r\n    @Input()\r\n    public viewSelection: boolean;\r\n\r\n    @Output()\r\n    public viewChange: EventEmitter<CalendarView> = new EventEmitter<CalendarView>();\r\n\r\n    @Output()\r\n    public selectedDateChange: EventEmitter<Date> = new EventEmitter<Date>();\r\n\r\n    @Output()\r\n    public rangeChange: EventEmitter<Date> = new EventEmitter<Date>();\r\n\r\n    public weekDays: Weekday[] = [];\r\n    public day: Day = NULL_DAY;\r\n    public showBackButton: boolean = true;\r\n\r\n    private _selectedDate: Date;\r\n    private _firstAvailableDate: Date;\r\n    private _eventsPerDay: AgendaEventPerDay[] = [];\r\n\r\n    constructor(\r\n        @Inject(LOCALE_ID) private readonly _locale: LanguageCode,\r\n        private _elementRef: ElementRef,\r\n        private _renderer: Renderer2,\r\n        private _ngZone: NgZone,\r\n        public iconCacheService: IconCacheService\r\n    ) {\r\n    }\r\n\r\n    ngOnDestroy(): void {\r\n        window.removeEventListener(\"resize\", this._onResize);\r\n        this._elementRef = undefined;\r\n    }\r\n\r\n    ngOnInit(): void {\r\n        this._ngZone.runOutsideAngular(() => {\r\n            window.addEventListener(\"resize\", this._onResize);\r\n        });\r\n    }\r\n\r\n    ngAfterContentChecked(): void {\r\n        this._resizeHost();\r\n    }\r\n\r\n    public subUnit(): void {\r\n        if (this.selectedDate) {\r\n            const newDate: Date = new Date(this.selectedDate);\r\n            switch (this.view) {\r\n                case CalendarView.DayView:\r\n                    newDate.setDate(this.selectedDate.getDate() - 1);\r\n                    break;\r\n                case CalendarView.DaysAround:\r\n                  newDate.setDate(this.selectedDate.getDate() - 1);\r\n                  break;\r\n                case CalendarView.WeekView:\r\n                    newDate.setDate(this.selectedDate.getDate() - 3);\r\n                    break;\r\n                case CalendarView.WeekSelectView:\r\n                    newDate.setDate(this.selectedDate.getDate() - 7);\r\n                    break;\r\n                case CalendarView.MonthView:\r\n                    newDate.setMonth(this.selectedDate.getMonth() - 1);\r\n                    break;\r\n            }\r\n            this.selectedDate = newDate;\r\n            this.rangeChange.emit(this.selectedDate);\r\n        }\r\n    }\r\n\r\n    public addUnit(): void {\r\n        if (this.selectedDate) {\r\n            const newDate: Date = new Date(this.selectedDate);\r\n            switch (this.view) {\r\n                case CalendarView.DayView:\r\n                    newDate.setDate(this.selectedDate.getDate() + 1);\r\n                    break;\r\n                case CalendarView.DaysAround:\r\n                    newDate.setDate(this.selectedDate.getDate() + 1);\r\n                    break;\r\n                case CalendarView.WeekView:\r\n                    newDate.setDate(this.selectedDate.getDate() + 3);\r\n                    break;\r\n                case CalendarView.WeekSelectView:\r\n                    newDate.setDate(this.selectedDate.getDate() + 7);\r\n                    break;\r\n                case CalendarView.MonthView:\r\n                    newDate.setMonth(this.selectedDate.getMonth() + 1);\r\n                    break;\r\n            }\r\n            this.selectedDate = newDate;\r\n            this.rangeChange.emit(this.selectedDate);\r\n        }\r\n    }\r\n\r\n    public setUnit(weekDay: Weekday): void {\r\n        this.selectedDate = weekDay.date;\r\n        this.selectedDateChange.emit(this.selectedDate);\r\n    }\r\n\r\n    public changeTheView(view: CalendarView): void {\r\n        this.view = view;\r\n        this.viewChange.emit(view);\r\n        this._prepareHeaderData();\r\n    }\r\n\r\n    private _onResize: EventListener = async (): Promise<void> => {\r\n        this._resizeHost();\r\n    }\r\n\r\n    /**\r\n     * Need to resize the host component to size it's fixed positioned child through css\r\n     */\r\n    private _resizeHost(): void {\r\n        if (this._elementRef) {\r\n            this._renderer.setStyle(\r\n                this._elementRef.nativeElement, \"width\", this._elementRef.nativeElement.parentElement.clientWidth - this.scrollbarWidth + \"px\");\r\n        }\r\n    }\r\n\r\n    private _prepareHeaderData(): void {\r\n        if (this.selectedDate) {\r\n            switch (this.view) {\r\n                case CalendarView.DayView:\r\n                    const day: Day = new Day();\r\n                    day.date = new Date(this.selectedDate);\r\n                    const options: any = { year: \"numeric\", month: \"long\", day: \"numeric\" };\r\n                    day.description = this.selectedDate.toLocaleDateString(this._locale, options);\r\n                    this.day = day;\r\n                    break;\r\n                case CalendarView.DaysAround:\r\n                    const weekAroundView: Week = CalendarUtils.GetDaysAround(this.selectedDate);\r\n                    this.weekDays = weekAroundView.weekDays;\r\n                    if (this.firstAvailableDate) {\r\n                      this.showBackButton = this.weekDays.find(wd => DateUtils.DatesEqual(this.firstAvailableDate, wd.date)) === undefined;\r\n                    }\r\n                    break;\r\n                case CalendarView.WeekView:\r\n                    const weekView: Week = CalendarUtils.GetDaysOfWeek(this.selectedDate);\r\n                    this.weekDays = weekView.weekDays;\r\n                    if (this.firstAvailableDate) {\r\n                        this.showBackButton = this.weekDays.find(wd => DateUtils.DatesEqual(this.firstAvailableDate, wd.date)) === undefined;\r\n                    }\r\n                    break;\r\n                case CalendarView.WeekSelectView:\r\n                    const weekSelectView: Week = CalendarUtils.GetDaysOfWeek(this.selectedDate);\r\n                    this.weekDays = weekSelectView.weekDays;\r\n                    this.weekDays.forEach((wd: Weekday) => {\r\n                        const evPerDay: AgendaEventPerDay = this._eventsPerDay && this._eventsPerDay.length > 0 ? this._eventsPerDay.find(e => DateUtils.DatesEqual(e.date, wd.date)) : null;\r\n                        if (evPerDay) {\r\n                            wd.events = evPerDay.events;\r\n                        } else {\r\n                            wd.weekdaySelected = false;\r\n                        }\r\n                    });\r\n                    if (this.firstAvailableDate) {\r\n                        this.showBackButton = this.weekDays.find(wd => DateUtils.DatesEqual(this.firstAvailableDate, wd.date)) === undefined;\r\n                    }\r\n                    break;\r\n                case CalendarView.MonthView:\r\n                    const weekOfMonth: Week = CalendarUtils.GetDaysOfWeek(this.selectedDate);\r\n                    this.weekDays = weekOfMonth.weekDays;\r\n                    if (this.firstAvailableDate) {\r\n                        this.showBackButton = this.weekDays.find(wd => DateUtils.DatesEqual(this.firstAvailableDate, wd.date)) === undefined;\r\n                    }\r\n                    break;\r\n            }\r\n        }\r\n    }\r\n\r\n    public capitalizeString(label: string): string {\r\n      return label[0].toUpperCase() + label.slice(1);\r\n    }\r\n\r\n    public getWeekNumber(date: Date): number {\r\n        // Copy date so we don’t modify the original\r\n        const target = new Date(Date.UTC(date.getFullYear(), date.getMonth(), date.getDate()));\r\n\r\n        // ISO week starts on Monday (1) and ends on Sunday (7)\r\n        // Set to nearest Thursday: current date + 4 - current day number\r\n        const dayNum = target.getUTCDay() || 7;\r\n        target.setUTCDate(target.getUTCDate() + 4 - dayNum);\r\n\r\n        // Calculate week number\r\n        const yearStart = new Date(Date.UTC(target.getUTCFullYear(), 0, 1));\r\n        const weekNo = Math.ceil((((target.getTime() - yearStart.getTime()) / 86400000) + 1) / 7);\r\n\r\n        return weekNo;\r\n    }\r\n}\r\n"]}
366
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"agenda-header.component.js","sourceRoot":"","sources":["../../../../../../../../projects/sharedcomponents/src/lib/components/date-planning/component/agenda/agenda-header.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterContentChecked,\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  Inject,\r\n  Input,\r\n  LOCALE_ID,\r\n  NgZone,\r\n  OnDestroy,\r\n  OnInit,\r\n  Output,\r\n  Renderer2, ViewEncapsulation\r\n} from \"@angular/core\";\r\nimport {CalendarView} from \"../../../../enum/calendar-view.enum\";\r\nimport {LanguageCode} from \"../../../../enum/language-code.enum\";\r\nimport {Weekday} from \"../../../../model/weekday.model\";\r\nimport {Week} from \"../../../../model/week.model\";\r\nimport {CalendarUtils} from \"../../../../utils/calendar.utils\";\r\nimport {NULL_DAY} from \"../../../../model/agenda-null-objects\";\r\nimport {Day} from \"../../../../model/day.model\"\r\nimport {Icon} from \"../../../../enum/icon.enum\";\r\nimport {AgendaEventPerDay} from \"../../../../model/agenda-event-per-day.model\";\r\nimport {DateUtils} from \"../../../../utils/date-utils\";\r\nimport {IconCacheService} from \"../../../../service/icon-cache.service\";\r\n\r\n@Component({\r\n    selector: \"agenda-header\",\r\n    template: `\r\n      <div class=\"agenda-header-wrapper day-view\" *ngIf=\"view === viewTypes.DayView\">\r\n        <div class=\"week-day-label\">\r\n          <co-icon class=\"pointer-hover no-user-select sub-unit-icon dark\"\r\n                   [iconData]=\"iconCacheService.getIcon(icons.ArrowPointLeft)\" (click)=\"subUnit()\"></co-icon>\r\n          <div class=\"day-description\" [textContent]=\"day.description\"></div>\r\n          <co-icon class=\"pointer-hover no-user-select add-unit-icon dark\"\r\n                   [iconData]=\"iconCacheService.getIcon(icons.ArrowPointRight)\" (click)=\"addUnit()\"></co-icon>\r\n        </div>\r\n      </div>\r\n      <div class=\"agenda-header-wrapper days-around\" *ngIf=\"view === viewTypes.DaysAround\">\r\n        <div class=\"month-description\" *ngIf=\"weekDays?.length > 0\">\r\n          {{ (selectedDate | date: 'MMMM') + ' ' + selectedDate.getFullYear() + ' ' + ('WEEK' | sharedLocalize)+ ': ' +  getWeekNumber(selectedDate) }}\r\n        </div>\r\n        <div class=\"week-day-label days-around\" *ngFor=\"let weekDay of weekDays; let index = index\"\r\n             [class.selected]=\"weekDay.weekdaySelected\" (click)=\"setUnit(weekDay)\">\r\n          <co-icon *ngIf=\"showBackButton && index === 0\" class=\"pointer-hover no-user-select sub-unit-icon dark\"\r\n                   [iconData]=\"iconCacheService.getIcon(icons.ArrowPointLeft)\" (click)=\"subUnit()\"></co-icon>\r\n          <div class=\"weekday-value day\"\r\n               [textContent]=\"capitalizeString(weekDay.weekdayShort)\"></div>\r\n          <div class=\"weekday-value date\"\r\n               [textContent]=\"weekDay.weekdayDay\"></div>\r\n          <co-icon *ngIf=\"index === 6\" class=\"pointer-hover no-user-select add-unit-icon dark\"\r\n                   [iconData]=\"iconCacheService.getIcon(icons.ArrowPointRight)\" (click)=\"addUnit()\"></co-icon>\r\n        </div>\r\n      </div>\r\n      <div class=\"agenda-header-wrapper three-days-view\" *ngIf=\"view === viewTypes.ThreeDaysView\">\r\n        <div class=\"hour-label-placeholder\" *ngIf=\"viewSelection\">\r\n          <view-select [selectedView]=\"view\" (selectedViewChange)=\"changeTheView($event)\"></view-select>\r\n        </div>\r\n        <div class=\"week-view-header-wrapper\">\r\n          <div class=\"week-day-label\" *ngFor=\"let weekDay of weekDays; let index = index\"\r\n               [class.selected]=\"weekDay.weekdaySelected\">\r\n            <co-icon *ngIf=\"showBackButton && index === 0\" class=\"pointer-hover no-user-select sub-unit-icon dark\"\r\n                     [iconData]=\"iconCacheService.getIcon(icons.ArrowPointLeft)\" (click)=\"subUnit()\"></co-icon>\r\n            <div *ngIf=\"weekDay.newMonth\"\r\n                 class=\"month-description\">\r\n              <span [textContent]=\"(selectedDate | date: 'MMMM') + ' ' + selectedDate.getFullYear() + ' ' + ('WEEK' | sharedLocalize)+ ': ' +  getWeekNumber(selectedDate) \"> </span>\r\n            </div>\r\n            <div class=\"weekday-value\"\r\n                 [textContent]=\"capitalizeString(weekDay.weekdayLong) + ' ' + weekDay.weekdayDay + ' ' + capitalizeString(weekDay.weekdayMonthLong) + ' ' + weekDay.weekdayYear \"></div>\r\n            <co-icon *ngIf=\"index === 2\" class=\"pointer-hover no-user-select add-unit-icon dark\"\r\n                     [iconData]=\"iconCacheService.getIcon(icons.ArrowPointRight)\" (click)=\"addUnit()\"></co-icon>\r\n\r\n          </div>\r\n        </div>\r\n\r\n      </div>\r\n      <div class=\"agenda-header-wrapper week-view\" *ngIf=\"view === viewTypes.WeekView\">\r\n        <div class=\"hour-label-placeholder\" *ngIf=\"viewSelection\">\r\n          <view-select [selectedView]=\"view\" (selectedViewChange)=\"changeTheView($event)\"></view-select>\r\n        </div>\r\n          <div class=\"week-view-header-wrapper\">\r\n        <div class=\"week-day-label\" *ngFor=\"let weekDay of weekDays; let index = index\"\r\n             [class.selected]=\"weekDay.weekdaySelected\" (click)=\"setUnit(weekDay)\">\r\n          <co-icon *ngIf=\"showBackButton && index === 0\" class=\"pointer-hover no-user-select sub-unit-icon dark\"\r\n                   [iconData]=\"iconCacheService.getIcon(icons.ArrowPointLeft)\" (click)=\"subUnit()\"></co-icon>\r\n          <div *ngIf=\"weekDay.newMonth\"\r\n               class=\"month-description\">\r\n            <span [textContent]=\"(selectedDate | date: 'MMMM') + ' ' + selectedDate.getFullYear() + ' ' + ('WEEK' | sharedLocalize)+ ': ' +  getWeekNumber(selectedDate) \"> </span>\r\n          </div>\r\n          <div class=\"weekday-value\">\r\n                <span [textContent]=\"capitalizeString(weekDay.weekdayLong)\"></span>\r\n                <span [textContent]=\"weekDay.weekdayDay + ' ' + capitalizeString(weekDay.weekdayMonthLong) + ' ' + weekDay.weekdayYear\"></span>\r\n          </div>\r\n          <co-icon *ngIf=\"index === 6\" class=\"pointer-hover no-user-select add-unit-icon dark\"\r\n                   [iconData]=\"iconCacheService.getIcon(icons.ArrowPointRight)\" (click)=\"addUnit()\"></co-icon>\r\n\r\n        </div>\r\n          </div>\r\n\r\n      </div>\r\n\r\n      <div class=\"agenda-header-wrapper work-week-view\" *ngIf=\"view === viewTypes.WeekWorkView\">\r\n        <div class=\"hour-label-placeholder\" *ngIf=\"viewSelection\">\r\n          <view-select [selectedView]=\"view\" (selectedViewChange)=\"changeTheView($event)\"></view-select>\r\n        </div>\r\n        <div class=\"week-view-header-wrapper\">\r\n          <div class=\"week-day-label\" *ngFor=\"let weekDay of weekDays; let index = index\"\r\n               [class.selected]=\"weekDay.weekdaySelected\">\r\n            <co-icon *ngIf=\"showBackButton && index === 0\" class=\"pointer-hover no-user-select sub-unit-icon dark\"\r\n                     [iconData]=\"iconCacheService.getIcon(icons.ArrowPointLeft)\" (click)=\"subUnit()\"></co-icon>\r\n            <div *ngIf=\"weekDay.newMonth\"\r\n                 class=\"month-description\">\r\n              <span [textContent]=\"(selectedDate | date: 'MMMM') + ' ' + selectedDate.getFullYear() + ' ' + ('WEEK' | sharedLocalize)+ ': ' +  getWeekNumber(selectedDate) \"> </span>\r\n            </div>\r\n            <div class=\"weekday-value\">\r\n              <span [textContent]=\"capitalizeString(weekDay.weekdayLong)\"></span>\r\n              <span [textContent]=\"weekDay.weekdayDay + ' ' + capitalizeString(weekDay.weekdayMonthLong) + ' ' + weekDay.weekdayYear\"></span>\r\n            </div>\r\n            <co-icon *ngIf=\"index === 4\" class=\"pointer-hover no-user-select add-unit-icon dark\"\r\n                     [iconData]=\"iconCacheService.getIcon(icons.ArrowPointRight)\" (click)=\"addUnit()\"></co-icon>\r\n\r\n          </div>\r\n        </div>\r\n\r\n      </div>\r\n\r\n      <div class=\"agenda-header-wrapper\" *ngIf=\"view === viewTypes.WeekSelectView\">\r\n        <div class=\"week-day-label\" *ngFor=\"let weekDay of weekDays; let index = index\"\r\n             [class.selected]=\"weekDay.weekdaySelected\"\r\n             [class.selectable]=\"weekDay.events && weekDay.events.length > 0\"\r\n             (click)=\"setUnit(weekDay)\">\r\n          <co-icon *ngIf=\"index === 0 && showBackButton\" class=\"pointer-hover no-user-select sub-unit-icon dark\"\r\n                   [iconData]=\"iconCacheService.getIcon(icons.ArrowPointLeft)\" (click)=\"subUnit()\"></co-icon>\r\n          <div class=\"weekday-description\" [textContent]=\"weekDay.weekdayShort\"></div>\r\n          <div class=\"weekday-value\" [textContent]=\"weekDay.weekdayDay + ' ' + weekDay.weekdayMonthShort\"></div>\r\n          <co-icon *ngIf=\"index === 6\" class=\"pointer-hover no-user-select add-unit-icon dark\"\r\n                   [iconData]=\"iconCacheService.getIcon(icons.ArrowPointRight)\" (click)=\"addUnit()\"></co-icon>\r\n        </div>\r\n      </div>\r\n      <div class=\"agenda-header-wrapper\" *ngIf=\"view === viewTypes.MonthView\">\r\n        <div class=\"week-day-label\" *ngFor=\"let weekDay of weekDays; let index = index\">\r\n          <co-icon *ngIf=\"index === 0 && showBackButton\" class=\"pointer-hover no-user-select sub-unit-icon dark\"\r\n                   [iconData]=\"iconCacheService.getIcon(icons.ArrowPointLeft)\" (click)=\"subUnit()\"></co-icon>\r\n          <div class=\"weekday-description\" [textContent]=\"weekDay.weekdayShort\"></div>\r\n          <co-icon *ngIf=\"index === 6\" class=\"pointer-hover no-user-select add-unit-icon dark\"\r\n                   [iconData]=\"iconCacheService.getIcon(icons.ArrowPointRight)\" (click)=\"addUnit()\"></co-icon>\r\n        </div>\r\n      </div>\r\n    `,\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class AgendaHeaderComponent implements OnInit, OnDestroy, AfterContentChecked {\r\n    public readonly icons: typeof Icon = Icon;\r\n    public readonly viewTypes: typeof CalendarView = CalendarView;\r\n\r\n    private readonly scrollbarWidth: number = 15;\r\n\r\n    public today: Date = new Date();\r\n\r\n    @Input()\r\n    public set selectedDate(value: Date) {\r\n        this._selectedDate = new Date(value);\r\n        this._prepareHeaderData();\r\n    }\r\n\r\n    public get selectedDate(): Date {\r\n        return this._selectedDate;\r\n    }\r\n\r\n    @Input()\r\n    public view: CalendarView;\r\n\r\n    @Input()\r\n    public set firstAvailableDate(value: Date) {\r\n        if (value) {\r\n            this._firstAvailableDate = new Date(value);\r\n            this._prepareHeaderData();\r\n        }\r\n    }\r\n\r\n    public get firstAvailableDate(): Date {\r\n        return this._firstAvailableDate;\r\n    }\r\n\r\n    @Input()\r\n    public set eventsPerDay(value: AgendaEventPerDay[]) {\r\n        this._eventsPerDay = value;\r\n        this._prepareHeaderData();\r\n    }\r\n\r\n    @Input()\r\n    public viewSelection: boolean;\r\n\r\n    @Output()\r\n    public viewChange: EventEmitter<CalendarView> = new EventEmitter<CalendarView>();\r\n\r\n    @Output()\r\n    public selectedDateChange: EventEmitter<Date> = new EventEmitter<Date>();\r\n\r\n    @Output()\r\n    public rangeChange: EventEmitter<Date> = new EventEmitter<Date>();\r\n\r\n    public weekDays: Weekday[] = [];\r\n    public day: Day = NULL_DAY;\r\n    public showBackButton: boolean = true;\r\n\r\n    private _selectedDate: Date;\r\n    private _firstAvailableDate: Date;\r\n    private _eventsPerDay: AgendaEventPerDay[] = [];\r\n\r\n    constructor(\r\n        @Inject(LOCALE_ID) private readonly _locale: LanguageCode,\r\n        private _elementRef: ElementRef,\r\n        private _renderer: Renderer2,\r\n        private _ngZone: NgZone,\r\n        public iconCacheService: IconCacheService\r\n    ) {\r\n    }\r\n\r\n    ngOnDestroy(): void {\r\n        window.removeEventListener(\"resize\", this._onResize);\r\n        this._elementRef = undefined;\r\n    }\r\n\r\n    ngOnInit(): void {\r\n        this._ngZone.runOutsideAngular(() => {\r\n            window.addEventListener(\"resize\", this._onResize);\r\n        });\r\n    }\r\n\r\n    ngAfterContentChecked(): void {\r\n        this._resizeHost();\r\n    }\r\n\r\n    public subUnit(): void {\r\n        if (this.selectedDate) {\r\n            const newDate: Date = new Date(this.selectedDate);\r\n            switch (this.view) {\r\n                case CalendarView.DayView:\r\n                    newDate.setDate(this.selectedDate.getDate() - 1);\r\n                    break;\r\n                case CalendarView.DaysAround:\r\n                  newDate.setDate(this.selectedDate.getDate() - 1);\r\n                  break;\r\n                case CalendarView.ThreeDaysView:\r\n                  newDate.setDate(this.selectedDate.getDate() - 3);\r\n                  break;\r\n                case CalendarView.WeekView:\r\n                    newDate.setDate(this.selectedDate.getDate() - 7);\r\n                    break;\r\n                case CalendarView.WeekWorkView:\r\n                    newDate.setDate(this.selectedDate.getDate() - 5);\r\n                    break;\r\n                case CalendarView.WeekSelectView:\r\n                    newDate.setDate(this.selectedDate.getDate() - 7);\r\n                    break;\r\n                case CalendarView.MonthView:\r\n                    newDate.setMonth(this.selectedDate.getMonth() - 1);\r\n                    break;\r\n            }\r\n            this.selectedDate = newDate;\r\n            this.rangeChange.emit(this.selectedDate);\r\n        }\r\n    }\r\n\r\n    public addUnit(): void {\r\n        if (this.selectedDate) {\r\n            const newDate: Date = new Date(this.selectedDate);\r\n            switch (this.view) {\r\n                case CalendarView.DayView:\r\n                    newDate.setDate(this.selectedDate.getDate() + 1);\r\n                    break;\r\n                case CalendarView.DaysAround:\r\n                    newDate.setDate(this.selectedDate.getDate() + 1);\r\n                    break;\r\n                case CalendarView.ThreeDaysView:\r\n                    newDate.setDate(this.selectedDate.getDate() + 3);\r\n                    break;\r\n                case CalendarView.WeekView:\r\n                    newDate.setDate(this.selectedDate.getDate() + 7);\r\n                    break;\r\n                case CalendarView.WeekWorkView:\r\n                    newDate.setDate(this.selectedDate.getDate() + 5);\r\n                    break;\r\n                case CalendarView.WeekSelectView:\r\n                    newDate.setDate(this.selectedDate.getDate() + 7);\r\n                    break;\r\n                case CalendarView.MonthView:\r\n                    newDate.setMonth(this.selectedDate.getMonth() + 1);\r\n                    break;\r\n            }\r\n            this.selectedDate = newDate;\r\n            this.rangeChange.emit(this.selectedDate);\r\n        }\r\n    }\r\n\r\n    public setUnit(weekDay: Weekday): void {\r\n        this.selectedDate = weekDay.date;\r\n        this.selectedDateChange.emit(this.selectedDate);\r\n    }\r\n\r\n    public changeTheView(view: CalendarView): void {\r\n        this.view = view;\r\n        this.viewChange.emit(view);\r\n        this._prepareHeaderData();\r\n    }\r\n\r\n    private _onResize: EventListener = async (): Promise<void> => {\r\n        this._resizeHost();\r\n    }\r\n\r\n    /**\r\n     * Need to resize the host component to size it's fixed positioned child through css\r\n     */\r\n    private _resizeHost(): void {\r\n        if (this._elementRef) {\r\n            this._renderer.setStyle(\r\n                this._elementRef.nativeElement, \"width\", this._elementRef.nativeElement.parentElement.clientWidth - this.scrollbarWidth + \"px\");\r\n        }\r\n    }\r\n\r\n    private _prepareHeaderData(): void {\r\n        if (this.selectedDate) {\r\n            switch (this.view) {\r\n                case CalendarView.DayView:\r\n                    const day: Day = new Day();\r\n                    day.date = new Date(this.selectedDate);\r\n                    const options: any = { year: \"numeric\", month: \"long\", day: \"numeric\" };\r\n                    day.description = this.selectedDate.toLocaleDateString(this._locale, options);\r\n                    this.day = day;\r\n                    break;\r\n                case CalendarView.DaysAround:\r\n                    const weekAroundView: Week = CalendarUtils.GetDaysAround(this.selectedDate);\r\n                    this.weekDays = weekAroundView.weekDays;\r\n                    if (this.firstAvailableDate) {\r\n                      this.showBackButton = this.weekDays.find(wd => DateUtils.DatesEqual(this.firstAvailableDate, wd.date)) === undefined;\r\n                    }\r\n                    break;\r\n                case CalendarView.ThreeDaysView:\r\n                const threeDaysView: Week = CalendarUtils.GetThreeDays(this.selectedDate);\r\n                this.weekDays = threeDaysView.weekDays;\r\n                if (this.firstAvailableDate) {\r\n                  this.showBackButton = this.weekDays.find(wd => DateUtils.DatesEqual(this.firstAvailableDate, wd.date)) === undefined;\r\n                }\r\n                break;\r\n                case CalendarView.WeekView:\r\n                const weekView: Week = CalendarUtils.GetDaysOfWeek(this.selectedDate);\r\n                this.weekDays = weekView.weekDays;\r\n                if (this.firstAvailableDate) {\r\n                  this.showBackButton = this.weekDays.find(wd => DateUtils.DatesEqual(this.firstAvailableDate, wd.date)) === undefined;\r\n                }\r\n                break;\r\n                case CalendarView.WeekWorkView:\r\n                const weekWorkView: Week = CalendarUtils.GetWorkDaysOfWeek(this.selectedDate);\r\n                this.weekDays = weekWorkView.weekDays;\r\n                if (this.firstAvailableDate) {\r\n                  this.showBackButton = this.weekDays.find(wd => DateUtils.DatesEqual(this.firstAvailableDate, wd.date)) === undefined;\r\n                }\r\n                break;\r\n                case CalendarView.WeekSelectView:\r\n                    const weekSelectView: Week = CalendarUtils.GetDaysOfWeek(this.selectedDate);\r\n                    this.weekDays = weekSelectView.weekDays;\r\n                    this.weekDays.forEach((wd: Weekday) => {\r\n                        const evPerDay: AgendaEventPerDay = this._eventsPerDay && this._eventsPerDay.length > 0 ? this._eventsPerDay.find(e => DateUtils.DatesEqual(e.date, wd.date)) : null;\r\n                        if (evPerDay) {\r\n                            wd.events = evPerDay.events;\r\n                        } else {\r\n                            wd.weekdaySelected = false;\r\n                        }\r\n                    });\r\n                    if (this.firstAvailableDate) {\r\n                        this.showBackButton = this.weekDays.find(wd => DateUtils.DatesEqual(this.firstAvailableDate, wd.date)) === undefined;\r\n                    }\r\n                    break;\r\n                case CalendarView.MonthView:\r\n                    const weekOfMonth: Week = CalendarUtils.GetDaysOfWeek(this.selectedDate);\r\n                    this.weekDays = weekOfMonth.weekDays;\r\n                    if (this.firstAvailableDate) {\r\n                        this.showBackButton = this.weekDays.find(wd => DateUtils.DatesEqual(this.firstAvailableDate, wd.date)) === undefined;\r\n                    }\r\n                    break;\r\n            }\r\n        }\r\n    }\r\n\r\n    public capitalizeString(label: string): string {\r\n      return label[0].toUpperCase() + label.slice(1);\r\n    }\r\n\r\n    public getWeekNumber(date: Date): number {\r\n        // Copy date so we don’t modify the original\r\n        const target = new Date(Date.UTC(date.getFullYear(), date.getMonth(), date.getDate()));\r\n\r\n        // ISO week starts on Monday (1) and ends on Sunday (7)\r\n        // Set to nearest Thursday: current date + 4 - current day number\r\n        const dayNum = target.getUTCDay() || 7;\r\n        target.setUTCDate(target.getUTCDate() + 4 - dayNum);\r\n\r\n        // Calculate week number\r\n        const yearStart = new Date(Date.UTC(target.getUTCFullYear(), 0, 1));\r\n        const weekNo = Math.ceil((((target.getTime() - yearStart.getTime()) / 86400000) + 1) / 7);\r\n\r\n        return weekNo;\r\n    }\r\n}\r\n"]}
@@ -11,10 +11,15 @@ export class ViewSelectComponent {
11
11
  ]);
12
12
  this.selectedView = CalendarView.WeekView;
13
13
  this.selectedViewChange = new EventEmitter();
14
+ this.CalendarView = CalendarView;
14
15
  }
15
16
  get modelAsThumbState() {
16
17
  return this._viewsToThumb.get(this.selectedView);
17
18
  }
19
+ selectView(view) {
20
+ this.selectedView = view;
21
+ this.selectedViewChange.emit(view);
22
+ }
18
23
  onThumbStateChange(thumbState) {
19
24
  this.selectedView = MapUtils.FindKeyByValue(this._viewsToThumb, (value) => {
20
25
  return (value === thumbState);
@@ -26,10 +31,38 @@ ViewSelectComponent.decorators = [
26
31
  { type: Component, args: [{
27
32
  selector: "view-select",
28
33
  template: `
29
- <div class="select-wrapper">
30
- <div [textContent]="'DAY'" class="label"></div>
31
- <div [textContent]="'MONTH'" class="label"></div>
34
+ <div class="select-wrapper">
35
+ <!--div class="label"
36
+ [class.active]="selectedView === CalendarView.DayView"
37
+ (click)="selectView(CalendarView.DayView)">
38
+ DAY
39
+ </div-->
40
+ <div
41
+ class="label"
42
+ [class.active]="selectedView === CalendarView.ThreeDaysView"
43
+ (click)="selectView(CalendarView.ThreeDaysView)">
44
+ <span [textContent]="'THREE_DAYS_VIEW' | sharedLocalize"></span>
45
+ </div>
46
+ <div
47
+ class="label"
48
+ [class.active]="selectedView === CalendarView.WeekWorkView"
49
+ (click)="selectView(CalendarView.WeekWorkView)">
50
+ <span [textContent]="'FIVE_DAYS_VIEW' | sharedLocalize"></span>
51
+ </div>
52
+ <div
53
+ class="label"
54
+ [class.active]="selectedView === CalendarView.WeekView"
55
+ (click)="selectView(CalendarView.WeekView)">
56
+ <span [textContent]="'WEEK_VIEW' | sharedLocalize"></span>
32
57
  </div>
58
+ <!--div
59
+ class="label"
60
+ [class.active]="selectedView === CalendarView.MonthView"
61
+ (click)="selectView(CalendarView.MonthView)">
62
+ MONTH
63
+ </div-->
64
+ </div>
65
+
33
66
  `,
34
67
  encapsulation: ViewEncapsulation.None
35
68
  },] }
@@ -39,4 +72,4 @@ ViewSelectComponent.propDecorators = {
39
72
  selectedView: [{ type: Input }],
40
73
  selectedViewChange: [{ type: Output }]
41
74
  };
42
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmlldy1zZWxlY3QuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc2hhcmVkY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvZGF0ZS1wbGFubmluZy9jb21wb25lbnQvYWdlbmRhL3ZpZXctc2VsZWN0LmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLGlCQUFpQixFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ3hGLE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSxxQ0FBcUMsQ0FBQztBQUNqRSxPQUFPLEVBQUMsa0JBQWtCLEVBQUMsTUFBTSx3Q0FBd0MsQ0FBQztBQUMxRSxPQUFPLEVBQUMsUUFBUSxFQUFDLE1BQU0sNkJBQTZCLENBQUM7QUFZckQsTUFBTSxPQUFPLG1CQUFtQjtJQWtCNUI7UUFoQmlCLGtCQUFhLEdBQTBDLElBQUksR0FBRyxDQUFtQztZQUM5RyxDQUFDLFlBQVksQ0FBQyxPQUFPLEVBQUUsa0JBQWtCLENBQUMsSUFBSSxDQUFDO1lBQy9DLENBQUMsWUFBWSxDQUFDLFFBQVEsRUFBRSxrQkFBa0IsQ0FBQyxNQUFNLENBQUM7WUFDbEQsQ0FBQyxZQUFZLENBQUMsU0FBUyxFQUFFLGtCQUFrQixDQUFDLEtBQUssQ0FBQztTQUNyRCxDQUFDLENBQUM7UUFHSSxpQkFBWSxHQUFpQixZQUFZLENBQUMsUUFBUSxDQUFDO1FBR25ELHVCQUFrQixHQUErQixJQUFJLFlBQVksRUFBZ0IsQ0FBQztJQU96RixDQUFDO0lBTEQsSUFBVyxpQkFBaUI7UUFDeEIsT0FBTyxJQUFJLENBQUMsYUFBYSxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsWUFBWSxDQUFDLENBQUM7SUFDckQsQ0FBQztJQUtNLGtCQUFrQixDQUFDLFVBQThCO1FBQ3BELElBQUksQ0FBQyxZQUFZLEdBQUcsUUFBUSxDQUFDLGNBQWMsQ0FBbUMsSUFBSSxDQUFDLGFBQWEsRUFBRSxDQUFDLEtBQXlCLEVBQUUsRUFBRTtZQUM1SCxPQUFPLENBQUMsS0FBSyxLQUFLLFVBQVUsQ0FBQyxDQUFDO1FBQ2xDLENBQUMsQ0FBQyxDQUFDO1FBQ0gsSUFBSSxDQUFDLGtCQUFrQixDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsWUFBWSxDQUFDLENBQUM7SUFDcEQsQ0FBQzs7O1lBcENKLFNBQVMsU0FBQztnQkFDUCxRQUFRLEVBQUUsYUFBYTtnQkFDdkIsUUFBUSxFQUFFOzs7OztLQUtUO2dCQUNELGFBQWEsRUFBRSxpQkFBaUIsQ0FBQyxJQUFJO2FBQ3hDOzs7OzJCQVNJLEtBQUs7aUNBR0wsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIElucHV0LCBPdXRwdXQsIFZpZXdFbmNhcHN1bGF0aW9ufSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5pbXBvcnQge0NhbGVuZGFyVmlld30gZnJvbSBcIi4uLy4uLy4uLy4uL2VudW0vY2FsZW5kYXItdmlldy5lbnVtXCI7XHJcbmltcG9ydCB7VGh1bWJUaHJlZVdheVN0YXRlfSBmcm9tIFwiLi4vLi4vLi4vLi4vZW51bS90aHVtYi10aHJlZS13YXktc3RhdGVcIjtcclxuaW1wb3J0IHtNYXBVdGlsc30gZnJvbSBcIi4uLy4uLy4uLy4uL3V0aWxzL21hcC11dGlsc1wiO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgICBzZWxlY3RvcjogXCJ2aWV3LXNlbGVjdFwiLFxyXG4gICAgdGVtcGxhdGU6IGBcclxuICAgICAgICA8ZGl2IGNsYXNzPVwic2VsZWN0LXdyYXBwZXJcIj5cclxuICAgICAgICAgICAgPGRpdiBbdGV4dENvbnRlbnRdPVwiJ0RBWSdcIiBjbGFzcz1cImxhYmVsXCI+PC9kaXY+XHJcbiAgICAgICAgICAgIDxkaXYgW3RleHRDb250ZW50XT1cIidNT05USCdcIiBjbGFzcz1cImxhYmVsXCI+PC9kaXY+XHJcbiAgICAgICAgPC9kaXY+XHJcbiAgICBgLFxyXG4gICAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZVxyXG59KVxyXG5leHBvcnQgY2xhc3MgVmlld1NlbGVjdENvbXBvbmVudCB7XHJcblxyXG4gICAgcHJpdmF0ZSByZWFkb25seSBfdmlld3NUb1RodW1iOiBNYXA8Q2FsZW5kYXJWaWV3LCBUaHVtYlRocmVlV2F5U3RhdGU+ID0gbmV3IE1hcDxDYWxlbmRhclZpZXcsIFRodW1iVGhyZWVXYXlTdGF0ZT4oW1xyXG4gICAgICAgIFtDYWxlbmRhclZpZXcuRGF5VmlldywgVGh1bWJUaHJlZVdheVN0YXRlLkxlZnRdLFxyXG4gICAgICAgIFtDYWxlbmRhclZpZXcuV2Vla1ZpZXcsIFRodW1iVGhyZWVXYXlTdGF0ZS5NaWRkbGVdLFxyXG4gICAgICAgIFtDYWxlbmRhclZpZXcuTW9udGhWaWV3LCBUaHVtYlRocmVlV2F5U3RhdGUuUmlnaHRdXHJcbiAgICBdKTtcclxuXHJcbiAgICBASW5wdXQoKVxyXG4gICAgcHVibGljIHNlbGVjdGVkVmlldzogQ2FsZW5kYXJWaWV3ID0gQ2FsZW5kYXJWaWV3LldlZWtWaWV3O1xyXG5cclxuICAgIEBPdXRwdXQoKVxyXG4gICAgcHVibGljIHNlbGVjdGVkVmlld0NoYW5nZTogRXZlbnRFbWl0dGVyPENhbGVuZGFyVmlldz4gPSBuZXcgRXZlbnRFbWl0dGVyPENhbGVuZGFyVmlldz4oKTtcclxuXHJcbiAgICBwdWJsaWMgZ2V0IG1vZGVsQXNUaHVtYlN0YXRlKCk6IFRodW1iVGhyZWVXYXlTdGF0ZSB7XHJcbiAgICAgICAgcmV0dXJuIHRoaXMuX3ZpZXdzVG9UaHVtYi5nZXQodGhpcy5zZWxlY3RlZFZpZXcpO1xyXG4gICAgfVxyXG5cclxuICAgIGNvbnN0cnVjdG9yKCkge1xyXG4gICAgfVxyXG5cclxuICAgIHB1YmxpYyBvblRodW1iU3RhdGVDaGFuZ2UodGh1bWJTdGF0ZTogVGh1bWJUaHJlZVdheVN0YXRlKTogdm9pZCB7XHJcbiAgICAgICAgdGhpcy5zZWxlY3RlZFZpZXcgPSBNYXBVdGlscy5GaW5kS2V5QnlWYWx1ZTxDYWxlbmRhclZpZXcsIFRodW1iVGhyZWVXYXlTdGF0ZT4odGhpcy5fdmlld3NUb1RodW1iLCAodmFsdWU6IFRodW1iVGhyZWVXYXlTdGF0ZSkgPT4ge1xyXG4gICAgICAgICAgICByZXR1cm4gKHZhbHVlID09PSB0aHVtYlN0YXRlKTtcclxuICAgICAgICB9KTtcclxuICAgICAgICB0aGlzLnNlbGVjdGVkVmlld0NoYW5nZS5lbWl0KHRoaXMuc2VsZWN0ZWRWaWV3KTtcclxuICAgIH1cclxufVxyXG4iXX0=
75
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmlldy1zZWxlY3QuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc2hhcmVkY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvZGF0ZS1wbGFubmluZy9jb21wb25lbnQvYWdlbmRhL3ZpZXctc2VsZWN0LmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLGlCQUFpQixFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ3hGLE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSxxQ0FBcUMsQ0FBQztBQUNqRSxPQUFPLEVBQUMsa0JBQWtCLEVBQUMsTUFBTSx3Q0FBd0MsQ0FBQztBQUMxRSxPQUFPLEVBQUMsUUFBUSxFQUFDLE1BQU0sNkJBQTZCLENBQUM7QUF3Q3JELE1BQU0sT0FBTyxtQkFBbUI7SUFvQjVCO1FBbEJpQixrQkFBYSxHQUEwQyxJQUFJLEdBQUcsQ0FBbUM7WUFDOUcsQ0FBQyxZQUFZLENBQUMsT0FBTyxFQUFFLGtCQUFrQixDQUFDLElBQUksQ0FBQztZQUMvQyxDQUFDLFlBQVksQ0FBQyxRQUFRLEVBQUUsa0JBQWtCLENBQUMsTUFBTSxDQUFDO1lBQ2xELENBQUMsWUFBWSxDQUFDLFNBQVMsRUFBRSxrQkFBa0IsQ0FBQyxLQUFLLENBQUM7U0FDckQsQ0FBQyxDQUFDO1FBR0ksaUJBQVksR0FBaUIsWUFBWSxDQUFDLFFBQVEsQ0FBQztRQUduRCx1QkFBa0IsR0FBK0IsSUFBSSxZQUFZLEVBQWdCLENBQUM7UUFFekUsaUJBQVksR0FBRyxZQUFZLENBQUM7SUFPNUMsQ0FBQztJQUxELElBQVcsaUJBQWlCO1FBQ3hCLE9BQU8sSUFBSSxDQUFDLGFBQWEsQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxDQUFDO0lBQ3JELENBQUM7SUFLTSxVQUFVLENBQUMsSUFBa0I7UUFDbEMsSUFBSSxDQUFDLFlBQVksR0FBRyxJQUFJLENBQUM7UUFDekIsSUFBSSxDQUFDLGtCQUFrQixDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUNyQyxDQUFDO0lBRU0sa0JBQWtCLENBQUMsVUFBOEI7UUFDcEQsSUFBSSxDQUFDLFlBQVksR0FBRyxRQUFRLENBQUMsY0FBYyxDQUFtQyxJQUFJLENBQUMsYUFBYSxFQUFFLENBQUMsS0FBeUIsRUFBRSxFQUFFO1lBQzVILE9BQU8sQ0FBQyxLQUFLLEtBQUssVUFBVSxDQUFDLENBQUM7UUFDbEMsQ0FBQyxDQUFDLENBQUM7UUFDSCxJQUFJLENBQUMsa0JBQWtCLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsQ0FBQztJQUNwRCxDQUFDOzs7WUF2RUosU0FBUyxTQUFDO2dCQUNQLFFBQVEsRUFBRSxhQUFhO2dCQUN2QixRQUFRLEVBQUU7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztLQWlDVDtnQkFDRCxhQUFhLEVBQUUsaUJBQWlCLENBQUMsSUFBSTthQUN4Qzs7OzsyQkFTSSxLQUFLO2lDQUdMLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT3V0cHV0LCBWaWV3RW5jYXBzdWxhdGlvbn0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuaW1wb3J0IHtDYWxlbmRhclZpZXd9IGZyb20gXCIuLi8uLi8uLi8uLi9lbnVtL2NhbGVuZGFyLXZpZXcuZW51bVwiO1xyXG5pbXBvcnQge1RodW1iVGhyZWVXYXlTdGF0ZX0gZnJvbSBcIi4uLy4uLy4uLy4uL2VudW0vdGh1bWItdGhyZWUtd2F5LXN0YXRlXCI7XHJcbmltcG9ydCB7TWFwVXRpbHN9IGZyb20gXCIuLi8uLi8uLi8uLi91dGlscy9tYXAtdXRpbHNcIjtcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gICAgc2VsZWN0b3I6IFwidmlldy1zZWxlY3RcIixcclxuICAgIHRlbXBsYXRlOiBgXHJcbiAgICAgIDxkaXYgY2xhc3M9XCJzZWxlY3Qtd3JhcHBlclwiPlxyXG4gICAgICAgIDwhLS1kaXYgY2xhc3M9XCJsYWJlbFwiXHJcbiAgICAgICAgICBbY2xhc3MuYWN0aXZlXT1cInNlbGVjdGVkVmlldyA9PT0gQ2FsZW5kYXJWaWV3LkRheVZpZXdcIlxyXG4gICAgICAgICAgKGNsaWNrKT1cInNlbGVjdFZpZXcoQ2FsZW5kYXJWaWV3LkRheVZpZXcpXCI+XHJcbiAgICAgICAgICBEQVlcclxuICAgICAgICA8L2Rpdi0tPlxyXG4gICAgICAgIDxkaXZcclxuICAgICAgICAgIGNsYXNzPVwibGFiZWxcIlxyXG4gICAgICAgICAgW2NsYXNzLmFjdGl2ZV09XCJzZWxlY3RlZFZpZXcgPT09IENhbGVuZGFyVmlldy5UaHJlZURheXNWaWV3XCJcclxuICAgICAgICAgIChjbGljayk9XCJzZWxlY3RWaWV3KENhbGVuZGFyVmlldy5UaHJlZURheXNWaWV3KVwiPlxyXG4gICAgICAgICAgPHNwYW4gW3RleHRDb250ZW50XT1cIidUSFJFRV9EQVlTX1ZJRVcnIHwgc2hhcmVkTG9jYWxpemVcIj48L3NwYW4+XHJcbiAgICAgICAgPC9kaXY+XHJcbiAgICAgICAgPGRpdlxyXG4gICAgICAgICAgY2xhc3M9XCJsYWJlbFwiXHJcbiAgICAgICAgICBbY2xhc3MuYWN0aXZlXT1cInNlbGVjdGVkVmlldyA9PT0gQ2FsZW5kYXJWaWV3LldlZWtXb3JrVmlld1wiXHJcbiAgICAgICAgICAoY2xpY2spPVwic2VsZWN0VmlldyhDYWxlbmRhclZpZXcuV2Vla1dvcmtWaWV3KVwiPlxyXG4gICAgICAgICAgPHNwYW4gW3RleHRDb250ZW50XT1cIidGSVZFX0RBWVNfVklFVycgfCBzaGFyZWRMb2NhbGl6ZVwiPjwvc3Bhbj5cclxuICAgICAgICA8L2Rpdj5cclxuICAgICAgICA8ZGl2XHJcbiAgICAgICAgICBjbGFzcz1cImxhYmVsXCJcclxuICAgICAgICAgIFtjbGFzcy5hY3RpdmVdPVwic2VsZWN0ZWRWaWV3ID09PSBDYWxlbmRhclZpZXcuV2Vla1ZpZXdcIlxyXG4gICAgICAgICAgKGNsaWNrKT1cInNlbGVjdFZpZXcoQ2FsZW5kYXJWaWV3LldlZWtWaWV3KVwiPlxyXG4gICAgICAgICAgPHNwYW4gW3RleHRDb250ZW50XT1cIidXRUVLX1ZJRVcnIHwgc2hhcmVkTG9jYWxpemVcIj48L3NwYW4+XHJcbiAgICAgICAgPC9kaXY+XHJcbiAgICAgICAgPCEtLWRpdlxyXG4gICAgICAgICAgY2xhc3M9XCJsYWJlbFwiXHJcbiAgICAgICAgICBbY2xhc3MuYWN0aXZlXT1cInNlbGVjdGVkVmlldyA9PT0gQ2FsZW5kYXJWaWV3Lk1vbnRoVmlld1wiXHJcbiAgICAgICAgICAoY2xpY2spPVwic2VsZWN0VmlldyhDYWxlbmRhclZpZXcuTW9udGhWaWV3KVwiPlxyXG4gICAgICAgICAgTU9OVEhcclxuICAgICAgICA8L2Rpdi0tPlxyXG4gICAgICA8L2Rpdj5cclxuXHJcbiAgICBgLFxyXG4gICAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZVxyXG59KVxyXG5leHBvcnQgY2xhc3MgVmlld1NlbGVjdENvbXBvbmVudCB7XHJcblxyXG4gICAgcHJpdmF0ZSByZWFkb25seSBfdmlld3NUb1RodW1iOiBNYXA8Q2FsZW5kYXJWaWV3LCBUaHVtYlRocmVlV2F5U3RhdGU+ID0gbmV3IE1hcDxDYWxlbmRhclZpZXcsIFRodW1iVGhyZWVXYXlTdGF0ZT4oW1xyXG4gICAgICAgIFtDYWxlbmRhclZpZXcuRGF5VmlldywgVGh1bWJUaHJlZVdheVN0YXRlLkxlZnRdLFxyXG4gICAgICAgIFtDYWxlbmRhclZpZXcuV2Vla1ZpZXcsIFRodW1iVGhyZWVXYXlTdGF0ZS5NaWRkbGVdLFxyXG4gICAgICAgIFtDYWxlbmRhclZpZXcuTW9udGhWaWV3LCBUaHVtYlRocmVlV2F5U3RhdGUuUmlnaHRdXHJcbiAgICBdKTtcclxuXHJcbiAgICBASW5wdXQoKVxyXG4gICAgcHVibGljIHNlbGVjdGVkVmlldzogQ2FsZW5kYXJWaWV3ID0gQ2FsZW5kYXJWaWV3LldlZWtWaWV3O1xyXG5cclxuICAgIEBPdXRwdXQoKVxyXG4gICAgcHVibGljIHNlbGVjdGVkVmlld0NoYW5nZTogRXZlbnRFbWl0dGVyPENhbGVuZGFyVmlldz4gPSBuZXcgRXZlbnRFbWl0dGVyPENhbGVuZGFyVmlldz4oKTtcclxuXHJcbiAgICBwdWJsaWMgcmVhZG9ubHkgQ2FsZW5kYXJWaWV3ID0gQ2FsZW5kYXJWaWV3O1xyXG5cclxuICAgIHB1YmxpYyBnZXQgbW9kZWxBc1RodW1iU3RhdGUoKTogVGh1bWJUaHJlZVdheVN0YXRlIHtcclxuICAgICAgICByZXR1cm4gdGhpcy5fdmlld3NUb1RodW1iLmdldCh0aGlzLnNlbGVjdGVkVmlldyk7XHJcbiAgICB9XHJcblxyXG4gICAgY29uc3RydWN0b3IoKSB7XHJcbiAgICB9XHJcblxyXG4gICAgcHVibGljIHNlbGVjdFZpZXcodmlldzogQ2FsZW5kYXJWaWV3KTogdm9pZCB7XHJcbiAgICAgIHRoaXMuc2VsZWN0ZWRWaWV3ID0gdmlldztcclxuICAgICAgdGhpcy5zZWxlY3RlZFZpZXdDaGFuZ2UuZW1pdCh2aWV3KTtcclxuICAgIH1cclxuXHJcbiAgICBwdWJsaWMgb25UaHVtYlN0YXRlQ2hhbmdlKHRodW1iU3RhdGU6IFRodW1iVGhyZWVXYXlTdGF0ZSk6IHZvaWQge1xyXG4gICAgICAgIHRoaXMuc2VsZWN0ZWRWaWV3ID0gTWFwVXRpbHMuRmluZEtleUJ5VmFsdWU8Q2FsZW5kYXJWaWV3LCBUaHVtYlRocmVlV2F5U3RhdGU+KHRoaXMuX3ZpZXdzVG9UaHVtYiwgKHZhbHVlOiBUaHVtYlRocmVlV2F5U3RhdGUpID0+IHtcclxuICAgICAgICAgICAgcmV0dXJuICh2YWx1ZSA9PT0gdGh1bWJTdGF0ZSk7XHJcbiAgICAgICAgfSk7XHJcbiAgICAgICAgdGhpcy5zZWxlY3RlZFZpZXdDaGFuZ2UuZW1pdCh0aGlzLnNlbGVjdGVkVmlldyk7XHJcbiAgICB9XHJcbn1cclxuIl19
@@ -18,7 +18,7 @@ export class CalendarViewComponent {
18
18
  this.weekDayLabel = [];
19
19
  this.weeks = [];
20
20
  this._selectedDate = new Date();
21
- this._view = CalendarView.WeekView;
21
+ this._view = CalendarView.ThreeDaysView;
22
22
  this.selectedDate.setHours(0, 0, 0, 0);
23
23
  this._setLabels();
24
24
  }
@@ -175,4 +175,4 @@ CalendarViewComponent.propDecorators = {
175
175
  selectedDate: [{ type: Input }],
176
176
  selectedDateChange: [{ type: Output }]
177
177
  };
178
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar-view.component.js","sourceRoot":"","sources":["../../../../../../../../projects/sharedcomponents/src/lib/components/date-planning/component/calendar/calendar-view.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, EventEmitter, Inject, Input, LOCALE_ID, Output, ViewEncapsulation} from \"@angular/core\";\r\nimport {ArrayNumberPipe} from \"../../../../pipe/array-number.pipe\";\r\nimport {DatePipe} from \"@angular/common\";\r\nimport {DateUtils} from \"../../../../utils/date-utils\";\r\nimport {CalendarView} from \"../../../../enum/calendar-view.enum\";\r\nimport {LanguageCode} from \"../../../../enum/language-code.enum\";\r\n\r\ntype DateStamp = { day: number, inMonth: boolean, timestamp: number, week: number, selected: boolean };\r\n\r\n@Component({\r\n  selector: \"calendar-view\",\r\n  template: `\r\n        <div class=\"calendar-content\">\r\n            <div>\r\n                <div class=\"week-day-header week-row\">\r\n                    <div class=\"week-acronym\"></div>\r\n                    <div *ngFor=\"let weekDay of weekDayLabel\" [textContent]=\"weekDay | ucfirst\"\r\n                         class=\"week-day-label\"></div>\r\n                </div>\r\n                <div class=\"week-row\" *ngFor=\"let week of weeks;trackBy:trackByWeek\">\r\n                    <div [textContent]=\"week[0].week\" class=\"week-number\"></div>\r\n                    <div *ngFor=\"let date of week;trackBy:trackByStamp\" class=\"week-day\"\r\n                         (click)=\"onDateClick(date)\" [textContent]=\"date.day\">\r\n                    </div>\r\n                </div>\r\n            </div>\r\n        </div>\r\n    `,\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\n//fixme we don't have a todayDayStamp field but our template references it\r\nexport class CalendarViewComponent {\r\n\r\n  @Input()\r\n  public set view(value: CalendarView) {\r\n    this._view = value;\r\n    this._selectDays();\r\n  }\r\n\r\n  public get view(): CalendarView {\r\n    return this._view;\r\n  }\r\n\r\n  @Input()\r\n  public set selectedDate(value: Date) {\r\n    this._selectedDate = value;\r\n    this._selectedDate.setHours(0, 0, 0, 0);\r\n    this._prepareWeeks();\r\n  }\r\n\r\n  public get selectedDate(): Date {\r\n    return this._selectedDate;\r\n  }\r\n\r\n  @Output()\r\n  public selectedDateChange: EventEmitter<Date> = new EventEmitter<Date>();\r\n\r\n  public trackByStamp: Function = (index: number, stamp: DateStamp): number => {\r\n    return stamp && stamp.timestamp || index;\r\n  }\r\n\r\n  public trackByWeek: Function = (index: number, week: DateStamp[]): number => {\r\n    return week && week[0].week || index;\r\n  }\r\n\r\n  public weekDayLabel: string[] = [];\r\n\r\n  public weeks: DateStamp[][] = [];\r\n\r\n  private _selectedDate: Date = new Date();\r\n\r\n  private _view: CalendarView = CalendarView.WeekView;\r\n\r\n  constructor(\r\n    @Inject(LOCALE_ID) private readonly _locale: LanguageCode,\r\n  ) {\r\n    this.selectedDate.setHours(0, 0, 0, 0);\r\n    this._setLabels();\r\n  }\r\n\r\n  public onDateClick(date: DateStamp): void {\r\n    this.selectedDate = new Date(date.timestamp);\r\n    this.selectedDateChange.emit(this.selectedDate);\r\n    this._selectDays();\r\n  }\r\n\r\n  private _setLabels(): void {\r\n    const datePipe: DatePipe = new DatePipe(this._locale);\r\n\r\n    const currentDay: number = this.selectedDate.getDay();\r\n    const startWeekDate: Date = new Date(this.selectedDate.getTime());\r\n    startWeekDate.setDate(startWeekDate.getDate() - currentDay - 1);\r\n\r\n    this.weekDayLabel = new ArrayNumberPipe().transform(7).map(() => {\r\n      startWeekDate.setDate(startWeekDate.getDate() + 1);\r\n      return datePipe.transform(startWeekDate, \"E\");\r\n    });\r\n    this.weekDayLabel.push(this.weekDayLabel.shift());\r\n  }\r\n\r\n  private _prepareWeeks(): void {\r\n    this.weeks.length = 0;\r\n\r\n    const date: Date = new Date(this.selectedDate.getTime());\r\n    date.setHours(0, 0, 0, 0);\r\n\r\n    // go to last day of month\r\n    date.setMonth(date.getMonth() + 1);\r\n    date.setDate(0);\r\n    const monthEndDay: number = date.getDay();\r\n    const monthEndDate: number = date.getDate();\r\n\r\n    // days after end of month\r\n    const daysAfter: number = !monthEndDay ? 0 : 7 - monthEndDay;\r\n\r\n    // go to first day of month\r\n    date.setDate(1);\r\n    const monthBeginDay: number = date.getDay();\r\n\r\n    // days before start of month\r\n    const daysBefore: number = !monthBeginDay ? 6 : monthBeginDay - 1;\r\n\r\n    // go to start of calendar view\r\n    date.setDate(-daysBefore + 1);\r\n\r\n    // amount of weeks to display\r\n    const weekCount: number = Math.ceil((daysBefore + daysAfter + monthEndDate) / 7);\r\n    const weekStart: number = DateUtils.GetWeekNumber(date);\r\n    const weekEnd: number = weekStart + weekCount - 1;\r\n\r\n    // iterate over week count\r\n    for (let i: number = weekStart; i <= weekEnd; i++) {\r\n      let week: number = i;\r\n\r\n      // only recalculate week when it's necessary\r\n      if (weekStart > 50) {\r\n        week = DateUtils.GetWeekNumber(date);\r\n      }\r\n      const days: DateStamp[] = [];\r\n\r\n      // iterate over 7 days\r\n      for (let ii: number = 1; ii <= 7; ii++) {\r\n        // check if we are in the current month\r\n        let inMonth: boolean = true;\r\n        if (i === weekStart) {\r\n          inMonth = ii > daysBefore;\r\n        } else if (i === weekEnd) {\r\n          inMonth = ii <= 7 - daysAfter;\r\n        }\r\n\r\n        const timestamp: number = date.getTime();\r\n        // add dateStamp to date array\r\n        days.push({\r\n          week: week,\r\n          inMonth: inMonth,\r\n          day: date.getDate(),\r\n          timestamp: timestamp,\r\n          selected: this.selectedDate.getTime() === timestamp\r\n        });\r\n        // go one day further\r\n        date.setDate(date.getDate() + 1);\r\n      }\r\n      this.weeks.push(days);\r\n    }\r\n    this._selectDays();\r\n  }\r\n\r\n  private _selectDays(): void {\r\n    this._resetSelection();\r\n    if (!this.selectedDate) {\r\n      return;\r\n    }\r\n    const weekNumber: number = DateUtils.GetWeekNumber(this.selectedDate);\r\n    const len: number = this.weeks.length;\r\n    for (let i: number = 0; i < len; i++) {\r\n      const leni: number = this.weeks[i].length;\r\n      for (let ii: number = 0; ii < leni; ii++) {\r\n        if (this.weeks[i][ii].inMonth && this.view === CalendarView.MonthView) {\r\n          this.weeks[i][ii].selected = true;\r\n        } else if (this.weeks[i][ii].week === weekNumber && this.view === CalendarView.WeekView) {\r\n          this.weeks[i][ii].selected = true;\r\n        } else if (this.weeks[i][ii].timestamp === this.selectedDate.getTime() && this.view === CalendarView.WeekSelectView) {\r\n          this.weeks[i][ii].selected = true;\r\n        } else if (this.weeks[i][ii].timestamp === this.selectedDate.getTime() && this.view === CalendarView.DayView) {\r\n          this.weeks[i][ii].selected = true;\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  private _resetSelection(): void {\r\n    const len: number = this.weeks.length;\r\n    for (let i: number = 0; i < len; i++) {\r\n      const leni: number = this.weeks[i].length;\r\n      for (let ii: number = 0; ii < leni; ii++) {\r\n        this.weeks[i][ii].selected = false;\r\n      }\r\n    }\r\n  }\r\n}\r\n"]}
178
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar-view.component.js","sourceRoot":"","sources":["../../../../../../../../projects/sharedcomponents/src/lib/components/date-planning/component/calendar/calendar-view.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, EventEmitter, Inject, Input, LOCALE_ID, Output, ViewEncapsulation} from \"@angular/core\";\r\nimport {ArrayNumberPipe} from \"../../../../pipe/array-number.pipe\";\r\nimport {DatePipe} from \"@angular/common\";\r\nimport {DateUtils} from \"../../../../utils/date-utils\";\r\nimport {CalendarView} from \"../../../../enum/calendar-view.enum\";\r\nimport {LanguageCode} from \"../../../../enum/language-code.enum\";\r\n\r\ntype DateStamp = { day: number, inMonth: boolean, timestamp: number, week: number, selected: boolean };\r\n\r\n@Component({\r\n  selector: \"calendar-view\",\r\n  template: `\r\n        <div class=\"calendar-content\">\r\n            <div>\r\n                <div class=\"week-day-header week-row\">\r\n                    <div class=\"week-acronym\"></div>\r\n                    <div *ngFor=\"let weekDay of weekDayLabel\" [textContent]=\"weekDay | ucfirst\"\r\n                         class=\"week-day-label\"></div>\r\n                </div>\r\n                <div class=\"week-row\" *ngFor=\"let week of weeks;trackBy:trackByWeek\">\r\n                    <div [textContent]=\"week[0].week\" class=\"week-number\"></div>\r\n                    <div *ngFor=\"let date of week;trackBy:trackByStamp\" class=\"week-day\"\r\n                         (click)=\"onDateClick(date)\" [textContent]=\"date.day\">\r\n                    </div>\r\n                </div>\r\n            </div>\r\n        </div>\r\n    `,\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\n//fixme we don't have a todayDayStamp field but our template references it\r\nexport class CalendarViewComponent {\r\n\r\n  @Input()\r\n  public set view(value: CalendarView) {\r\n    this._view = value;\r\n    this._selectDays();\r\n  }\r\n\r\n  public get view(): CalendarView {\r\n    return this._view;\r\n  }\r\n\r\n  @Input()\r\n  public set selectedDate(value: Date) {\r\n    this._selectedDate = value;\r\n    this._selectedDate.setHours(0, 0, 0, 0);\r\n    this._prepareWeeks();\r\n  }\r\n\r\n  public get selectedDate(): Date {\r\n    return this._selectedDate;\r\n  }\r\n\r\n  @Output()\r\n  public selectedDateChange: EventEmitter<Date> = new EventEmitter<Date>();\r\n\r\n  public trackByStamp: Function = (index: number, stamp: DateStamp): number => {\r\n    return stamp && stamp.timestamp || index;\r\n  }\r\n\r\n  public trackByWeek: Function = (index: number, week: DateStamp[]): number => {\r\n    return week && week[0].week || index;\r\n  }\r\n\r\n  public weekDayLabel: string[] = [];\r\n\r\n  public weeks: DateStamp[][] = [];\r\n\r\n  private _selectedDate: Date = new Date();\r\n\r\n  private _view: CalendarView = CalendarView.ThreeDaysView;\r\n\r\n  constructor(\r\n    @Inject(LOCALE_ID) private readonly _locale: LanguageCode,\r\n  ) {\r\n    this.selectedDate.setHours(0, 0, 0, 0);\r\n    this._setLabels();\r\n  }\r\n\r\n  public onDateClick(date: DateStamp): void {\r\n    this.selectedDate = new Date(date.timestamp);\r\n    this.selectedDateChange.emit(this.selectedDate);\r\n    this._selectDays();\r\n  }\r\n\r\n  private _setLabels(): void {\r\n    const datePipe: DatePipe = new DatePipe(this._locale);\r\n\r\n    const currentDay: number = this.selectedDate.getDay();\r\n    const startWeekDate: Date = new Date(this.selectedDate.getTime());\r\n    startWeekDate.setDate(startWeekDate.getDate() - currentDay - 1);\r\n\r\n    this.weekDayLabel = new ArrayNumberPipe().transform(7).map(() => {\r\n      startWeekDate.setDate(startWeekDate.getDate() + 1);\r\n      return datePipe.transform(startWeekDate, \"E\");\r\n    });\r\n    this.weekDayLabel.push(this.weekDayLabel.shift());\r\n  }\r\n\r\n  private _prepareWeeks(): void {\r\n    this.weeks.length = 0;\r\n\r\n    const date: Date = new Date(this.selectedDate.getTime());\r\n    date.setHours(0, 0, 0, 0);\r\n\r\n    // go to last day of month\r\n    date.setMonth(date.getMonth() + 1);\r\n    date.setDate(0);\r\n    const monthEndDay: number = date.getDay();\r\n    const monthEndDate: number = date.getDate();\r\n\r\n    // days after end of month\r\n    const daysAfter: number = !monthEndDay ? 0 : 7 - monthEndDay;\r\n\r\n    // go to first day of month\r\n    date.setDate(1);\r\n    const monthBeginDay: number = date.getDay();\r\n\r\n    // days before start of month\r\n    const daysBefore: number = !monthBeginDay ? 6 : monthBeginDay - 1;\r\n\r\n    // go to start of calendar view\r\n    date.setDate(-daysBefore + 1);\r\n\r\n    // amount of weeks to display\r\n    const weekCount: number = Math.ceil((daysBefore + daysAfter + monthEndDate) / 7);\r\n    const weekStart: number = DateUtils.GetWeekNumber(date);\r\n    const weekEnd: number = weekStart + weekCount - 1;\r\n\r\n    // iterate over week count\r\n    for (let i: number = weekStart; i <= weekEnd; i++) {\r\n      let week: number = i;\r\n\r\n      // only recalculate week when it's necessary\r\n      if (weekStart > 50) {\r\n        week = DateUtils.GetWeekNumber(date);\r\n      }\r\n      const days: DateStamp[] = [];\r\n\r\n      // iterate over 7 days\r\n      for (let ii: number = 1; ii <= 7; ii++) {\r\n        // check if we are in the current month\r\n        let inMonth: boolean = true;\r\n        if (i === weekStart) {\r\n          inMonth = ii > daysBefore;\r\n        } else if (i === weekEnd) {\r\n          inMonth = ii <= 7 - daysAfter;\r\n        }\r\n\r\n        const timestamp: number = date.getTime();\r\n        // add dateStamp to date array\r\n        days.push({\r\n          week: week,\r\n          inMonth: inMonth,\r\n          day: date.getDate(),\r\n          timestamp: timestamp,\r\n          selected: this.selectedDate.getTime() === timestamp\r\n        });\r\n        // go one day further\r\n        date.setDate(date.getDate() + 1);\r\n      }\r\n      this.weeks.push(days);\r\n    }\r\n    this._selectDays();\r\n  }\r\n\r\n  private _selectDays(): void {\r\n    this._resetSelection();\r\n    if (!this.selectedDate) {\r\n      return;\r\n    }\r\n    const weekNumber: number = DateUtils.GetWeekNumber(this.selectedDate);\r\n    const len: number = this.weeks.length;\r\n    for (let i: number = 0; i < len; i++) {\r\n      const leni: number = this.weeks[i].length;\r\n      for (let ii: number = 0; ii < leni; ii++) {\r\n        if (this.weeks[i][ii].inMonth && this.view === CalendarView.MonthView) {\r\n          this.weeks[i][ii].selected = true;\r\n        } else if (this.weeks[i][ii].week === weekNumber && this.view === CalendarView.WeekView) {\r\n          this.weeks[i][ii].selected = true;\r\n        } else if (this.weeks[i][ii].timestamp === this.selectedDate.getTime() && this.view === CalendarView.WeekSelectView) {\r\n          this.weeks[i][ii].selected = true;\r\n        } else if (this.weeks[i][ii].timestamp === this.selectedDate.getTime() && this.view === CalendarView.DayView) {\r\n          this.weeks[i][ii].selected = true;\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  private _resetSelection(): void {\r\n    const len: number = this.weeks.length;\r\n    for (let i: number = 0; i < len; i++) {\r\n      const leni: number = this.weeks[i].length;\r\n      for (let ii: number = 0; ii < leni; ii++) {\r\n        this.weeks[i][ii].selected = false;\r\n      }\r\n    }\r\n  }\r\n}\r\n"]}
@@ -2,7 +2,7 @@ import { Component, EventEmitter, Input, Output, ViewEncapsulation } from "@angu
2
2
  import { CalendarView } from "../../../../enum/calendar-view.enum";
3
3
  export class CalendarComponent {
4
4
  constructor() {
5
- this.view = CalendarView.WeekView;
5
+ this.view = CalendarView.ThreeDaysView;
6
6
  this.selectedDate = new Date();
7
7
  this.days = [];
8
8
  this.selectedDateChange = new EventEmitter();
@@ -31,4 +31,4 @@ CalendarComponent.propDecorators = {
31
31
  days: [{ type: Input }],
32
32
  selectedDateChange: [{ type: Output }]
33
33
  };
34
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FsZW5kYXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc2hhcmVkY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvZGF0ZS1wbGFubmluZy9jb21wb25lbnQvY2FsZW5kYXIvY2FsZW5kYXIuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsaUJBQWlCLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDeEYsT0FBTyxFQUFDLFlBQVksRUFBQyxNQUFNLHFDQUFxQyxDQUFDO0FBWWpFLE1BQU0sT0FBTyxpQkFBaUI7SUFjNUI7UUFYTyxTQUFJLEdBQWlCLFlBQVksQ0FBQyxRQUFRLENBQUM7UUFHM0MsaUJBQVksR0FBUyxJQUFJLElBQUksRUFBRSxDQUFDO1FBR2hDLFNBQUksR0FBVyxFQUFFLENBQUM7UUFHbEIsdUJBQWtCLEdBQXVCLElBQUksWUFBWSxFQUFRLENBQUM7SUFHekUsQ0FBQztJQUVNLGtCQUFrQixDQUFDLElBQVU7UUFDbEMsSUFBSSxDQUFDLFlBQVksR0FBRyxJQUFJLENBQUM7UUFDekIsSUFBSSxDQUFDLGtCQUFrQixDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsWUFBWSxDQUFDLENBQUM7SUFDbEQsQ0FBQzs7O1lBOUJGLFNBQVMsU0FBQztnQkFDVCxRQUFRLEVBQUUsVUFBVTtnQkFDcEIsUUFBUSxFQUFFOzs7OztLQUtQO2dCQUNILGFBQWEsRUFBRSxpQkFBaUIsQ0FBQyxJQUFJO2FBQ3RDOzs7O21CQUdFLEtBQUs7MkJBR0wsS0FBSzttQkFHTCxLQUFLO2lDQUdMLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT3V0cHV0LCBWaWV3RW5jYXBzdWxhdGlvbn0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuaW1wb3J0IHtDYWxlbmRhclZpZXd9IGZyb20gXCIuLi8uLi8uLi8uLi9lbnVtL2NhbGVuZGFyLXZpZXcuZW51bVwiO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6IFwiY2FsZW5kYXJcIixcclxuICB0ZW1wbGF0ZTogYFxyXG4gICAgICAgIDxkaXYgY2xhc3M9XCJzYy1jYWxlbmRhclwiPlxyXG4gICAgICAgICAgPGNhbGVuZGFyLWhlYWRlciBbc2VsZWN0ZWREYXRlXT1cInNlbGVjdGVkRGF0ZVwiIChzZWxlY3RlZERhdGVDaGFuZ2UpPVwiY2hhbmdlU2VsZWN0ZWREYXRlKCRldmVudClcIj48L2NhbGVuZGFyLWhlYWRlcj5cclxuICAgICAgICAgIDxjYWxlbmRhci12aWV3IFt2aWV3XT1cInZpZXdcIiBbc2VsZWN0ZWREYXRlXT1cInNlbGVjdGVkRGF0ZVwiIChzZWxlY3RlZERhdGVDaGFuZ2UpPVwiY2hhbmdlU2VsZWN0ZWREYXRlKCRldmVudClcIj48L2NhbGVuZGFyLXZpZXc+XHJcbiAgICAgICAgPC9kaXY+XHJcbiAgICBgLFxyXG4gIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmVcclxufSlcclxuZXhwb3J0IGNsYXNzIENhbGVuZGFyQ29tcG9uZW50IHtcclxuXHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgdmlldzogQ2FsZW5kYXJWaWV3ID0gQ2FsZW5kYXJWaWV3LldlZWtWaWV3O1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBzZWxlY3RlZERhdGU6IERhdGUgPSBuZXcgRGF0ZSgpO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBkYXlzOiBEYXRlW10gPSBbXTtcclxuXHJcbiAgQE91dHB1dCgpXHJcbiAgcHVibGljIHNlbGVjdGVkRGF0ZUNoYW5nZTogRXZlbnRFbWl0dGVyPERhdGU+ID0gbmV3IEV2ZW50RW1pdHRlcjxEYXRlPigpO1xyXG5cclxuICBjb25zdHJ1Y3RvcigpIHtcclxuICB9XHJcblxyXG4gIHB1YmxpYyBjaGFuZ2VTZWxlY3RlZERhdGUoZGF0ZTogRGF0ZSk6IHZvaWQge1xyXG4gICAgdGhpcy5zZWxlY3RlZERhdGUgPSBkYXRlO1xyXG4gICAgdGhpcy5zZWxlY3RlZERhdGVDaGFuZ2UuZW1pdCh0aGlzLnNlbGVjdGVkRGF0ZSk7XHJcbiAgfVxyXG59XHJcbiJdfQ==
34
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FsZW5kYXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc2hhcmVkY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvZGF0ZS1wbGFubmluZy9jb21wb25lbnQvY2FsZW5kYXIvY2FsZW5kYXIuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsaUJBQWlCLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDeEYsT0FBTyxFQUFDLFlBQVksRUFBQyxNQUFNLHFDQUFxQyxDQUFDO0FBWWpFLE1BQU0sT0FBTyxpQkFBaUI7SUFjNUI7UUFYTyxTQUFJLEdBQWlCLFlBQVksQ0FBQyxhQUFhLENBQUM7UUFHaEQsaUJBQVksR0FBUyxJQUFJLElBQUksRUFBRSxDQUFDO1FBR2hDLFNBQUksR0FBVyxFQUFFLENBQUM7UUFHbEIsdUJBQWtCLEdBQXVCLElBQUksWUFBWSxFQUFRLENBQUM7SUFHekUsQ0FBQztJQUVNLGtCQUFrQixDQUFDLElBQVU7UUFDbEMsSUFBSSxDQUFDLFlBQVksR0FBRyxJQUFJLENBQUM7UUFDekIsSUFBSSxDQUFDLGtCQUFrQixDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsWUFBWSxDQUFDLENBQUM7SUFDbEQsQ0FBQzs7O1lBOUJGLFNBQVMsU0FBQztnQkFDVCxRQUFRLEVBQUUsVUFBVTtnQkFDcEIsUUFBUSxFQUFFOzs7OztLQUtQO2dCQUNILGFBQWEsRUFBRSxpQkFBaUIsQ0FBQyxJQUFJO2FBQ3RDOzs7O21CQUdFLEtBQUs7MkJBR0wsS0FBSzttQkFHTCxLQUFLO2lDQUdMLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT3V0cHV0LCBWaWV3RW5jYXBzdWxhdGlvbn0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuaW1wb3J0IHtDYWxlbmRhclZpZXd9IGZyb20gXCIuLi8uLi8uLi8uLi9lbnVtL2NhbGVuZGFyLXZpZXcuZW51bVwiO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6IFwiY2FsZW5kYXJcIixcclxuICB0ZW1wbGF0ZTogYFxyXG4gICAgICAgIDxkaXYgY2xhc3M9XCJzYy1jYWxlbmRhclwiPlxyXG4gICAgICAgICAgPGNhbGVuZGFyLWhlYWRlciBbc2VsZWN0ZWREYXRlXT1cInNlbGVjdGVkRGF0ZVwiIChzZWxlY3RlZERhdGVDaGFuZ2UpPVwiY2hhbmdlU2VsZWN0ZWREYXRlKCRldmVudClcIj48L2NhbGVuZGFyLWhlYWRlcj5cclxuICAgICAgICAgIDxjYWxlbmRhci12aWV3IFt2aWV3XT1cInZpZXdcIiBbc2VsZWN0ZWREYXRlXT1cInNlbGVjdGVkRGF0ZVwiIChzZWxlY3RlZERhdGVDaGFuZ2UpPVwiY2hhbmdlU2VsZWN0ZWREYXRlKCRldmVudClcIj48L2NhbGVuZGFyLXZpZXc+XHJcbiAgICAgICAgPC9kaXY+XHJcbiAgICBgLFxyXG4gIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmVcclxufSlcclxuZXhwb3J0IGNsYXNzIENhbGVuZGFyQ29tcG9uZW50IHtcclxuXHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgdmlldzogQ2FsZW5kYXJWaWV3ID0gQ2FsZW5kYXJWaWV3LlRocmVlRGF5c1ZpZXc7XHJcblxyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIHNlbGVjdGVkRGF0ZTogRGF0ZSA9IG5ldyBEYXRlKCk7XHJcblxyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIGRheXM6IERhdGVbXSA9IFtdO1xyXG5cclxuICBAT3V0cHV0KClcclxuICBwdWJsaWMgc2VsZWN0ZWREYXRlQ2hhbmdlOiBFdmVudEVtaXR0ZXI8RGF0ZT4gPSBuZXcgRXZlbnRFbWl0dGVyPERhdGU+KCk7XHJcblxyXG4gIGNvbnN0cnVjdG9yKCkge1xyXG4gIH1cclxuXHJcbiAgcHVibGljIGNoYW5nZVNlbGVjdGVkRGF0ZShkYXRlOiBEYXRlKTogdm9pZCB7XHJcbiAgICB0aGlzLnNlbGVjdGVkRGF0ZSA9IGRhdGU7XHJcbiAgICB0aGlzLnNlbGVjdGVkRGF0ZUNoYW5nZS5lbWl0KHRoaXMuc2VsZWN0ZWREYXRlKTtcclxuICB9XHJcbn1cclxuIl19
@@ -10,8 +10,8 @@ export class DatePlanningComponent {
10
10
  this.showButton = false;
11
11
  this.buttonLabel = "";
12
12
  this.eventsPerDay = [];
13
- this.view = CalendarView.WeekView;
14
- this.viewSelection = false;
13
+ this.view = CalendarView.ThreeDaysView;
14
+ this.viewSelection = true;
15
15
  this.eventChecked = new EventEmitter();
16
16
  this.selectedDateChange = new EventEmitter();
17
17
  this.rangeChange = new EventEmitter();
@@ -113,4 +113,4 @@ DatePlanningComponent.propDecorators = {
113
113
  buttonClick: [{ type: Output }],
114
114
  showClass: [{ type: HostBinding, args: ["class.co-date-planning",] }]
115
115
  };
116
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-planning.component.js","sourceRoot":"","sources":["../../../../../../projects/sharedcomponents/src/lib/components/date-planning/date-planning.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectorRef,\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  HostBinding,\r\n  Input,\r\n  Output,\r\n  Renderer2,\r\n  ViewChild,\r\n  ViewEncapsulation\r\n} from '@angular/core';\r\nimport {animate, state, style, transition, trigger} from \"@angular/animations\";\r\nimport {CalendarView} from '../../enum/calendar-view.enum';\r\nimport {AgendaEventPerDay} from \"../../model/agenda-event-per-day.model\";\r\n\r\n@Component({\r\n  selector: \"co-date-planning\",\r\n  template: `\r\n    <div class=\"sc-agenda\">\r\n      <div class=\"content-wrapper\">\r\n        <calendar *ngIf=\"calendarNavigation\"\r\n                  [view]=\"view\"\r\n                  [(days)]=\"days\"\r\n                  [selectedDate]=\"selectedDate\" (selectedDateChange)=\"doChangeSelectedDate($event)\"></calendar>\r\n        <div class=\"agenda-content-wrapper mini-scrollbar\">\r\n          <div class=\"agenda-content\">\r\n            <agenda-header [view]=\"view\" (viewChange)=\"doChangeView($event)\"\r\n                           [firstAvailableDate]=\"firstAvailableDate\"\r\n                           [eventsPerDay]=\"eventsPerDay\"\r\n                           [selectedDate]=\"selectedDate\"\r\n                           (selectedDateChange)=\"doChangeSelectedDate($event)\"\r\n                           [viewSelection]=\"viewSelection\"\r\n                           (rangeChange)=\"doChangeSelectedDate($event, true)\"></agenda-header>\r\n            <agenda-view [view]=\"view\"\r\n                         [customEventObject]=\"customEventObject\"\r\n                         [selectedDate]=\"selectedDate\"\r\n                         [eventsPerDay]=\"eventsPerDay\"\r\n                         (eventChecked)=\"eventChecked.emit($event)\"></agenda-view>\r\n          </div>\r\n        </div>\r\n      </div>\r\n    </div>\r\n    <co-button *ngIf=\"showButton && eventsPerDay.length > 0\" class=\"text-only select-agenda-button\"\r\n               [label]=\"buttonLabel\"\r\n               (click)=\"buttonClick.emit($event)\">\r\n    </co-button>\r\n    `,\r\n  animations: [\r\n    trigger(\"showHideWindow\", [\r\n      state(\"void\", style({transform: \"scaleY(0)\"})),\r\n      state(\"*\", style({transform: \"scaleY(1)\"})),\r\n      transition(\":enter, :leave\", [\r\n        animate(\"200ms ease-in-out\")\r\n      ])\r\n    ])\r\n  ],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\n\r\nexport class DatePlanningComponent {\r\n  @ViewChild(\"dayStart\", { static: true })\r\n  public dayStart: ElementRef;\r\n\r\n  @Input()\r\n  public calendarNavigation: boolean = false;\r\n\r\n  @Input()\r\n  public customEventObject: boolean = false;\r\n\r\n  @Input()\r\n  public showButton: boolean = false;\r\n\r\n  @Input()\r\n  public selectedDate: Date;\r\n\r\n  @Input()\r\n  public firstAvailableDate: Date;\r\n\r\n  @Input()\r\n  public buttonLabel: string = \"\";\r\n\r\n  @Input()\r\n  public eventsPerDay: AgendaEventPerDay[] = [];\r\n\r\n  @Input()\r\n  public view: CalendarView = CalendarView.WeekView;\r\n\r\n  @Input()\r\n  public viewSelection: boolean = false;\r\n\r\n  @Output()\r\n  public readonly eventChecked: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n  @Output()\r\n  public readonly selectedDateChange: EventEmitter<Date> = new EventEmitter<Date>();\r\n\r\n  @Output()\r\n  public readonly rangeChange: EventEmitter<Date> = new EventEmitter<Date>();\r\n\r\n  @Output()\r\n  public readonly viewChange: EventEmitter<CalendarView> = new EventEmitter<CalendarView>();\r\n\r\n  @Output()\r\n  public readonly buttonClick: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\r\n\r\n  @HostBinding(\"class.co-date-planning\")\r\n  public showClass: boolean = true;\r\n\r\n  public days: Date[] = [];\r\n  private _selectedDate: Date = new Date();\r\n\r\n  constructor(\r\n    private _changeDetector: ChangeDetectorRef,\r\n    private renderer: Renderer2\r\n  ) {\r\n  }\r\n\r\n  public doChangeSelectedDate(date: Date, rangeChanged: boolean = false): void {\r\n    this.selectedDate = new Date(date);\r\n    if (rangeChanged) {\r\n      this.rangeChange.next(this.selectedDate);\r\n    } else {\r\n      this.selectedDateChange.next(this.selectedDate);\r\n    }\r\n    this._changeDetector.detectChanges();\r\n  }\r\n\r\n  public doChangeView(view: CalendarView): void {\r\n    this.view = view;\r\n    this.viewChange.next(this.view);\r\n  }\r\n\r\n  public scrollToDayStart(): void {\r\n    if (this.dayStart !== undefined) {\r\n      const dayStart: any = this.renderer.selectRootElement(\"#dayStart\");\r\n      if (dayStart) {\r\n        setTimeout(() => {\r\n          dayStart.scrollIntoView({behavior: \"instant\", block: \"center\"});\r\n        });\r\n      }\r\n    }\r\n  }\r\n\r\n}\r\n"]}
116
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-planning.component.js","sourceRoot":"","sources":["../../../../../../projects/sharedcomponents/src/lib/components/date-planning/date-planning.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectorRef,\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  HostBinding,\r\n  Input,\r\n  Output,\r\n  Renderer2,\r\n  ViewChild,\r\n  ViewEncapsulation\r\n} from '@angular/core';\r\nimport {animate, state, style, transition, trigger} from \"@angular/animations\";\r\nimport {CalendarView} from '../../enum/calendar-view.enum';\r\nimport {AgendaEventPerDay} from \"../../model/agenda-event-per-day.model\";\r\n\r\n@Component({\r\n  selector: \"co-date-planning\",\r\n  template: `\r\n    <div class=\"sc-agenda\">\r\n      <div class=\"content-wrapper\">\r\n        <calendar *ngIf=\"calendarNavigation\"\r\n                  [view]=\"view\"\r\n                  [(days)]=\"days\"\r\n                  [selectedDate]=\"selectedDate\" (selectedDateChange)=\"doChangeSelectedDate($event)\"></calendar>\r\n        <div class=\"agenda-content-wrapper mini-scrollbar\">\r\n          <div class=\"agenda-content\">\r\n            <agenda-header [view]=\"view\" (viewChange)=\"doChangeView($event)\"\r\n                           [firstAvailableDate]=\"firstAvailableDate\"\r\n                           [eventsPerDay]=\"eventsPerDay\"\r\n                           [selectedDate]=\"selectedDate\"\r\n                           (selectedDateChange)=\"doChangeSelectedDate($event)\"\r\n                           [viewSelection]=\"viewSelection\"\r\n                           (rangeChange)=\"doChangeSelectedDate($event, true)\"></agenda-header>\r\n            <agenda-view [view]=\"view\"\r\n                         [customEventObject]=\"customEventObject\"\r\n                         [selectedDate]=\"selectedDate\"\r\n                         [eventsPerDay]=\"eventsPerDay\"\r\n                         (eventChecked)=\"eventChecked.emit($event)\"></agenda-view>\r\n          </div>\r\n        </div>\r\n      </div>\r\n    </div>\r\n    <co-button *ngIf=\"showButton && eventsPerDay.length > 0\" class=\"text-only select-agenda-button\"\r\n               [label]=\"buttonLabel\"\r\n               (click)=\"buttonClick.emit($event)\">\r\n    </co-button>\r\n    `,\r\n  animations: [\r\n    trigger(\"showHideWindow\", [\r\n      state(\"void\", style({transform: \"scaleY(0)\"})),\r\n      state(\"*\", style({transform: \"scaleY(1)\"})),\r\n      transition(\":enter, :leave\", [\r\n        animate(\"200ms ease-in-out\")\r\n      ])\r\n    ])\r\n  ],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\n\r\nexport class DatePlanningComponent {\r\n  @ViewChild(\"dayStart\", { static: true })\r\n  public dayStart: ElementRef;\r\n\r\n  @Input()\r\n  public calendarNavigation: boolean = false;\r\n\r\n  @Input()\r\n  public customEventObject: boolean = false;\r\n\r\n  @Input()\r\n  public showButton: boolean = false;\r\n\r\n  @Input()\r\n  public selectedDate: Date;\r\n\r\n  @Input()\r\n  public firstAvailableDate: Date;\r\n\r\n  @Input()\r\n  public buttonLabel: string = \"\";\r\n\r\n  @Input()\r\n  public eventsPerDay: AgendaEventPerDay[] = [];\r\n\r\n  @Input()\r\n  public view: CalendarView = CalendarView.ThreeDaysView;\r\n\r\n  @Input()\r\n  public viewSelection: boolean = true;\r\n\r\n  @Output()\r\n  public readonly eventChecked: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n  @Output()\r\n  public readonly selectedDateChange: EventEmitter<Date> = new EventEmitter<Date>();\r\n\r\n  @Output()\r\n  public readonly rangeChange: EventEmitter<Date> = new EventEmitter<Date>();\r\n\r\n  @Output()\r\n  public readonly viewChange: EventEmitter<CalendarView> = new EventEmitter<CalendarView>();\r\n\r\n  @Output()\r\n  public readonly buttonClick: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\r\n\r\n  @HostBinding(\"class.co-date-planning\")\r\n  public showClass: boolean = true;\r\n\r\n  public days: Date[] = [];\r\n  private _selectedDate: Date = new Date();\r\n\r\n  constructor(\r\n    private _changeDetector: ChangeDetectorRef,\r\n    private renderer: Renderer2\r\n  ) {\r\n  }\r\n\r\n  public doChangeSelectedDate(date: Date, rangeChanged: boolean = false): void {\r\n    this.selectedDate = new Date(date);\r\n    if (rangeChanged) {\r\n      this.rangeChange.next(this.selectedDate);\r\n    } else {\r\n      this.selectedDateChange.next(this.selectedDate);\r\n    }\r\n    this._changeDetector.detectChanges();\r\n  }\r\n\r\n  public doChangeView(view: CalendarView): void {\r\n    this.view = view;\r\n    this.viewChange.next(this.view);\r\n  }\r\n\r\n  public scrollToDayStart(): void {\r\n    if (this.dayStart !== undefined) {\r\n      const dayStart: any = this.renderer.selectRootElement(\"#dayStart\");\r\n      if (dayStart) {\r\n        setTimeout(() => {\r\n          dayStart.scrollIntoView({behavior: \"instant\", block: \"center\"});\r\n        });\r\n      }\r\n    }\r\n  }\r\n\r\n}\r\n"]}