@colijnit/corecomponents_v12 12.2.9 → 12.2.11

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 (29) hide show
  1. package/bundles/colijnit-corecomponents_v12.umd.js +61 -12
  2. package/bundles/colijnit-corecomponents_v12.umd.js.map +1 -1
  3. package/colijnit-corecomponents_v12.metadata.json +1 -1
  4. package/esm2015/lib/components/base/base-input.component.js +3 -3
  5. package/esm2015/lib/components/calendar/calendar-template.component.js +51 -17
  6. package/esm2015/lib/components/co-dialog/co-dialog.component.js +15 -13
  7. package/esm2015/lib/components/co-dialog/co-dialog.module.js +4 -2
  8. package/esm2015/lib/components/filter-item/filter-item.component.js +40 -1
  9. package/esm2015/lib/components/form/form.component.js +2 -2
  10. package/esm2015/lib/components/simple-grid/simple-grid.component.js +3 -3
  11. package/esm2015/lib/core/enum/filterItem-mode.enum.js +4 -1
  12. package/fesm2015/colijnit-corecomponents_v12.js +114 -35
  13. package/fesm2015/colijnit-corecomponents_v12.js.map +1 -1
  14. package/lib/components/button/style/_layout.scss +29 -7
  15. package/lib/components/button/style/_material-definition.scss +12 -0
  16. package/lib/components/calendar/calendar-template.component.d.ts +4 -0
  17. package/lib/components/calendar/style/_layout.scss +32 -3
  18. package/lib/components/calendar/style/_material-definition.scss +24 -12
  19. package/lib/components/co-dialog/style/_layout.scss +17 -8
  20. package/lib/components/co-dialog/style/_material-definition.scss +7 -7
  21. package/lib/components/double-calendar/style/_layout.scss +4 -3
  22. package/lib/components/filter-item/filter-item.component.d.ts +2 -0
  23. package/lib/components/simple-grid/style/_layout.scss +7 -0
  24. package/lib/components/simple-grid/style/_material-definition.scss +2 -0
  25. package/lib/core/enum/filterItem-mode.enum.d.ts +1 -0
  26. package/lib/style/_input.mixins.scss +1 -0
  27. package/lib/style/_variables.scss +6 -1
  28. package/lib/style/corecomponents-globals.scss +61 -9
  29. package/package.json +1 -1
@@ -3,6 +3,8 @@ import { CoreComponentsIcon } from "../../core/enum/core-components-icon.enum";
3
3
  export class CalendarTemplateComponent {
4
4
  constructor() {
5
5
  this.icons = CoreComponentsIcon;
6
+ this.showWeekNumbers = true;
7
+ this.weekNumbers = [];
6
8
  this.locale = "nl-NL";
7
9
  this.highlightDaysBetweenDates = false;
8
10
  this.dateSelected = new EventEmitter();
@@ -75,6 +77,7 @@ export class CalendarTemplateComponent {
75
77
  }
76
78
  this.generateCalendar();
77
79
  this._fillDatesBetweenSelected();
80
+ this.calculateWeekNumbers();
78
81
  }
79
82
  nextMonth() {
80
83
  if (this.workingMonth === 11) {
@@ -86,6 +89,7 @@ export class CalendarTemplateComponent {
86
89
  }
87
90
  this.generateCalendar();
88
91
  this._fillDatesBetweenSelected();
92
+ this.calculateWeekNumbers();
89
93
  }
90
94
  prevYear() {
91
95
  this.workingYear--;
@@ -104,6 +108,7 @@ export class CalendarTemplateComponent {
104
108
  this.monthHeader = `${month} ${year}`;
105
109
  this.yearHeader = `${year}`;
106
110
  this.generateYearSelectionYears();
111
+ this.calculateWeekNumbers();
107
112
  }
108
113
  _setInitialValues() {
109
114
  this.workingDay = this.selectedDate ? this.selectedDate : new Date();
@@ -233,6 +238,28 @@ export class CalendarTemplateComponent {
233
238
  _capitalizeFirstLetter(value) {
234
239
  return value.charAt(0).toUpperCase() + value.slice(1);
235
240
  }
241
+ calculateWeekNumbers() {
242
+ this.weekNumbers = [];
243
+ let weekNumber = null;
244
+ for (let i = 0; i < this.daysInMonth.length; i++) {
245
+ const day = this.daysInMonth[i];
246
+ if (day) {
247
+ // Start of a new week or first day of the month, calculate and set weekNumber
248
+ weekNumber = this.getISOWeek(day);
249
+ // Check if the weekNumber is not already in the array
250
+ if (!this.weekNumbers.includes(weekNumber)) {
251
+ this.weekNumbers.push(weekNumber);
252
+ }
253
+ }
254
+ }
255
+ }
256
+ getISOWeek(date) {
257
+ const d = new Date(Date.UTC(date.getFullYear(), date.getMonth(), date.getDate()));
258
+ d.setUTCDate(d.getUTCDate() + 4 - (d.getUTCDay() || 7));
259
+ const yearStart = new Date(Date.UTC(d.getUTCFullYear(), 0, 1));
260
+ const weekNumber = Math.ceil(((d.valueOf() - yearStart.valueOf()) / 86400000 + 1) / 7);
261
+ return weekNumber;
262
+ }
236
263
  }
237
264
  CalendarTemplateComponent.decorators = [
238
265
  { type: Component, args: [{
@@ -271,23 +298,29 @@ CalendarTemplateComponent.decorators = [
271
298
  </ng-container>
272
299
  </div>
273
300
  </div>
274
-
275
- <div class="calendar-body" *ngIf="showCalendarBody">
276
- <div class="day-names">
277
- <div class="weekday" *ngFor="let dayName of dayNames" [textContent]="dayName"></div>
301
+ <div class="calendar-wrapper">
302
+ <div class="week-wrapper" *ngIf="showWeekNumbers && showCalendarBody">
303
+ <div class="week-number" [textContent]="'W'"></div>
304
+ <div class="week-number" *ngFor="let weekNumber of weekNumbers">
305
+ {{ weekNumber }}
306
+ </div>
278
307
  </div>
279
- <div *ngFor="let day of daysInMonth" class="calendar-day"
280
- [class.highlighted-day]="daysToHighlight.includes(day)"
281
- [class.selected-day]="selectedDate && (day && day.getTime() === selectedDate.getTime()) ||
282
- secondSelectedDate && (day && day.getTime() === secondSelectedDate.getTime()) ||
283
- temporarySelectedSecondaryDate && (day && day.getTime() === temporarySelectedSecondaryDate.getTime())"
284
-
285
- (click)="selectDate(day)"
286
- (mouseover)="handleMouseOverDay(day)">
287
- <ng-container *ngIf="day">
288
- <div class="day-number"
289
- [textContent]="day.getDate()"></div>
290
- </ng-container>
308
+ <div class="calendar-body" *ngIf="showCalendarBody">
309
+ <div class="day-names">
310
+ <div class="weekday" *ngFor="let dayName of dayNames" [textContent]="dayName"></div>
311
+ </div>
312
+ <div *ngFor="let day of daysInMonth" class="calendar-day"
313
+ [class.highlighted-day]="daysToHighlight.includes(day)"
314
+ [class.selected-day]="selectedDate && (day && day.getTime() === selectedDate.getTime()) ||
315
+ secondSelectedDate && (day && day.getTime() === secondSelectedDate.getTime()) ||
316
+ temporarySelectedSecondaryDate && (day && day.getTime() === temporarySelectedSecondaryDate.getTime())"
317
+ (click)="selectDate(day)"
318
+ (mouseover)="handleMouseOverDay(day)">
319
+ <!-- Day number -->
320
+ <ng-container *ngIf="day">
321
+ <div class="day-number" [textContent]="day.getDate()"></div>
322
+ </ng-container>
323
+ </div>
291
324
  </div>
292
325
  </div>
293
326
  </div>
@@ -296,6 +329,7 @@ CalendarTemplateComponent.decorators = [
296
329
  },] }
297
330
  ];
298
331
  CalendarTemplateComponent.propDecorators = {
332
+ showWeekNumbers: [{ type: Input }],
299
333
  locale: [{ type: Input }],
300
334
  highlightDaysBetweenDates: [{ type: Input }],
301
335
  selectedDate: [{ type: Input }],
@@ -305,4 +339,4 @@ CalendarTemplateComponent.propDecorators = {
305
339
  hoveringDate: [{ type: Output }],
306
340
  showClass: [{ type: HostBinding, args: ["class.calendar-template",] }]
307
341
  };
308
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar-template.component.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/components/calendar/calendar-template.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, ElementRef, EventEmitter, HostBinding, Input, Output, ViewEncapsulation} from \"@angular/core\";\r\nimport {CoreComponentsIcon} from \"../../core/enum/core-components-icon.enum\";\r\n\r\n@Component({\r\n  selector: \"calendar-template\",\r\n  template: `\r\n      <div class=\"calendar\">\r\n        <div class=\"calendar-header\" *ngIf=\"monthSelection || yearSelection\">\r\n          <co-icon class=\"calendar-change-month-button\" [icon]=\"icons.ArrowPointLeft\" (click)=\"prevMonth()\"></co-icon>\r\n\r\n          <div class=\"calendar-header-title-wrapper\">\r\n            <span class=\"calendar-header-title\" [textContent]=\"monthSelection ? monthHeader : yearHeader\"\r\n                  (click)=\"monthSelection ? openMonthSelection() : openYearSelection()\"\r\n            ></span>\r\n          </div>\r\n\r\n          <co-icon class=\"calendar-change-month-button\" [icon]=\"icons.ArrowPointRight\" (click)=\"nextMonth()\"></co-icon>\r\n        </div>\r\n\r\n        <div class=\"selection-grid month\" *ngIf=\"showMonthSelection\">\r\n          <div *ngFor=\"let month of monthSelectionNames\"\r\n               class=\"calendar-month-or-year\"\r\n               (click)=\"selectMonth(month)\">\r\n            <ng-container *ngIf=\"month\">\r\n              <div class=\"month\" [textContent]=\"month\"></div>\r\n            </ng-container>\r\n          </div>\r\n        </div>\r\n\r\n        <div class=\"selection-grid year\" *ngIf=\"showYearSelection\">\r\n          <div *ngFor=\"let year of yearSelectionYears\"\r\n               class=\"calendar-month-or-year\"\r\n               (click)=\"selectYear(year)\"\r\n               [textContent]=\"year\">\r\n            <ng-container *ngIf=\"year\">\r\n              <div class=\"year\" [textContent]=\"year\"></div>\r\n            </ng-container>\r\n          </div>\r\n        </div>\r\n\r\n        <div class=\"calendar-body\" *ngIf=\"showCalendarBody\">\r\n          <div class=\"day-names\">\r\n            <div class=\"weekday\" *ngFor=\"let dayName of dayNames\" [textContent]=\"dayName\"></div>\r\n          </div>\r\n          <div *ngFor=\"let day of daysInMonth\" class=\"calendar-day\"\r\n               [class.highlighted-day]=\"daysToHighlight.includes(day)\"\r\n               [class.selected-day]=\"selectedDate && (day && day.getTime() === selectedDate.getTime()) ||\r\n               secondSelectedDate && (day && day.getTime() === secondSelectedDate.getTime()) ||\r\n               temporarySelectedSecondaryDate && (day && day.getTime() === temporarySelectedSecondaryDate.getTime())\"\r\n\r\n               (click)=\"selectDate(day)\"\r\n               (mouseover)=\"handleMouseOverDay(day)\">\r\n            <ng-container *ngIf=\"day\">\r\n              <div class=\"day-number\"\r\n                   [textContent]=\"day.getDate()\"></div>\r\n            </ng-container>\r\n          </div>\r\n        </div>\r\n      </div>\r\n  `,\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class CalendarTemplateComponent {\r\n  public readonly icons: typeof CoreComponentsIcon = CoreComponentsIcon;\r\n\r\n  @Input()\r\n  public locale: string = \"nl-NL\";\r\n\r\n  @Input()\r\n  public highlightDaysBetweenDates: boolean = false;\r\n\r\n  @Input()\r\n  public set selectedDate(date: Date) {\r\n    this._selectedDate = !!date ? new Date(date.getFullYear(), date.getMonth(), date.getDate()) : date;\r\n    if (this.secondSelectedDate && date && this.secondSelectedDate.getTime() < this.selectedDate.getTime() && this.temporarySelectedSecondaryDate) {\r\n      this.daysToHighlight = [];\r\n    }\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 set secondSelectedDate(date: Date) {\r\n    this._secondSelectedDate = !!date ? new Date(date.getFullYear(), date.getMonth(), date.getDate()) : date;\r\n    if (!this.selectedDate) {\r\n      this.daysToHighlight = [];\r\n    } else {\r\n      this._fillDatesBetweenSelected();\r\n    }\r\n  }\r\n\r\n  public get secondSelectedDate(): Date {\r\n    return this._secondSelectedDate;\r\n  }\r\n\r\n  @Input()\r\n  public set secondHoveringDate(date : Date) {\r\n    this._secondHoveringDate = date;\r\n    if (!!date) {\r\n      this.temporarySelectedSecondaryDate = null;\r\n    }\r\n    if (this.selectedDate && !this.secondSelectedDate) {\r\n      this.temporarySelectedSecondaryDate = new Date(date);\r\n    }\r\n    this.handleMouseOverDay(date);\r\n  }\r\n\r\n  public get secondHoveringDate(): Date {\r\n    return this._secondHoveringDate;\r\n  }\r\n\r\n  @Output()\r\n  public dateSelected: EventEmitter<Date> = new EventEmitter<Date>();\r\n\r\n  @Output()\r\n  public hoveringDate: EventEmitter<Date> = new EventEmitter<Date>();\r\n\r\n  public showCalendarBody: boolean = true;\r\n  public showMonthSelection: boolean = false;\r\n  public showYearSelection: boolean = false;\r\n  public showSelectedMonth: string;\r\n\r\n  public workingDay: Date;\r\n  public workingYear: number;\r\n  public workingMonth: number;\r\n\r\n  public monthHeader: string = '';\r\n  public yearHeader: string = '';\r\n\r\n  public monthSelection: boolean = true;\r\n  public yearSelection: boolean = false;\r\n\r\n  public dayNames = [];\r\n  public monthNames = [];\r\n  public monthSelectionNames: string[] = [];\r\n  public yearSelectionYears: number[] = [];\r\n  public daysInMonth: Date[] = [];\r\n\r\n  public daysUnixTimestamps: number[] = [];\r\n  public daysToHighlight: Date[] = [];\r\n  public temporarySelectedSecondaryDate: Date;\r\n\r\n  private _secondHoveringDate: Date;\r\n  private _secondSelectedDate: Date;\r\n  private _selectedDate: Date;\r\n\r\n  @HostBinding(\"class.calendar-template\")\r\n  public showClass() {\r\n    return true;\r\n  }\r\n\r\n  public ngOnInit(): void {\r\n    this._setInitialValues();\r\n    this.generateMonthNames();\r\n    this.generateCalendar();\r\n    this._fillDatesBetweenSelected();\r\n  }\r\n\r\n  public prevMonth(): void {\r\n    if (this.workingMonth === 0) {\r\n      this.workingMonth = 11;\r\n      this.workingYear--;\r\n    } else {\r\n      this.workingMonth--;\r\n    }\r\n    this.generateCalendar();\r\n    this._fillDatesBetweenSelected();\r\n  }\r\n\r\n  public nextMonth(): void {\r\n    if (this.workingMonth === 11) {\r\n      this.workingMonth = 0;\r\n      this.workingYear++;\r\n    } else {\r\n      this.workingMonth++;\r\n    }\r\n    this.generateCalendar();\r\n    this._fillDatesBetweenSelected();\r\n  }\r\n\r\n  public prevYear(): void {\r\n    this.workingYear--;\r\n    this.generateCalendar();\r\n  }\r\n\r\n  public nextYear(): void {\r\n    this.workingYear++;\r\n    this.generateCalendar();\r\n  }\r\n\r\n  public generateCalendar(): void {\r\n    this._setMonthDaysForDate(this.workingMonth);\r\n\r\n    // Update the displayed month\r\n    const month = this.monthNames[this.workingMonth];\r\n    const year = this.workingYear;\r\n\r\n    // Update headerText\r\n    this.monthHeader = `${month} ${year}`;\r\n    this.yearHeader = `${year}`;\r\n\r\n    this.generateYearSelectionYears();\r\n  }\r\n\r\n  private _setInitialValues(): void {\r\n    this.workingDay = this.selectedDate ? this.selectedDate : new Date();\r\n    this.workingYear = this.workingDay.getFullYear();\r\n    this.workingMonth = this.workingDay.getMonth();\r\n  }\r\n\r\n  private _setMonthDaysForDate(monthNumber: number): void {\r\n    this.daysInMonth = [];\r\n\r\n    const firstDayOfMonth = new Date(this.workingYear, monthNumber, 0).getDay();\r\n    const lastDayOfMonth = new Date(this.workingYear, monthNumber + 1, 0).getDate();\r\n\r\n    // Add null values to the beginning of the array to align the first day with the correct day of the week\r\n    for (let i = 0; i < firstDayOfMonth; i++) {\r\n      this.daysInMonth.push(null);\r\n    }\r\n\r\n    // Add the days of the current month to the array\r\n    for (let i = 1; i <= lastDayOfMonth; i++) {\r\n      const date = new Date(this.workingYear, this.workingMonth, i);\r\n      this.daysInMonth.push(date);\r\n    }\r\n\r\n    // Add null values to the end of the array to fill out the grid\r\n    // const remainingCells = 42 - this.daysInMonth.length;\r\n    // for (let i = 0; i < remainingCells; i++) {\r\n    //   this.daysInMonth.push(null);\r\n    // }\r\n\r\n    this.daysUnixTimestamps = this.daysInMonth.map(day => { return day ? day.getTime() : undefined });\r\n  }\r\n\r\n  public generateYearSelectionYears(): void {\r\n    const pastYears = 5;\r\n    const futureYears = 3;\r\n    const years = [];\r\n\r\n    for (let i = pastYears; i >= 1; i--) {\r\n\r\n      years.push(this.workingYear - i);\r\n    }\r\n\r\n    years.push(this.workingYear);\r\n\r\n    for (let i = 1; i <= futureYears; i++) {\r\n      years.push(this.workingYear + i);\r\n    }\r\n\r\n    this.yearSelectionYears = years.reverse();\r\n  }\r\n\r\n  public openMonthSelection(): void {\r\n    this.showCalendarBody = false;\r\n    this.monthSelection = false;\r\n    this.yearSelection = true;\r\n    this.showMonthSelection = true;\r\n  }\r\n\r\n  public openYearSelection(): void {\r\n    this.showMonthSelection = false;\r\n    this.showYearSelection = true;\r\n  }\r\n\r\n  public selectDate(day: Date): void {\r\n    this.selectedDate = day;\r\n    this._fillDatesBetweenSelected();\r\n    this.dateSelected.emit(new Date(this.selectedDate));\r\n  }\r\n\r\n  public selectMonth(month: string): void {\r\n    this.showSelectedMonth = month;\r\n    this.workingMonth = this.monthSelectionNames.indexOf(month);\r\n    this.showMonthSelection = false;\r\n    this.yearSelection = false;\r\n    this.monthSelection = true;\r\n    this.showCalendarBody = true;\r\n    this.generateCalendar();\r\n  }\r\n\r\n  public selectYear(year: number): void {\r\n    this.workingYear = year;\r\n    this.showYearSelection = false;\r\n    this.showMonthSelection = true;\r\n    this.generateCalendar();\r\n  }\r\n\r\n  public generateMonthNames(): void {\r\n    for (let i = 0; i < 12; i++) {\r\n      const date = new Date(2000, i, 1);\r\n      const monthNameShort = date.toLocaleString(this.locale, {month: 'short'});\r\n      const monthNameFull = date.toLocaleString(this.locale, {month: 'long'});\r\n      this.monthSelectionNames.push(this._capitalizeFirstLetter(monthNameShort));\r\n      this.monthNames.push(this._capitalizeFirstLetter(monthNameFull));\r\n    }\r\n\r\n    for (let i = 1; i <= 7; i++) {\r\n      const date = new Date(2018, 0, i);\r\n      const weekdayName = date.toLocaleString(this.locale, { weekday: 'short' });\r\n      this.dayNames.push(this._capitalizeFirstLetter(weekdayName));\r\n    }\r\n  }\r\n\r\n  public handleMouseOverDay(day: Date): void {\r\n    if (this.highlightDaysBetweenDates && day && (this.selectedDate || this.secondSelectedDate) && !(this.selectedDate && this.secondSelectedDate) && !(this.selectedDate && !this.temporarySelectedSecondaryDate && !this.secondSelectedDate)) {\r\n      this.daysToHighlight = [];\r\n      if (this.daysUnixTimestamps.includes(day.getTime())) {\r\n        this.daysToHighlight.push(...this.daysInMonth.map((dayInMonth: Date) => {\r\n          if (this.selectedDate) {\r\n            if (dayInMonth &&\r\n              // day in the month is after selected date and day in the month is before the hovering day\r\n              (dayInMonth.getTime() > this.selectedDate.getTime() && dayInMonth.getTime() < day.getTime()) ||\r\n              // second date is after selected date and day in the month is before hovering day and day in month is after selected date\r\n              (this._secondHoveringDate && this._secondHoveringDate.getTime() > this.selectedDate.getTime() && day && dayInMonth && dayInMonth.getTime() < day.getTime() && dayInMonth.getTime() > this.selectedDate.getTime())) {\r\n              return dayInMonth;\r\n            }\r\n          } else {\r\n            if (dayInMonth &&\r\n              // day in the month is after second date and day in the month is before the hovering day\r\n              (dayInMonth.getTime() > this.secondSelectedDate.getTime() && dayInMonth.getTime() < day.getTime())) {\r\n              return dayInMonth;\r\n            }\r\n          }\r\n        }));\r\n      } else {\r\n        this.daysToHighlight.push(...this.daysInMonth.map((day) => {\r\n          if (day > this.selectedDate) {\r\n            return day;\r\n          }\r\n        }));\r\n      }\r\n    }\r\n    this.hoveringDate.next(day);\r\n  }\r\n\r\n  private _fillDatesBetweenSelected(): void {\r\n    if (this.selectedDate && this.secondSelectedDate) {\r\n      this.daysToHighlight = [];\r\n      this.daysToHighlight.push(...this.daysInMonth.map((dayInMonth: Date) => {\r\n        if (dayInMonth && (dayInMonth > this.selectedDate && dayInMonth < this.secondSelectedDate) || (dayInMonth > this.secondSelectedDate && dayInMonth < this.selectedDate)) {\r\n          return dayInMonth;\r\n        }\r\n      }));\r\n    }\r\n  }\r\n\r\n  private _capitalizeFirstLetter(value: string): string {\r\n    return value.charAt(0).toUpperCase() + value.slice(1);\r\n  }\r\n}\r\n"]}
342
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar-template.component.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/components/calendar/calendar-template.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, ElementRef, EventEmitter, HostBinding, Input, Output, ViewEncapsulation} from \"@angular/core\";\r\nimport {CoreComponentsIcon} from \"../../core/enum/core-components-icon.enum\";\r\n\r\n@Component({\r\n  selector: \"calendar-template\",\r\n  template: `\r\n      <div class=\"calendar\">\r\n        <div class=\"calendar-header\" *ngIf=\"monthSelection || yearSelection\">\r\n          <co-icon class=\"calendar-change-month-button\" [icon]=\"icons.ArrowPointLeft\" (click)=\"prevMonth()\"></co-icon>\r\n\r\n          <div class=\"calendar-header-title-wrapper\">\r\n            <span class=\"calendar-header-title\" [textContent]=\"monthSelection ? monthHeader : yearHeader\"\r\n                  (click)=\"monthSelection ? openMonthSelection() : openYearSelection()\"\r\n            ></span>\r\n          </div>\r\n\r\n          <co-icon class=\"calendar-change-month-button\" [icon]=\"icons.ArrowPointRight\" (click)=\"nextMonth()\"></co-icon>\r\n        </div>\r\n\r\n        <div class=\"selection-grid month\" *ngIf=\"showMonthSelection\">\r\n          <div *ngFor=\"let month of monthSelectionNames\"\r\n               class=\"calendar-month-or-year\"\r\n               (click)=\"selectMonth(month)\">\r\n            <ng-container *ngIf=\"month\">\r\n              <div class=\"month\" [textContent]=\"month\"></div>\r\n            </ng-container>\r\n          </div>\r\n        </div>\r\n\r\n        <div class=\"selection-grid year\" *ngIf=\"showYearSelection\">\r\n          <div *ngFor=\"let year of yearSelectionYears\"\r\n               class=\"calendar-month-or-year\"\r\n               (click)=\"selectYear(year)\"\r\n               [textContent]=\"year\">\r\n            <ng-container *ngIf=\"year\">\r\n              <div class=\"year\" [textContent]=\"year\"></div>\r\n            </ng-container>\r\n          </div>\r\n        </div>\r\n        <div class=\"calendar-wrapper\">\r\n          <div class=\"week-wrapper\" *ngIf=\"showWeekNumbers && showCalendarBody\">\r\n            <div class=\"week-number\" [textContent]=\"'W'\"></div>\r\n            <div class=\"week-number\" *ngFor=\"let weekNumber of weekNumbers\">\r\n              {{ weekNumber }}\r\n            </div>\r\n          </div>\r\n          <div class=\"calendar-body\" *ngIf=\"showCalendarBody\">\r\n            <div class=\"day-names\">\r\n              <div class=\"weekday\" *ngFor=\"let dayName of dayNames\" [textContent]=\"dayName\"></div>\r\n            </div>\r\n            <div *ngFor=\"let day of daysInMonth\" class=\"calendar-day\"\r\n                 [class.highlighted-day]=\"daysToHighlight.includes(day)\"\r\n                 [class.selected-day]=\"selectedDate && (day && day.getTime() === selectedDate.getTime()) ||\r\n            secondSelectedDate && (day && day.getTime() === secondSelectedDate.getTime()) ||\r\n            temporarySelectedSecondaryDate && (day && day.getTime() === temporarySelectedSecondaryDate.getTime())\"\r\n                 (click)=\"selectDate(day)\"\r\n                 (mouseover)=\"handleMouseOverDay(day)\">\r\n              <!-- Day number -->\r\n              <ng-container *ngIf=\"day\">\r\n                <div class=\"day-number\" [textContent]=\"day.getDate()\"></div>\r\n              </ng-container>\r\n            </div>\r\n          </div>\r\n        </div>\r\n      </div>\r\n  `,\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class CalendarTemplateComponent {\r\n  public readonly icons: typeof CoreComponentsIcon = CoreComponentsIcon;\r\n\r\n  @Input()\r\n  public showWeekNumbers: boolean = true;\r\n\r\n  public weekNumbers: number[] = [];\r\n  @Input()\r\n  public locale: string = \"nl-NL\";\r\n\r\n  @Input()\r\n  public highlightDaysBetweenDates: boolean = false;\r\n\r\n  @Input()\r\n  public set selectedDate(date: Date) {\r\n    this._selectedDate = !!date ? new Date(date.getFullYear(), date.getMonth(), date.getDate()) : date;\r\n    if (this.secondSelectedDate && date && this.secondSelectedDate.getTime() < this.selectedDate.getTime() && this.temporarySelectedSecondaryDate) {\r\n      this.daysToHighlight = [];\r\n    }\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 set secondSelectedDate(date: Date) {\r\n    this._secondSelectedDate = !!date ? new Date(date.getFullYear(), date.getMonth(), date.getDate()) : date;\r\n    if (!this.selectedDate) {\r\n      this.daysToHighlight = [];\r\n    } else {\r\n      this._fillDatesBetweenSelected();\r\n    }\r\n  }\r\n\r\n  public get secondSelectedDate(): Date {\r\n    return this._secondSelectedDate;\r\n  }\r\n\r\n  @Input()\r\n  public set secondHoveringDate(date : Date) {\r\n    this._secondHoveringDate = date;\r\n    if (!!date) {\r\n      this.temporarySelectedSecondaryDate = null;\r\n    }\r\n    if (this.selectedDate && !this.secondSelectedDate) {\r\n      this.temporarySelectedSecondaryDate = new Date(date);\r\n    }\r\n    this.handleMouseOverDay(date);\r\n  }\r\n\r\n  public get secondHoveringDate(): Date {\r\n    return this._secondHoveringDate;\r\n  }\r\n\r\n  @Output()\r\n  public dateSelected: EventEmitter<Date> = new EventEmitter<Date>();\r\n\r\n  @Output()\r\n  public hoveringDate: EventEmitter<Date> = new EventEmitter<Date>();\r\n\r\n  public showCalendarBody: boolean = true;\r\n  public showMonthSelection: boolean = false;\r\n  public showYearSelection: boolean = false;\r\n  public showSelectedMonth: string;\r\n\r\n  public workingDay: Date;\r\n  public workingYear: number;\r\n  public workingMonth: number;\r\n\r\n  public monthHeader: string = '';\r\n  public yearHeader: string = '';\r\n\r\n  public monthSelection: boolean = true;\r\n  public yearSelection: boolean = false;\r\n\r\n  public dayNames = [];\r\n  public monthNames = [];\r\n  public monthSelectionNames: string[] = [];\r\n  public yearSelectionYears: number[] = [];\r\n  public daysInMonth: Date[] = [];\r\n\r\n  public daysUnixTimestamps: number[] = [];\r\n  public daysToHighlight: Date[] = [];\r\n  public temporarySelectedSecondaryDate: Date;\r\n\r\n  private _secondHoveringDate: Date;\r\n  private _secondSelectedDate: Date;\r\n  private _selectedDate: Date;\r\n\r\n  @HostBinding(\"class.calendar-template\")\r\n  public showClass() {\r\n    return true;\r\n  }\r\n\r\n  public ngOnInit(): void {\r\n    this._setInitialValues();\r\n    this.generateMonthNames();\r\n    this.generateCalendar();\r\n    this._fillDatesBetweenSelected();\r\n  }\r\n\r\n  public prevMonth(): void {\r\n    if (this.workingMonth === 0) {\r\n      this.workingMonth = 11;\r\n      this.workingYear--;\r\n    } else {\r\n      this.workingMonth--;\r\n    }\r\n    this.generateCalendar();\r\n    this._fillDatesBetweenSelected();\r\n    this.calculateWeekNumbers();\r\n  }\r\n\r\n  public nextMonth(): void {\r\n    if (this.workingMonth === 11) {\r\n      this.workingMonth = 0;\r\n      this.workingYear++;\r\n    } else {\r\n      this.workingMonth++;\r\n    }\r\n    this.generateCalendar();\r\n    this._fillDatesBetweenSelected();\r\n    this.calculateWeekNumbers();\r\n  }\r\n\r\n  public prevYear(): void {\r\n    this.workingYear--;\r\n    this.generateCalendar();\r\n  }\r\n\r\n  public nextYear(): void {\r\n    this.workingYear++;\r\n    this.generateCalendar();\r\n  }\r\n\r\n  public generateCalendar(): void {\r\n    this._setMonthDaysForDate(this.workingMonth);\r\n\r\n    // Update the displayed month\r\n    const month = this.monthNames[this.workingMonth];\r\n    const year = this.workingYear;\r\n\r\n    // Update headerText\r\n    this.monthHeader = `${month} ${year}`;\r\n    this.yearHeader = `${year}`;\r\n\r\n    this.generateYearSelectionYears();\r\n    this.calculateWeekNumbers();\r\n  }\r\n\r\n  private _setInitialValues(): void {\r\n    this.workingDay = this.selectedDate ? this.selectedDate : new Date();\r\n    this.workingYear = this.workingDay.getFullYear();\r\n    this.workingMonth = this.workingDay.getMonth();\r\n  }\r\n\r\n  private _setMonthDaysForDate(monthNumber: number): void {\r\n    this.daysInMonth = [];\r\n\r\n    const firstDayOfMonth = new Date(this.workingYear, monthNumber, 0).getDay();\r\n    const lastDayOfMonth = new Date(this.workingYear, monthNumber + 1, 0).getDate();\r\n\r\n    // Add null values to the beginning of the array to align the first day with the correct day of the week\r\n    for (let i = 0; i < firstDayOfMonth; i++) {\r\n      this.daysInMonth.push(null);\r\n    }\r\n\r\n    // Add the days of the current month to the array\r\n    for (let i = 1; i <= lastDayOfMonth; i++) {\r\n      const date = new Date(this.workingYear, this.workingMonth, i);\r\n      this.daysInMonth.push(date);\r\n    }\r\n\r\n    // Add null values to the end of the array to fill out the grid\r\n    // const remainingCells = 42 - this.daysInMonth.length;\r\n    // for (let i = 0; i < remainingCells; i++) {\r\n    //   this.daysInMonth.push(null);\r\n    // }\r\n\r\n    this.daysUnixTimestamps = this.daysInMonth.map(day => { return day ? day.getTime() : undefined });\r\n  }\r\n\r\n  public generateYearSelectionYears(): void {\r\n    const pastYears = 5;\r\n    const futureYears = 3;\r\n    const years = [];\r\n\r\n    for (let i = pastYears; i >= 1; i--) {\r\n\r\n      years.push(this.workingYear - i);\r\n    }\r\n\r\n    years.push(this.workingYear);\r\n\r\n    for (let i = 1; i <= futureYears; i++) {\r\n      years.push(this.workingYear + i);\r\n    }\r\n\r\n    this.yearSelectionYears = years.reverse();\r\n  }\r\n\r\n  public openMonthSelection(): void {\r\n    this.showCalendarBody = false;\r\n    this.monthSelection = false;\r\n    this.yearSelection = true;\r\n    this.showMonthSelection = true;\r\n  }\r\n\r\n  public openYearSelection(): void {\r\n    this.showMonthSelection = false;\r\n    this.showYearSelection = true;\r\n  }\r\n\r\n  public selectDate(day: Date): void {\r\n    this.selectedDate = day;\r\n    this._fillDatesBetweenSelected();\r\n    this.dateSelected.emit(new Date(this.selectedDate));\r\n  }\r\n\r\n  public selectMonth(month: string): void {\r\n    this.showSelectedMonth = month;\r\n    this.workingMonth = this.monthSelectionNames.indexOf(month);\r\n    this.showMonthSelection = false;\r\n    this.yearSelection = false;\r\n    this.monthSelection = true;\r\n    this.showCalendarBody = true;\r\n    this.generateCalendar();\r\n  }\r\n\r\n  public selectYear(year: number): void {\r\n    this.workingYear = year;\r\n    this.showYearSelection = false;\r\n    this.showMonthSelection = true;\r\n    this.generateCalendar();\r\n  }\r\n\r\n  public generateMonthNames(): void {\r\n    for (let i = 0; i < 12; i++) {\r\n      const date = new Date(2000, i, 1);\r\n      const monthNameShort = date.toLocaleString(this.locale, {month: 'short'});\r\n      const monthNameFull = date.toLocaleString(this.locale, {month: 'long'});\r\n      this.monthSelectionNames.push(this._capitalizeFirstLetter(monthNameShort));\r\n      this.monthNames.push(this._capitalizeFirstLetter(monthNameFull));\r\n    }\r\n\r\n    for (let i = 1; i <= 7; i++) {\r\n      const date = new Date(2018, 0, i);\r\n      const weekdayName = date.toLocaleString(this.locale, { weekday: 'short' });\r\n      this.dayNames.push(this._capitalizeFirstLetter(weekdayName));\r\n    }\r\n  }\r\n\r\n  public handleMouseOverDay(day: Date): void {\r\n    if (this.highlightDaysBetweenDates && day && (this.selectedDate || this.secondSelectedDate) && !(this.selectedDate && this.secondSelectedDate) && !(this.selectedDate && !this.temporarySelectedSecondaryDate && !this.secondSelectedDate)) {\r\n      this.daysToHighlight = [];\r\n      if (this.daysUnixTimestamps.includes(day.getTime())) {\r\n        this.daysToHighlight.push(...this.daysInMonth.map((dayInMonth: Date) => {\r\n          if (this.selectedDate) {\r\n            if (dayInMonth &&\r\n              // day in the month is after selected date and day in the month is before the hovering day\r\n              (dayInMonth.getTime() > this.selectedDate.getTime() && dayInMonth.getTime() < day.getTime()) ||\r\n              // second date is after selected date and day in the month is before hovering day and day in month is after selected date\r\n              (this._secondHoveringDate && this._secondHoveringDate.getTime() > this.selectedDate.getTime() && day && dayInMonth && dayInMonth.getTime() < day.getTime() && dayInMonth.getTime() > this.selectedDate.getTime())) {\r\n              return dayInMonth;\r\n            }\r\n          } else {\r\n            if (dayInMonth &&\r\n              // day in the month is after second date and day in the month is before the hovering day\r\n              (dayInMonth.getTime() > this.secondSelectedDate.getTime() && dayInMonth.getTime() < day.getTime())) {\r\n              return dayInMonth;\r\n            }\r\n          }\r\n        }));\r\n      } else {\r\n        this.daysToHighlight.push(...this.daysInMonth.map((day) => {\r\n          if (day > this.selectedDate) {\r\n            return day;\r\n          }\r\n        }));\r\n      }\r\n    }\r\n    this.hoveringDate.next(day);\r\n  }\r\n\r\n  private _fillDatesBetweenSelected(): void {\r\n    if (this.selectedDate && this.secondSelectedDate) {\r\n      this.daysToHighlight = [];\r\n      this.daysToHighlight.push(...this.daysInMonth.map((dayInMonth: Date) => {\r\n        if (dayInMonth && (dayInMonth > this.selectedDate && dayInMonth < this.secondSelectedDate) || (dayInMonth > this.secondSelectedDate && dayInMonth < this.selectedDate)) {\r\n          return dayInMonth;\r\n        }\r\n      }));\r\n    }\r\n  }\r\n\r\n  private _capitalizeFirstLetter(value: string): string {\r\n    return value.charAt(0).toUpperCase() + value.slice(1);\r\n  }\r\n  private calculateWeekNumbers(): void {\r\n    this.weekNumbers = [];\r\n    let weekNumber: number | null = null;\r\n    for (let i = 0; i < this.daysInMonth.length; i++) {\r\n      const day = this.daysInMonth[i];\r\n      if (day) {\r\n          // Start of a new week or first day of the month, calculate and set weekNumber\r\n          weekNumber = this.getISOWeek(day);\r\n          // Check if the weekNumber is not already in the array\r\n          if (!this.weekNumbers.includes(weekNumber)) {\r\n            this.weekNumbers.push(weekNumber);\r\n          }\r\n      }\r\n    }\r\n  }\r\n\r\n\r\n  public getISOWeek(date: Date): number {\r\n      const d = new Date(Date.UTC(date.getFullYear(), date.getMonth(), date.getDate()));\r\n      d.setUTCDate(d.getUTCDate() + 4 - (d.getUTCDay() || 7));\r\n      const yearStart = new Date(Date.UTC(d.getUTCFullYear(), 0, 1));\r\n      const weekNumber = Math.ceil(((d.valueOf() - yearStart.valueOf()) / 86400000 + 1) / 7);\r\n      return weekNumber;\r\n  }\r\n}\r\n"]}
@@ -57,20 +57,22 @@ CoDialogComponent.decorators = [
57
57
  selector: 'co-dialog',
58
58
  template: `
59
59
  <div class="co-dialog-overlay" (click)="handleOverlayClick($event)"></div>
60
- <div class="co-dialog-wrapper" [ngClass]="customCssClass ? customCssClass : undefined" @showHideDialog>
61
- <div class="dialog-header" *ngIf="!borderless">
62
- <div class="dialog-header-caption" *ngIf="headerTemplate">
63
- <ng-container [ngTemplateOutlet]="headerTemplate"></ng-container>
60
+ <div class="co-dialog-placeholder">
61
+ <div class="co-dialog-wrapper" [ngClass]="customCssClass ? customCssClass : undefined" @showHideDialog cdkDrag>
62
+ <div class="dialog-header" *ngIf="!borderless" cdkDragHandle>
63
+ <div class="dialog-header-caption" *ngIf="headerTemplate">
64
+ <ng-container [ngTemplateOutlet]="headerTemplate"></ng-container>
65
+ </div>
66
+ <div class="dialog-close-button" *ngIf="showCloseIcon" (click)="handleCloseDialog($event)">
67
+ <co-icon [icon]="icons.CrossSkinny"></co-icon>
68
+ </div>
64
69
  </div>
65
- <div class="dialog-close-button" *ngIf="showCloseIcon" (click)="handleCloseDialog($event)">
66
- <co-icon [icon]="icons.CrossSkinny"></co-icon>
70
+ <div class="dialog-content co-small-scrollbar" [ngClass]="customCssClass ? customCssClass : undefined">
71
+ <ng-content></ng-content>
72
+ </div>
73
+ <div class="dialog-footer" *ngIf="footerTemplate">
74
+ <ng-container [ngTemplateOutlet]="footerTemplate"></ng-container>
67
75
  </div>
68
- </div>
69
- <div class="dialog-content co-small-scrollbar" [ngClass]="customCssClass ? customCssClass : undefined">
70
- <ng-content></ng-content>
71
- </div>
72
- <div class="dialog-footer" *ngIf="footerTemplate">
73
- <ng-container [ngTemplateOutlet]="footerTemplate"></ng-container>
74
76
  </div>
75
77
  </div>
76
78
  `,
@@ -107,4 +109,4 @@ CoDialogComponent.propDecorators = {
107
109
  mobile: [{ type: HostBinding, args: ['class.is-mobile',] }],
108
110
  ngOnInit: [{ type: HostBinding, args: ['@showHideCoDialog',] }]
109
111
  };
110
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"co-dialog.component.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/components/co-dialog/co-dialog.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, EventEmitter, HostBinding, HostListener, Input, OnInit, Output, TemplateRef, ViewEncapsulation} from '@angular/core';\nimport {CoreComponentsIcon} from '../../core/enum/core-components-icon.enum';\nimport {animate, animateChild, AnimationTriggerMetadata, query, state, style, transition, trigger} from '@angular/animations';\n\nexport const showHideDialog = [\n    window.innerWidth > 700 ?\n        trigger('showHideDialog', [\n            state('*', style({opacity: 1})),\n            state('void', style({opacity: 0})),\n            transition('void <=> *', animate(200))\n        ]) :\n        trigger('showHideDialog', [\n            state('*', style({bottom: 0})),\n            state('void', style({bottom: '-100%'})),\n            transition('void <=> *', animate(200))\n        ])\n]\n\n@Component({\n    selector: 'co-dialog',\n    template: `\n        <div class=\"co-dialog-overlay\" (click)=\"handleOverlayClick($event)\"></div>\n        <div class=\"co-dialog-wrapper\" [ngClass]=\"customCssClass ? customCssClass : undefined\" @showHideDialog>\n            <div class=\"dialog-header\" *ngIf=\"!borderless\">\n                <div class=\"dialog-header-caption\" *ngIf=\"headerTemplate\">\n                    <ng-container [ngTemplateOutlet]=\"headerTemplate\"></ng-container>\n                </div>\n                <div class=\"dialog-close-button\" *ngIf=\"showCloseIcon\" (click)=\"handleCloseDialog($event)\">\n                    <co-icon [icon]=\"icons.CrossSkinny\"></co-icon>\n                </div>\n            </div>\n            <div class=\"dialog-content co-small-scrollbar\" [ngClass]=\"customCssClass ? customCssClass : undefined\">\n                <ng-content></ng-content>\n            </div>\n            <div class=\"dialog-footer\" *ngIf=\"footerTemplate\">\n                <ng-container [ngTemplateOutlet]=\"footerTemplate\"></ng-container>\n            </div>\n        </div>\n    `,\n    animations: [\n        trigger('showHideCoDialog', [\n            transition('void => *', [\n                query('.co-dialog-overlay', style({opacity: 0})),\n                // query('.co-dialog-wrapper', style({bottom: '-100%'})),\n                query('.co-dialog-overlay', animate(200, style({opacity: 1}))),\n                query('@showHideDialog', animateChild())\n\n            ]),\n            transition('* => void', [\n                // query('.co-dialog-wrapper', style({bottom: 0})),\n                query('@showHideDialog', animateChild()),\n                query('.co-dialog-overlay', animate(200, style({opacity: 0})))\n            ]),\n        ]),\n        showHideDialog\n    ],\n    encapsulation: ViewEncapsulation.None\n})\nexport class CoDialogComponent implements OnInit {\n    public readonly icons: typeof CoreComponentsIcon = CoreComponentsIcon;\n\n    @Input()\n    public customCssClass: string;\n\n    @Input()\n    public headerTemplate: TemplateRef<any>;\n\n    @Input()\n    public footerTemplate: TemplateRef<any>;\n\n    @Input()\n    public showCloseIcon: boolean = true;\n\n    @Input()\n    public modal: boolean = false;\n\n    @HostBinding('class.borderless')\n    @Input()\n    public borderless: boolean = false;\n\n    @Output()\n    public readonly closeClick: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\n\n    @HostBinding('class.co-dialog')\n    public showClass(): boolean {\n        return true;\n    }\n\n    @HostListener('window:keydown', ['$event'])\n    public handleKeyDown(event: KeyboardEvent): void {\n        switch (event.code) {\n            case 'Escape':\n                this.handleCloseDialog();\n        }\n    }\n\n    @HostBinding('class.is-touch')\n    public isTouch: boolean = false;\n\n    @HostBinding('class.is-mobile')\n    public mobile: boolean = false;\n\n    public state: string = 'closed';\n\n    @HostBinding('@showHideCoDialog')\n\n    ngOnInit(): void {\n        this._checkDevice();\n    }\n\n    public handleCloseDialog(event?: MouseEvent): void {\n        this.closeClick.emit(event);\n    }\n\n    public handleOverlayClick(event: MouseEvent): void {\n        if (!this.modal) {\n            this.closeClick.emit(event);\n        }\n    }\n\n    private _checkDevice(): void {\n        this.isTouch = ('ontouchstart' in window) ||\n            (navigator.maxTouchPoints > 0) ||\n            (navigator.msMaxTouchPoints > 0);\n        this.mobile = window.innerWidth < 700;\n    }\n}\n"]}
112
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"co-dialog.component.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/components/co-dialog/co-dialog.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, EventEmitter, HostBinding, HostListener, Input, OnInit, Output, TemplateRef, ViewEncapsulation} from '@angular/core';\nimport {CoreComponentsIcon} from '../../core/enum/core-components-icon.enum';\nimport {animate, animateChild, AnimationTriggerMetadata, query, state, style, transition, trigger} from '@angular/animations';\n\nexport const showHideDialog = [\n    window.innerWidth > 700 ?\n        trigger('showHideDialog', [\n            state('*', style({opacity: 1})),\n            state('void', style({opacity: 0})),\n            transition('void <=> *', animate(200))\n        ]) :\n        trigger('showHideDialog', [\n            state('*', style({bottom: 0})),\n            state('void', style({bottom: '-100%'})),\n            transition('void <=> *', animate(200))\n        ])\n]\n\n@Component({\n    selector: 'co-dialog',\n    template: `\n        <div class=\"co-dialog-overlay\" (click)=\"handleOverlayClick($event)\"></div>\n        <div class=\"co-dialog-placeholder\">\n            <div class=\"co-dialog-wrapper\" [ngClass]=\"customCssClass ? customCssClass : undefined\" @showHideDialog cdkDrag>\n                <div class=\"dialog-header\" *ngIf=\"!borderless\" cdkDragHandle>\n                    <div class=\"dialog-header-caption\" *ngIf=\"headerTemplate\">\n                        <ng-container [ngTemplateOutlet]=\"headerTemplate\"></ng-container>\n                    </div>\n                    <div class=\"dialog-close-button\" *ngIf=\"showCloseIcon\" (click)=\"handleCloseDialog($event)\">\n                        <co-icon [icon]=\"icons.CrossSkinny\"></co-icon>\n                    </div>\n                </div>\n                <div class=\"dialog-content co-small-scrollbar\" [ngClass]=\"customCssClass ? customCssClass : undefined\">\n                    <ng-content></ng-content>\n                </div>\n                <div class=\"dialog-footer\" *ngIf=\"footerTemplate\">\n                    <ng-container [ngTemplateOutlet]=\"footerTemplate\"></ng-container>\n                </div>\n            </div>\n        </div>\n    `,\n    animations: [\n        trigger('showHideCoDialog', [\n            transition('void => *', [\n                query('.co-dialog-overlay', style({opacity: 0})),\n                // query('.co-dialog-wrapper', style({bottom: '-100%'})),\n                query('.co-dialog-overlay', animate(200, style({opacity: 1}))),\n                query('@showHideDialog', animateChild())\n\n            ]),\n            transition('* => void', [\n                // query('.co-dialog-wrapper', style({bottom: 0})),\n                query('@showHideDialog', animateChild()),\n                query('.co-dialog-overlay', animate(200, style({opacity: 0})))\n            ]),\n        ]),\n        showHideDialog\n    ],\n    encapsulation: ViewEncapsulation.None\n})\nexport class CoDialogComponent implements OnInit {\n    public readonly icons: typeof CoreComponentsIcon = CoreComponentsIcon;\n\n    @Input()\n    public customCssClass: string;\n\n    @Input()\n    public headerTemplate: TemplateRef<any>;\n\n    @Input()\n    public footerTemplate: TemplateRef<any>;\n\n    @Input()\n    public showCloseIcon: boolean = true;\n\n    @Input()\n    public modal: boolean = false;\n\n    @HostBinding('class.borderless')\n    @Input()\n    public borderless: boolean = false;\n\n    @Output()\n    public readonly closeClick: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\n\n    @HostBinding('class.co-dialog')\n    public showClass(): boolean {\n        return true;\n    }\n\n    @HostListener('window:keydown', ['$event'])\n    public handleKeyDown(event: KeyboardEvent): void {\n        switch (event.code) {\n            case 'Escape':\n                this.handleCloseDialog();\n        }\n    }\n\n    @HostBinding('class.is-touch')\n    public isTouch: boolean = false;\n\n    @HostBinding('class.is-mobile')\n    public mobile: boolean = false;\n\n    public state: string = 'closed';\n\n    @HostBinding('@showHideCoDialog')\n\n    ngOnInit(): void {\n        this._checkDevice();\n    }\n\n    public handleCloseDialog(event?: MouseEvent): void {\n        this.closeClick.emit(event);\n    }\n\n    public handleOverlayClick(event: MouseEvent): void {\n        if (!this.modal) {\n            this.closeClick.emit(event);\n        }\n    }\n\n    private _checkDevice(): void {\n        this.isTouch = ('ontouchstart' in window) ||\n            (navigator.maxTouchPoints > 0) ||\n            (navigator.msMaxTouchPoints > 0);\n        this.mobile = window.innerWidth < 700;\n    }\n}\n"]}
@@ -2,16 +2,18 @@ import { NgModule } from "@angular/core";
2
2
  import { CoDialogComponent } from "./co-dialog.component";
3
3
  import { IconModule } from "../icon/icon.module";
4
4
  import { CommonModule } from "@angular/common";
5
+ import { DragDropModule } from '@angular/cdk/drag-drop';
5
6
  export class CoDialogModule {
6
7
  }
7
8
  CoDialogModule.decorators = [
8
9
  { type: NgModule, args: [{
9
10
  imports: [
10
11
  CommonModule,
11
- IconModule
12
+ IconModule,
13
+ DragDropModule
12
14
  ],
13
15
  declarations: [CoDialogComponent],
14
16
  exports: [CoDialogComponent]
15
17
  },] }
16
18
  ];
17
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY28tZGlhbG9nLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmVjb21wb25lbnRzL3NyYy9saWIvY29tcG9uZW50cy9jby1kaWFsb2cvY28tZGlhbG9nLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsUUFBUSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ3ZDLE9BQU8sRUFBQyxpQkFBaUIsRUFBQyxNQUFNLHVCQUF1QixDQUFDO0FBQ3hELE9BQU8sRUFBQyxVQUFVLEVBQUMsTUFBTSxxQkFBcUIsQ0FBQztBQUMvQyxPQUFPLEVBQUMsWUFBWSxFQUFDLE1BQU0saUJBQWlCLENBQUM7QUFVN0MsTUFBTSxPQUFPLGNBQWM7OztZQVIxQixRQUFRLFNBQUM7Z0JBQ1IsT0FBTyxFQUFFO29CQUNQLFlBQVk7b0JBQ1osVUFBVTtpQkFDWDtnQkFDQyxZQUFZLEVBQUUsQ0FBQyxpQkFBaUIsQ0FBQztnQkFDakMsT0FBTyxFQUFFLENBQUMsaUJBQWlCLENBQUM7YUFDL0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge05nTW9kdWxlfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5pbXBvcnQge0NvRGlhbG9nQ29tcG9uZW50fSBmcm9tIFwiLi9jby1kaWFsb2cuY29tcG9uZW50XCI7XHJcbmltcG9ydCB7SWNvbk1vZHVsZX0gZnJvbSBcIi4uL2ljb24vaWNvbi5tb2R1bGVcIjtcclxuaW1wb3J0IHtDb21tb25Nb2R1bGV9IGZyb20gXCJAYW5ndWxhci9jb21tb25cIjtcclxuXHJcbkBOZ01vZHVsZSh7XHJcbiAgaW1wb3J0czogW1xyXG4gICAgQ29tbW9uTW9kdWxlLFxyXG4gICAgSWNvbk1vZHVsZVxyXG4gIF0sXHJcbiAgICBkZWNsYXJhdGlvbnM6IFtDb0RpYWxvZ0NvbXBvbmVudF0sXHJcbiAgICBleHBvcnRzOiBbQ29EaWFsb2dDb21wb25lbnRdXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBDb0RpYWxvZ01vZHVsZSB7XHJcbn1cclxuIl19
19
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY28tZGlhbG9nLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmVjb21wb25lbnRzL3NyYy9saWIvY29tcG9uZW50cy9jby1kaWFsb2cvY28tZGlhbG9nLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsUUFBUSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ3ZDLE9BQU8sRUFBQyxpQkFBaUIsRUFBQyxNQUFNLHVCQUF1QixDQUFDO0FBQ3hELE9BQU8sRUFBQyxVQUFVLEVBQUMsTUFBTSxxQkFBcUIsQ0FBQztBQUMvQyxPQUFPLEVBQUMsWUFBWSxFQUFDLE1BQU0saUJBQWlCLENBQUM7QUFDN0MsT0FBTyxFQUFDLGNBQWMsRUFBQyxNQUFNLHdCQUF3QixDQUFDO0FBV3RELE1BQU0sT0FBTyxjQUFjOzs7WUFUMUIsUUFBUSxTQUFDO2dCQUNOLE9BQU8sRUFBRTtvQkFDTCxZQUFZO29CQUNaLFVBQVU7b0JBQ1YsY0FBYztpQkFDakI7Z0JBQ0QsWUFBWSxFQUFFLENBQUMsaUJBQWlCLENBQUM7Z0JBQ2pDLE9BQU8sRUFBRSxDQUFDLGlCQUFpQixDQUFDO2FBQy9CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtOZ01vZHVsZX0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuaW1wb3J0IHtDb0RpYWxvZ0NvbXBvbmVudH0gZnJvbSBcIi4vY28tZGlhbG9nLmNvbXBvbmVudFwiO1xyXG5pbXBvcnQge0ljb25Nb2R1bGV9IGZyb20gXCIuLi9pY29uL2ljb24ubW9kdWxlXCI7XHJcbmltcG9ydCB7Q29tbW9uTW9kdWxlfSBmcm9tIFwiQGFuZ3VsYXIvY29tbW9uXCI7XHJcbmltcG9ydCB7RHJhZ0Ryb3BNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2Nkay9kcmFnLWRyb3AnO1xyXG5cclxuQE5nTW9kdWxlKHtcclxuICAgIGltcG9ydHM6IFtcclxuICAgICAgICBDb21tb25Nb2R1bGUsXHJcbiAgICAgICAgSWNvbk1vZHVsZSxcclxuICAgICAgICBEcmFnRHJvcE1vZHVsZVxyXG4gICAgXSxcclxuICAgIGRlY2xhcmF0aW9uczogW0NvRGlhbG9nQ29tcG9uZW50XSxcclxuICAgIGV4cG9ydHM6IFtDb0RpYWxvZ0NvbXBvbmVudF1cclxufSlcclxuZXhwb3J0IGNsYXNzIENvRGlhbG9nTW9kdWxlIHtcclxufVxyXG4iXX0=