asksuite-citrus 0.2.0 → 0.2.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -2,9 +2,19 @@ import { Component, EventEmitter, Input, Output } from '@angular/core';
2
2
  import moment from 'moment';
3
3
  import * as i0 from "@angular/core";
4
4
  import * as i1 from "@angular/common";
5
- export const asDate = (inMoment) => {
6
- return inMoment.utc(true).toDate();
7
- };
5
+ export var PeriodLabel;
6
+ (function (PeriodLabel) {
7
+ PeriodLabel["TODAY"] = "TODAY";
8
+ PeriodLabel["YESTERDAY"] = "YESTERDAY";
9
+ PeriodLabel["LAST_7_DAYS"] = "LAST_7_DAYS";
10
+ PeriodLabel["LAST_30_DAYS"] = "LAST_30_DAYS";
11
+ PeriodLabel["THIS_MONTH"] = "THIS_MONTH";
12
+ PeriodLabel["LAST_QUARTER"] = "LAST_QUARTER";
13
+ PeriodLabel["CUSTOM_PERIOD"] = "CUSTOM_PERIOD";
14
+ })(PeriodLabel || (PeriodLabel = {}));
15
+ export const DEFAULT_DATE_FORMAT = 'YYYY-MM-DDTHH:mm:ssZ';
16
+ export const formatFrom = (from) => from.startOf('day').format(DEFAULT_DATE_FORMAT);
17
+ export const formatTo = (from) => from.endOf('day').format(DEFAULT_DATE_FORMAT);
8
18
  export class DatePickerCalendarComponent {
9
19
  constructor() {
10
20
  this.isRange = false;
@@ -43,15 +53,15 @@ export class DatePickerCalendarComponent {
43
53
  }
44
54
  isFirstSelectedDay(day) {
45
55
  if (this.isRange) {
46
- return day.timestamp === this.innerDate.from?.timestamp;
56
+ return day.formatted === this.innerDate.from?.formatted;
47
57
  }
48
- return this.innerDate.timestamp === day.timestamp;
58
+ return this.innerDate.formatted === day.formatted;
49
59
  }
50
60
  isLastSelectedDay(day) {
51
61
  if (this.isRange) {
52
- return day.timestamp === (this.innerDate.to?.timestamp || this.innerDate.from?.timestamp);
62
+ return day.formatted === (this.innerDate.to?.formatted || this.innerDate.from?.formatted);
53
63
  }
54
- return this.innerDate.timestamp === day.timestamp;
64
+ return this.innerDate.formatted === day.formatted;
55
65
  }
56
66
  ngOnInit() {
57
67
  this.assignInitialValues();
@@ -62,9 +72,9 @@ export class DatePickerCalendarComponent {
62
72
  const receivedDate = this.date;
63
73
  if (receivedDate.from && receivedDate.to) {
64
74
  this.innerDate = {
65
- from: this.getDayFromDate(receivedDate.from),
66
- to: this.getDayFromDate(receivedDate.to),
67
- label: receivedDate.label || 'CUSTOM_PERIOD'
75
+ from: this.getDayFromString(receivedDate.from),
76
+ to: this.getDayFromString(receivedDate.to),
77
+ label: PeriodLabel[receivedDate.label || 'CUSTOM_PERIOD'].toString()
68
78
  };
69
79
  }
70
80
  else {
@@ -75,7 +85,7 @@ export class DatePickerCalendarComponent {
75
85
  this.displayDate = moment.unix(this.innerDate.from?.timestamp || (Date.now() / 1000));
76
86
  }
77
87
  else {
78
- this.innerDate = this.getDayFromDate(this.date);
88
+ this.innerDate = this.getDayFromString(this.date);
79
89
  this.displayDate = moment.unix(this.innerDate.timestamp);
80
90
  }
81
91
  this.firstDayOfWeek = this.displayDate.clone().startOf('week').day();
@@ -144,14 +154,15 @@ export class DatePickerCalendarComponent {
144
154
  timestamp: day.unix(),
145
155
  day: day.format('D'),
146
156
  month: day.month(),
147
- weekDay: day.day()
157
+ weekDay: day.day(),
158
+ formatted: day.format(DEFAULT_DATE_FORMAT),
148
159
  };
149
160
  }
150
- getDayFromDate(date) {
151
- return this.getDayFromMoment(moment(date).utc(false));
161
+ getDayFromString(date) {
162
+ return this.getDayFromMoment(moment(date));
152
163
  }
153
164
  getDateFromDay(day) {
154
- return moment.unix(day.timestamp).startOf('day').toDate();
165
+ return moment.unix(day.timestamp).startOf('day').format(DEFAULT_DATE_FORMAT);
155
166
  }
156
167
  incrementMonth(amount) {
157
168
  this.displayDate.add(amount, 'month');
@@ -194,17 +205,17 @@ export class DatePickerCalendarComponent {
194
205
  }
195
206
  emitRange(range) {
196
207
  const newRange = {};
197
- newRange.label = 'CUSTOM_PERIOD';
208
+ newRange.label = PeriodLabel.CUSTOM_PERIOD;
198
209
  if (range.from) {
199
210
  newRange.from = this.getDateFromDay(range.from);
200
211
  if (range.to)
201
- newRange.to = asDate(moment.unix(range.to.timestamp).endOf('day'));
212
+ newRange.to = formatTo(moment.unix(range.to.timestamp));
202
213
  }
203
214
  this.dateChange.emit(newRange);
204
215
  }
205
216
  handleSingleSelect(momentDate) {
206
217
  this.innerDate = this.getDayFromMoment(momentDate);
207
- this.dateChange.emit(asDate(momentDate));
218
+ this.dateChange.emit(momentDate.format(DEFAULT_DATE_FORMAT));
208
219
  }
209
220
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: DatePickerCalendarComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
210
221
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.6", type: DatePickerCalendarComponent, selector: "ask-date-picker-calendar", inputs: { isRange: "isRange", date: "date" }, outputs: { dateChange: "dateChange" }, ngImport: i0, template: "<div class=\"date-picker-calendar-container\">\n <header class=\"month-selector\">\n <button type=\"button\" class=\"selector-button\" (click)=\"incrementMonth(-1)\">\n <span class=\"material-icons icon\">chevron_left</span>\n </button>\n\n <span class=\"month-year-display\" data-testid=\"month-year-display\">{{ month }} {{ year }}</span>\n\n <button type=\"button\" class=\"selector-button\" (click)=\"incrementMonth(1)\">\n <span class=\"material-icons icon\">chevron_right</span>\n </button>\n </header>\n\n <main class=\"calendar\">\n <div class=\"week-days-header\">\n <span class=\"week-day\" *ngFor=\"let weekDay of weekDays\">{{ weekDay.name }}</span>\n </div>\n\n <div class=\"days-block\" data-testid=\"days-block\">\n <span\n *ngFor=\"let day of days\"\n (click)=\"selectDate(day.timestamp)\"\n [ngClass]=\"{\n 'day': true,\n 'another-month': monthNumber != day.month,\n 'selected': isDaySelected(day),\n 'first': isFirstSelectedDay(day),\n 'last': isLastSelectedDay(day),\n }\"\n >\n {{ day.day }}\n </span>\n </div>\n </main>\n</div>\n", styles: [":root{--asksuite-orange: #FF5724;--white: #FFF;--grey-50: #F5F7FA;--grey-100: #E4E7EB;--grey-200: #CBD2D9;--grey-300: #9AA5B1;--grey-400: #7B8794;--grey-500: #616E7C;--grey-600: #52606D;--grey-700: #3E4C59;--grey-800: #2A3042;--grey-900: #1F2933;--yellow-50: #FFF8E2;--yellow-200: #FFECB3;--success-green: #4BAF50;--warning-yellow: #FFC107;--error-red: #E8453E;--shadow: rgba(42, 48, 66, .1607843137);--lightblue-tag: #CDF9F3;--lavender-tag: #D4DAF3;--green-tag: #CEEEAA;--pink-tag: #FBC5FF;--orange-tag: #FED5C9;--purple-tag: #DDBFE5;--yellow-tag: #FFE0B2;--blue-tag: #B2E5FD;--brown-tag: #EFC89C;--whatsapp-green: #68B35D;--facebook-blue: #0084FF;--instagram-pink: #D53E91;--google-blue: #345DC8;--telegram-blue: #34AADF;--telephone-yellow: #FECB00;--primary-background: #FFF;--secondary-background: #EFF3F8;--hover-background: #F5F7FA;--divider-background: #E4E7EB;--font-color-100: #2A3042;--font-color-200: #616E7C;--font-color-300: #9AA5B1}:root{--font-default: $font-default;--font-code: $font-code}:root{--font-xs: $font-xs;--font-sm: $font-sm;--font-md: $font-md;--font-lg: $font-lg;--font-xl: $font-xl;--font-xxl: $font-xxl}:root{--font-weight-regular: $font-weight-regular;--font-weight-medium: $font-weight-medium}:root{--radii-px: $radii-px;--radii-xs: $radii-xs;--radii-sm: $radii-sm;--radii-md: $radii-md;--radii-lg: $radii-lg;--radii-full: $radii-full}.ellipsis{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.material-icons{font-family:Material Icons;font-weight:400;font-style:normal;font-size:24px;line-height:1;letter-spacing:normal;text-transform:none;display:inline-block;white-space:nowrap;word-wrap:normal;direction:ltr;-webkit-font-feature-settings:\"liga\";-webkit-font-smoothing:antialiased}*{box-sizing:border-box}*,button,select,textarea{font-family:Inter,sans-serif;font-weight:400}input{font-size:1rem}.date-picker-calendar-container{display:flex;flex-direction:column;padding:16px;width:320px;-webkit-user-select:none;user-select:none}.month-selector{display:flex;align-items:center;justify-content:space-between;padding:4px;background-color:var(--secondary-background);border-radius:4px;text-transform:capitalize}.month-selector>.month-year-display{font-size:.75rem;color:var(--font-color-100);font-weight:500}.selector-button{display:flex;align-items:center;justify-content:center;width:20px;height:20px;background-color:var(--primary-background);box-shadow:0 1px 2px #2a304229;outline:none;border:none;border-radius:4px;cursor:pointer}.selector-button>.icon{color:var(--font-color-100);font-size:18px}.calendar{display:flex;flex-direction:column;padding:16px 32px}.week-days-header{display:grid;grid-template-rows:auto;grid-template-columns:repeat(7,auto);place-items:center;padding-bottom:8px;border-bottom:1px solid #E4E7EB}.week-days-header>.week-day{display:flex;align-items:center;justify-content:center;font-size:.75rem;line-height:1rem;width:100%;color:var(--font-color-100)}.days-block{display:grid;grid-template-rows:repeat(6,auto);grid-template-columns:repeat(7,auto);place-items:center;row-gap:4px;color:var(--font-color-200);padding-top:4px}.days-block>.day{display:flex;align-items:center;justify-content:center;text-align:center;font-size:.75rem;line-height:1rem;width:100%;height:31px;border-radius:99999px;transition:.2s background-color,.2s color,.2s font-weight}.days-block>.day.another-month{color:var(--font-color-300)}.days-block>.day.selected,.days-block>.day:hover{color:#ff5724;background-color:#ff57241a;cursor:pointer}.days-block>.day.selected{border-radius:0;font-weight:500}.days-block>.day.selected.first{border-top-left-radius:99999px;border-bottom-left-radius:99999px}.days-block>.day.selected.last{border-top-right-radius:99999px;border-bottom-right-radius:99999px}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] }); }
@@ -219,4 +230,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImpor
219
230
  }], dateChange: [{
220
231
  type: Output
221
232
  }] } });
222
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-picker-calendar.component.js","sourceRoot":"","sources":["../../../../../../../projects/asksuite-citrus/src/lib/components/date-picker/date-picker-calendar/date-picker-calendar.component.ts","../../../../../../../projects/asksuite-citrus/src/lib/components/date-picker/date-picker-calendar/date-picker-calendar.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, EventEmitter, Input, OnInit, Output} from '@angular/core';\nimport moment from 'moment';\n\nexport const asDate = (inMoment: moment.Moment) => {\n  return inMoment.utc(true).toDate();\n}\n\nexport interface Day {\n  timestamp: number;\n  day: string;\n  month: number;\n  weekDay: number;\n}\n\nexport interface WeekDay {\n  name: string;\n}\n\nexport type DateRange = { from?: Date; to?: Date; label?: string; };\n\nexport type DatePickerValue = Date | DateRange;\n\ntype DayRange = { from?: Day; to?: Day; label?: string; };\n\ntype DatePickerInnerValue = Day | DayRange;\n\n@Component({\n  selector: 'ask-date-picker-calendar',\n  templateUrl: './date-picker-calendar.component.html',\n  styleUrls: ['./date-picker-calendar.component.scss']\n})\nexport class DatePickerCalendarComponent implements OnInit {\n  @Input() isRange: boolean = false;\n  @Input() date!: DatePickerValue;\n  @Output() dateChange: EventEmitter<DatePickerValue> = new EventEmitter<DatePickerValue>();\n\n  private innerDate!: DatePickerInnerValue;\n  private displayDate!: moment.Moment;\n  private firstDayOfWeek!: number;\n  private _weekDays: Array<WeekDay> = [];\n  private _days: Array<Day> = [];\n\n  get days(): Array<Day> {\n    return this._days\n  }\n\n  get month(): string {\n    return this.displayDate.format('MMMM');\n  }\n\n  get monthNumber(): number {\n    return this.displayDate.month();\n  }\n\n  get year(): string {\n    return this.displayDate.format('YYYY');\n  }\n\n  get weekDays(): Array<WeekDay> {\n    return this._weekDays;\n  }\n\n  isDaySelected(day: Day): boolean {\n    if (this.isRange) {\n\n      const from = (this.innerDate as DayRange).from?.timestamp;\n      const to = (this.innerDate as DayRange).to?.timestamp;\n\n      if (!from) {\n        return false;\n      }\n      else if (!to) {\n        return day.timestamp === from;\n      }\n\n      return day.timestamp >= from && day.timestamp <= to;\n    }\n\n    return (this.innerDate as Day)?.timestamp === day.timestamp;\n  }\n\n  isFirstSelectedDay(day: Day) {\n    if (this.isRange) {\n      return day.timestamp === (this.innerDate as DayRange).from?.timestamp;\n    }\n\n    return (this.innerDate as Day).timestamp === day.timestamp;\n  }\n\n  isLastSelectedDay(day: Day) {\n    if (this.isRange) {\n      return day.timestamp === ((this.innerDate as DayRange).to?.timestamp || (this.innerDate as DayRange).from?.timestamp);\n    }\n\n    return (this.innerDate as Day).timestamp === day.timestamp;\n  }\n\n  ngOnInit() {\n    this.assignInitialValues();\n    this.refreshDisplay();\n  }\n\n  private assignInitialValues() {\n    if (this.isRange) {\n      const receivedDate = this.date as DateRange;\n      if (receivedDate.from && receivedDate.to) {\n        (this.innerDate as DayRange) = {\n          from: this.getDayFromDate(receivedDate.from),\n          to: this.getDayFromDate(receivedDate.to),\n          label: receivedDate.label || 'CUSTOM_PERIOD'\n        }\n      }\n      else {\n        (this.innerDate as DayRange) = {\n          label: 'CUSTOM_PERIOD'\n        };\n      }\n      this.displayDate = moment.unix((this.innerDate as DayRange).from?.timestamp || (Date.now() / 1000));\n    }\n    else {\n      this.innerDate = this.getDayFromDate(this.date as Date);\n      this.displayDate = moment.unix(this.innerDate.timestamp);\n    }\n\n    this.firstDayOfWeek = this.displayDate.clone().startOf('week').day();\n  }\n\n  private refreshDisplay() {\n    this.buildWeekDays();\n    this.buildDays();\n  }\n\n  private buildWeekDays() {\n    const startOfWeek = this.displayDate.clone().startOf('week');\n    const endOfWeek = this.displayDate.clone().endOf('week');\n    this._weekDays = [];\n\n    do {\n      this._weekDays.push({\n        name: startOfWeek.format('ddd')\n      });\n\n      startOfWeek.add(1, 'day');\n    }\n    while (startOfWeek.isBefore(endOfWeek));\n  }\n\n  private buildDays() {\n    let startDay = this.displayDate.clone().startOf('month');\n    let endDay = this.displayDate.clone().endOf('month');\n\n    let daysOfPastMonth: Array<Day> = [];\n    let daysOfThisMonth: Array<Day> = [];\n    let daysOfNextMonth: Array<Day> = [];\n\n    // Builds this month days\n    daysOfThisMonth = this.getDaysBetween(startDay, endDay);\n\n    // Builds past month days\n    if (daysOfThisMonth[0].weekDay !== this.firstDayOfWeek) {\n      startDay = this.displayDate.clone().startOf('month').startOf('week');\n    }\n    else {\n      startDay = this.displayDate.clone().subtract(1, 'month').endOf('month').startOf('week');\n    }\n    endDay = startDay.clone().endOf('month');\n    daysOfPastMonth = this.getDaysBetween(startDay, endDay);\n\n    // Builds next month days\n    startDay = this.displayDate.clone().add(1, 'month').startOf('month');\n    endDay = startDay.clone().endOf('week');\n    daysOfNextMonth = this.getDaysBetween(startDay, endDay);\n\n    this._days = [\n      ...daysOfPastMonth,\n      ...daysOfThisMonth,\n      ...daysOfNextMonth,\n    ];\n\n    // If calendar isn't complete yet (all 7 columns and 6 rows are full), adds another week to complete the calendar\n    if (this._days.length < 42) {\n      endDay = endDay.clone().add(1, 'day').endOf('week');\n      startDay = endDay.clone().startOf('week');\n      this._days.push(...this.getDaysBetween(startDay, endDay));\n    }\n  }\n\n  private getDaysBetween(start: moment.Moment, end: moment.Moment): Array<Day> {\n    start = start.clone();\n    end = end.clone();\n\n    const days = [];\n    do {\n      days.push(this.getDayFromMoment(start));\n\n      start.add(1, 'day');\n    }\n    while (start.isBefore(end));\n\n    return days;\n  }\n\n  getDayFromMoment(day: moment.Moment): Day {\n    day = day.clone().startOf('day');\n\n    return {\n      timestamp: day.unix(),\n      day: day.format('D'),\n      month: day.month(),\n      weekDay: day.day()\n    }\n  }\n\n  getDayFromDate(date: Date): Day {\n    return this.getDayFromMoment(moment(date).utc(false));\n  }\n\n  getDateFromDay(day: Day): Date {\n    return moment.unix(day.timestamp).startOf('day').toDate();\n  }\n\n  incrementMonth(amount: number) {\n    this.displayDate.add(amount, 'month');\n    this.refreshDisplay();\n  }\n\n  selectDate(timestamp: number) {\n    const momentDate = moment.unix(timestamp);\n\n    if (this.isRange) {\n      this.handleRangeSelect(momentDate);\n    }\n    else {\n      this.handleSingleSelect(momentDate);\n    }\n  }\n\n  private handleRangeSelect(selectedDate: moment.Moment) {\n    const innerDate = (this.innerDate as DayRange);\n\n    // First selection\n    if (!innerDate.from) {\n      innerDate.from = this.getDayFromMoment(selectedDate);\n    }\n\n    // Second selection\n    else if (!innerDate.to) {\n      const actualFrom = moment.unix(innerDate.from.timestamp);\n\n      // Selected date is past the previous selected date\n      if (selectedDate.isBefore(actualFrom, 'day')) {\n        innerDate.to = innerDate.from;\n        innerDate.from = this.getDayFromMoment(selectedDate);\n      }\n\n      // Selected date is future of the previous selected date\n      else {\n        innerDate.to = this.getDayFromMoment(selectedDate);\n      }\n    }\n\n    // Selection when both from and to are already selected\n    else {\n      innerDate.from = this.getDayFromMoment(selectedDate);\n      innerDate.to = undefined;\n    }\n\n    this.emitRange(innerDate);\n  }\n\n  private emitRange(range: DayRange) {\n    const newRange: DateRange = {};\n    newRange.label = 'CUSTOM_PERIOD';\n\n    if (range.from) {\n      newRange.from = this.getDateFromDay(range.from);\n\n      if (range.to) newRange.to = asDate(moment.unix(range.to.timestamp).endOf('day'));\n    }\n\n    this.dateChange.emit(newRange);\n  }\n\n  private handleSingleSelect(momentDate: moment.Moment) {\n    this.innerDate = this.getDayFromMoment(momentDate);\n    this.dateChange.emit(asDate(momentDate));\n  }\n}\n","<div class=\"date-picker-calendar-container\">\n  <header class=\"month-selector\">\n    <button type=\"button\" class=\"selector-button\" (click)=\"incrementMonth(-1)\">\n      <span class=\"material-icons icon\">chevron_left</span>\n    </button>\n\n    <span class=\"month-year-display\" data-testid=\"month-year-display\">{{ month }} {{ year }}</span>\n\n    <button type=\"button\" class=\"selector-button\" (click)=\"incrementMonth(1)\">\n      <span class=\"material-icons icon\">chevron_right</span>\n    </button>\n  </header>\n\n  <main class=\"calendar\">\n    <div class=\"week-days-header\">\n      <span class=\"week-day\" *ngFor=\"let weekDay of weekDays\">{{ weekDay.name }}</span>\n    </div>\n\n    <div class=\"days-block\" data-testid=\"days-block\">\n      <span\n        *ngFor=\"let day of days\"\n        (click)=\"selectDate(day.timestamp)\"\n        [ngClass]=\"{\n          'day': true,\n          'another-month': monthNumber != day.month,\n          'selected': isDaySelected(day),\n          'first': isFirstSelectedDay(day),\n          'last': isLastSelectedDay(day),\n        }\"\n      >\n        {{ day.day }}\n      </span>\n    </div>\n  </main>\n</div>\n"]}
233
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-picker-calendar.component.js","sourceRoot":"","sources":["../../../../../../../projects/asksuite-citrus/src/lib/components/date-picker/date-picker-calendar/date-picker-calendar.component.ts","../../../../../../../projects/asksuite-citrus/src/lib/components/date-picker/date-picker-calendar/date-picker-calendar.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, EventEmitter, Input, OnInit, Output} from '@angular/core';\nimport moment from 'moment';\n\nexport enum PeriodLabel {\n  TODAY = 'TODAY',\n  YESTERDAY = 'YESTERDAY',\n  LAST_7_DAYS = 'LAST_7_DAYS',\n  LAST_30_DAYS = 'LAST_30_DAYS',\n  THIS_MONTH = 'THIS_MONTH',\n  LAST_QUARTER = 'LAST_QUARTER',\n  CUSTOM_PERIOD = 'CUSTOM_PERIOD',\n}\n\nexport interface Day {\n  timestamp: number;\n  day: string;\n  month: number;\n  weekDay: number;\n  formatted: string;\n}\n\nexport interface WeekDay {\n  name: string;\n}\n\nexport type DateRange = { from?: string; to?: string; label?: PeriodLabel; };\n\nexport type DatePickerValue = string | DateRange;\n\ntype DayRange = { from?: Day; to?: Day; label?: string; };\n\ntype DatePickerInnerValue = Day | DayRange;\n\nexport const DEFAULT_DATE_FORMAT = 'YYYY-MM-DDTHH:mm:ssZ';\nexport const formatFrom = (from: moment.Moment) => from.startOf('day').format(DEFAULT_DATE_FORMAT)\nexport const formatTo = (from: moment.Moment) => from.endOf('day').format(DEFAULT_DATE_FORMAT)\n\n@Component({\n  selector: 'ask-date-picker-calendar',\n  templateUrl: './date-picker-calendar.component.html',\n  styleUrls: ['./date-picker-calendar.component.scss']\n})\nexport class DatePickerCalendarComponent implements OnInit {\n  @Input() isRange: boolean = false;\n  @Input() date!: DatePickerValue;\n  @Output() dateChange: EventEmitter<DatePickerValue> = new EventEmitter<DatePickerValue>();\n\n  private innerDate!: DatePickerInnerValue;\n  private displayDate!: moment.Moment;\n  private firstDayOfWeek!: number;\n  private _weekDays: Array<WeekDay> = [];\n  private _days: Array<Day> = [];\n\n  get days(): Array<Day> {\n    return this._days\n  }\n\n  get month(): string {\n    return this.displayDate.format('MMMM');\n  }\n\n  get monthNumber(): number {\n    return this.displayDate.month();\n  }\n\n  get year(): string {\n    return this.displayDate.format('YYYY');\n  }\n\n  get weekDays(): Array<WeekDay> {\n    return this._weekDays;\n  }\n\n  isDaySelected(day: Day): boolean {\n    if (this.isRange) {\n\n      const from = (this.innerDate as DayRange).from?.timestamp;\n      const to = (this.innerDate as DayRange).to?.timestamp;\n\n      if (!from) {\n        return false;\n      }\n      else if (!to) {\n        return day.timestamp === from;\n      }\n\n      return day.timestamp >= from && day.timestamp <= to;\n    }\n\n    return (this.innerDate as Day)?.timestamp === day.timestamp;\n  }\n\n  isFirstSelectedDay(day: Day) {\n    if (this.isRange) {\n      return day.formatted === (this.innerDate as DayRange).from?.formatted;\n    }\n\n    return (this.innerDate as Day).formatted === day.formatted;\n  }\n\n  isLastSelectedDay(day: Day) {\n    if (this.isRange) {\n      return day.formatted === ((this.innerDate as DayRange).to?.formatted || (this.innerDate as DayRange).from?.formatted);\n    }\n\n    return (this.innerDate as Day).formatted === day.formatted;\n  }\n\n  ngOnInit() {\n    this.assignInitialValues();\n    this.refreshDisplay();\n  }\n\n  private assignInitialValues() {\n    if (this.isRange) {\n      const receivedDate = this.date as DateRange;\n      if (receivedDate.from && receivedDate.to) {\n        (this.innerDate as DayRange) = {\n          from: this.getDayFromString(receivedDate.from),\n          to: this.getDayFromString(receivedDate.to),\n          label: PeriodLabel[receivedDate.label || 'CUSTOM_PERIOD'].toString()\n        }\n      }\n      else {\n        (this.innerDate as DayRange) = {\n          label: 'CUSTOM_PERIOD'\n        };\n      }\n      this.displayDate = moment.unix((this.innerDate as DayRange).from?.timestamp || (Date.now() / 1000));\n    }\n    else {\n      this.innerDate = this.getDayFromString(this.date as string);\n      this.displayDate = moment.unix(this.innerDate.timestamp);\n    }\n\n    this.firstDayOfWeek = this.displayDate.clone().startOf('week').day();\n  }\n\n  private refreshDisplay() {\n    this.buildWeekDays();\n    this.buildDays();\n  }\n\n  private buildWeekDays() {\n    const startOfWeek = this.displayDate.clone().startOf('week');\n    const endOfWeek = this.displayDate.clone().endOf('week');\n    this._weekDays = [];\n\n    do {\n      this._weekDays.push({\n        name: startOfWeek.format('ddd')\n      });\n\n      startOfWeek.add(1, 'day');\n    }\n    while (startOfWeek.isBefore(endOfWeek));\n  }\n\n  private buildDays() {\n    let startDay = this.displayDate.clone().startOf('month');\n    let endDay = this.displayDate.clone().endOf('month');\n\n    let daysOfPastMonth: Array<Day> = [];\n    let daysOfThisMonth: Array<Day> = [];\n    let daysOfNextMonth: Array<Day> = [];\n\n    // Builds this month days\n    daysOfThisMonth = this.getDaysBetween(startDay, endDay);\n\n    // Builds past month days\n    if (daysOfThisMonth[0].weekDay !== this.firstDayOfWeek) {\n      startDay = this.displayDate.clone().startOf('month').startOf('week');\n    }\n    else {\n      startDay = this.displayDate.clone().subtract(1, 'month').endOf('month').startOf('week');\n    }\n    endDay = startDay.clone().endOf('month');\n    daysOfPastMonth = this.getDaysBetween(startDay, endDay);\n\n    // Builds next month days\n    startDay = this.displayDate.clone().add(1, 'month').startOf('month');\n    endDay = startDay.clone().endOf('week');\n    daysOfNextMonth = this.getDaysBetween(startDay, endDay);\n\n    this._days = [\n      ...daysOfPastMonth,\n      ...daysOfThisMonth,\n      ...daysOfNextMonth,\n    ];\n\n    // If calendar isn't complete yet (all 7 columns and 6 rows are full), adds another week to complete the calendar\n    if (this._days.length < 42) {\n      endDay = endDay.clone().add(1, 'day').endOf('week');\n      startDay = endDay.clone().startOf('week');\n      this._days.push(...this.getDaysBetween(startDay, endDay));\n    }\n  }\n\n  private getDaysBetween(start: moment.Moment, end: moment.Moment): Array<Day> {\n    start = start.clone();\n    end = end.clone();\n\n    const days = [];\n    do {\n      days.push(this.getDayFromMoment(start));\n\n      start.add(1, 'day');\n    }\n    while (start.isBefore(end));\n\n    return days;\n  }\n\n  getDayFromMoment(day: moment.Moment): Day {\n    day = day.clone().startOf('day');\n\n    return {\n      timestamp: day.unix(),\n      day: day.format('D'),\n      month: day.month(),\n      weekDay: day.day(),\n      formatted: day.format(DEFAULT_DATE_FORMAT),\n    }\n  }\n\n  getDayFromString(date: string): Day {\n    return this.getDayFromMoment(moment(date));\n  }\n\n  getDateFromDay(day: Day): string {\n    return moment.unix(day.timestamp).startOf('day').format(DEFAULT_DATE_FORMAT);\n  }\n\n  incrementMonth(amount: number) {\n    this.displayDate.add(amount, 'month');\n    this.refreshDisplay();\n  }\n\n  selectDate(timestamp: number) {\n    const momentDate = moment.unix(timestamp);\n\n    if (this.isRange) {\n      this.handleRangeSelect(momentDate);\n    }\n    else {\n      this.handleSingleSelect(momentDate);\n    }\n  }\n\n  private handleRangeSelect(selectedDate: moment.Moment) {\n    const innerDate = (this.innerDate as DayRange);\n\n    // First selection\n    if (!innerDate.from) {\n      innerDate.from = this.getDayFromMoment(selectedDate);\n    }\n\n    // Second selection\n    else if (!innerDate.to) {\n      const actualFrom = moment.unix(innerDate.from.timestamp);\n\n      // Selected date is past the previous selected date\n      if (selectedDate.isBefore(actualFrom, 'day')) {\n        innerDate.to = innerDate.from;\n        innerDate.from = this.getDayFromMoment(selectedDate);\n      }\n\n      // Selected date is future of the previous selected date\n      else {\n        innerDate.to = this.getDayFromMoment(selectedDate);\n      }\n    }\n\n    // Selection when both from and to are already selected\n    else {\n      innerDate.from = this.getDayFromMoment(selectedDate);\n      innerDate.to = undefined;\n    }\n\n    this.emitRange(innerDate);\n  }\n\n  private emitRange(range: DayRange) {\n    const newRange: DateRange = {};\n    newRange.label = PeriodLabel.CUSTOM_PERIOD;\n\n    if (range.from) {\n      newRange.from = this.getDateFromDay(range.from);\n\n      if (range.to) newRange.to = formatTo(moment.unix(range.to.timestamp));\n    }\n\n    this.dateChange.emit(newRange);\n  }\n\n  private handleSingleSelect(momentDate: moment.Moment) {\n    this.innerDate = this.getDayFromMoment(momentDate);\n    this.dateChange.emit(momentDate.format(DEFAULT_DATE_FORMAT));\n  }\n}\n","<div class=\"date-picker-calendar-container\">\n  <header class=\"month-selector\">\n    <button type=\"button\" class=\"selector-button\" (click)=\"incrementMonth(-1)\">\n      <span class=\"material-icons icon\">chevron_left</span>\n    </button>\n\n    <span class=\"month-year-display\" data-testid=\"month-year-display\">{{ month }} {{ year }}</span>\n\n    <button type=\"button\" class=\"selector-button\" (click)=\"incrementMonth(1)\">\n      <span class=\"material-icons icon\">chevron_right</span>\n    </button>\n  </header>\n\n  <main class=\"calendar\">\n    <div class=\"week-days-header\">\n      <span class=\"week-day\" *ngFor=\"let weekDay of weekDays\">{{ weekDay.name }}</span>\n    </div>\n\n    <div class=\"days-block\" data-testid=\"days-block\">\n      <span\n        *ngFor=\"let day of days\"\n        (click)=\"selectDate(day.timestamp)\"\n        [ngClass]=\"{\n          'day': true,\n          'another-month': monthNumber != day.month,\n          'selected': isDaySelected(day),\n          'first': isFirstSelectedDay(day),\n          'last': isLastSelectedDay(day),\n        }\"\n      >\n        {{ day.day }}\n      </span>\n    </div>\n  </main>\n</div>\n"]}
@@ -1,76 +1,123 @@
1
- import { Component, EventEmitter, Input, Output } from '@angular/core';
1
+ import { Component, EventEmitter, forwardRef, Input, Output } from '@angular/core';
2
2
  import moment from 'moment';
3
- import { asDate } from "./date-picker-calendar/date-picker-calendar.component";
3
+ import { PeriodLabel, formatFrom, formatTo } from "./date-picker-calendar/date-picker-calendar.component";
4
+ import { NG_VALUE_ACCESSOR } from "@angular/forms";
4
5
  import * as i0 from "@angular/core";
5
6
  import * as i1 from "@angular/common";
6
7
  import * as i2 from "../button/button.component";
7
8
  import * as i3 from "./date-picker-calendar/date-picker-calendar.component";
8
9
  import * as i4 from "@ngx-translate/core";
10
+ const VALUE_ACCESSOR = {
11
+ provide: NG_VALUE_ACCESSOR,
12
+ multi: true,
13
+ useExisting: forwardRef(() => DatePickerComponent),
14
+ };
9
15
  export class DatePickerComponent {
10
16
  constructor() {
11
17
  this.periods = [
12
- { label: 'TODAY', getRange: () => ({ from: asDate(moment().startOf('day')), to: asDate(moment().endOf('day')) }), selected: false },
13
- { label: 'YESTERDAY', getRange: () => ({ from: asDate(moment().subtract(1, 'day').startOf('day')), to: asDate(moment().subtract(1, 'day').endOf('day')) }), selected: false },
14
- { label: 'LAST_7_DAYS', getRange: () => ({ from: asDate(moment().subtract(1, 'week').startOf('day')), to: asDate(moment().endOf('day')) }), selected: false },
15
- { label: 'LAST_30_DAYS', getRange: () => ({ from: asDate(moment().subtract(30, 'days').startOf('day')), to: asDate(moment().endOf('day')) }), selected: false },
16
- { label: 'THIS_MONTH', getRange: () => ({ from: asDate(moment().startOf('month')), to: asDate(moment().endOf('month')) }), selected: false },
17
- { label: 'LAST_QUARTER', getRange: () => ({ from: asDate(moment().subtract(3, 'months').startOf('day')), to: asDate(moment().endOf('month')) }), selected: false },
18
- { label: 'CUSTOM_PERIOD', getRange: () => ({}), isCustomRange: true, selected: false },
18
+ { label: PeriodLabel.TODAY, getRange: () => ({ from: formatFrom(moment()), to: formatTo(moment()) }), selected: false },
19
+ { label: PeriodLabel.YESTERDAY, getRange: () => ({ from: formatFrom(moment().subtract(1, 'day')), to: formatTo(moment().subtract(1, 'day')) }), selected: false },
20
+ { label: PeriodLabel.LAST_7_DAYS, getRange: () => ({ from: formatFrom(moment().subtract(1, 'week')), to: formatTo(moment()) }), selected: false },
21
+ { label: PeriodLabel.LAST_30_DAYS, getRange: () => ({ from: formatFrom(moment().subtract(30, 'days')), to: formatTo(moment()) }), selected: false },
22
+ { label: PeriodLabel.THIS_MONTH, getRange: () => ({ from: formatFrom(moment().startOf('month')), to: formatTo(moment().endOf('month')) }), selected: false },
23
+ { label: PeriodLabel.LAST_QUARTER, getRange: () => ({ from: formatFrom(moment().subtract(3, 'months')), to: formatTo(moment().endOf('month')) }), selected: false },
24
+ { label: PeriodLabel.CUSTOM_PERIOD, getRange: () => ({}), isCustomRange: true, selected: false },
19
25
  ];
20
- this.date = new Date();
26
+ this.date = moment().format();
21
27
  this.isRange = false;
22
28
  this.dateChange = new EventEmitter();
23
29
  this.close = new EventEmitter();
24
30
  this.isCustomRange = false;
31
+ this.onChange = (value) => { };
32
+ this.onTouch = () => { };
25
33
  }
26
34
  get from() {
27
- if (this.date instanceof Date) {
35
+ if (!this.isRange) {
28
36
  return;
29
37
  }
30
38
  return this.date.from;
31
39
  }
32
40
  get to() {
33
- if (this.date instanceof Date) {
41
+ if (!this.isRange) {
34
42
  return;
35
43
  }
36
44
  return this.date.to;
37
45
  }
38
46
  get dateDisplay() {
39
- const from = this.from ? moment(this.from).utc(false).format('L') : '';
40
- const to = this.to ? moment(this.to).utc(false).format('L') : '';
47
+ const from = this.from ? moment(this.from).format('L') : '';
48
+ const to = this.to ? moment(this.to).format('L') : '';
41
49
  return `${from} ${to ? '- ' + to : ''}`;
42
50
  }
43
51
  ngOnInit() {
44
52
  }
45
53
  selectPeriod(period) {
46
- this.periods.forEach(period => period.selected = false);
54
+ this.periods.forEach((period) => period.selected = false);
47
55
  this.date = period.getRange();
48
56
  this.date.label = period.label;
49
57
  this.isCustomRange = period.isCustomRange || false;
50
58
  period.selected = true;
51
59
  if (!this.isCustomRange) {
52
- this.writeValue();
60
+ this.emitValue();
53
61
  }
54
62
  }
55
63
  handleDateChange(value) {
56
64
  this.date = value;
57
65
  if (!this.isRange) {
58
- this.writeValue();
66
+ this.emitValue();
59
67
  }
60
68
  }
61
- writeValue() {
69
+ emitValue() {
62
70
  this.dateChange.emit(this.date);
71
+ this.onChange(this.date);
63
72
  this.close.emit();
64
73
  }
65
74
  handleCancelClick() {
66
75
  this.close.emit();
67
76
  }
77
+ getPeriodOrDefault(periodName, defaultPeriodName = PeriodLabel.TODAY) {
78
+ return this.periods.find(p => p.label === periodName) ||
79
+ this.periods.find(p => p.label === defaultPeriodName);
80
+ }
81
+ checkPeriodShouldBeSelectedByValue() {
82
+ if (!this.isRange) {
83
+ return;
84
+ }
85
+ this.periods.forEach((period) => period.selected = false);
86
+ const period = this.periods.find(p => p.label === this.date?.label);
87
+ if (!period) {
88
+ return;
89
+ }
90
+ period.selected = true;
91
+ this.isCustomRange = period.isCustomRange || false;
92
+ }
93
+ writeValue(value) {
94
+ if (this.isRange) {
95
+ const valueRange = value;
96
+ if (valueRange.label && valueRange.label !== PeriodLabel.CUSTOM_PERIOD) {
97
+ const period = this.getPeriodOrDefault(valueRange.label)?.getRange() || {};
98
+ this.date = { ...period, label: valueRange.label };
99
+ }
100
+ else if (valueRange.from && valueRange.to) {
101
+ this.date = { from: valueRange.from, to: valueRange.to, label: PeriodLabel.CUSTOM_PERIOD };
102
+ }
103
+ this.checkPeriodShouldBeSelectedByValue();
104
+ }
105
+ else {
106
+ this.date = value;
107
+ }
108
+ }
109
+ registerOnChange(fn) {
110
+ this.onChange = fn;
111
+ }
112
+ registerOnTouched(fn) {
113
+ this.onTouch = fn;
114
+ }
68
115
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: DatePickerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
69
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.6", type: DatePickerComponent, selector: "ask-date-picker", inputs: { date: "date", isRange: "isRange" }, outputs: { dateChange: "dateChange", close: "close" }, ngImport: i0, template: "<div class=\"date-picker-container\">\n <main class=\"main-content\">\n <div\n class=\"periods-list\"\n *ngIf=\"isRange\"\n [ngClass]=\"{ 'show-divider': isCustomRange }\"\n >\n <button\n *ngFor=\"let period of periods\"\n type=\"button\"\n class=\"period\"\n [ngClass]=\"{ 'selected': period.selected }\"\n (click)=\"selectPeriod(period)\"\n >\n {{ period.label | translate }}\n </button>\n </div>\n\n <ask-date-picker-calendar\n *ngIf=\"!isRange || (isRange && isCustomRange)\"\n [date]=\"date\"\n (dateChange)=\"handleDateChange($event)\"\n [isRange]=\"isRange\"\n ></ask-date-picker-calendar>\n </main>\n\n <footer class=\"footer\" *ngIf=\"isCustomRange && isRange\">\n <div class=\"date-display\">{{ dateDisplay }}</div>\n\n <div class=\"button-tray\">\n <ask-button\n [size]=\"'xsmall'\"\n [type]=\"'secondary'\"\n (click)=\"handleCancelClick()\"\n >\n {{ 'CANCEL' | translate }}\n </ask-button>\n\n <ask-button\n [size]=\"'xsmall'\"\n [type]=\"'primary'\"\n (click)=\"writeValue()\"\n >\n {{ 'APPLY' | translate }}\n </ask-button>\n </div>\n </footer>\n</div>\n", styles: [":root{--asksuite-orange: #FF5724;--white: #FFF;--grey-50: #F5F7FA;--grey-100: #E4E7EB;--grey-200: #CBD2D9;--grey-300: #9AA5B1;--grey-400: #7B8794;--grey-500: #616E7C;--grey-600: #52606D;--grey-700: #3E4C59;--grey-800: #2A3042;--grey-900: #1F2933;--yellow-50: #FFF8E2;--yellow-200: #FFECB3;--success-green: #4BAF50;--warning-yellow: #FFC107;--error-red: #E8453E;--shadow: rgba(42, 48, 66, .1607843137);--lightblue-tag: #CDF9F3;--lavender-tag: #D4DAF3;--green-tag: #CEEEAA;--pink-tag: #FBC5FF;--orange-tag: #FED5C9;--purple-tag: #DDBFE5;--yellow-tag: #FFE0B2;--blue-tag: #B2E5FD;--brown-tag: #EFC89C;--whatsapp-green: #68B35D;--facebook-blue: #0084FF;--instagram-pink: #D53E91;--google-blue: #345DC8;--telegram-blue: #34AADF;--telephone-yellow: #FECB00;--primary-background: #FFF;--secondary-background: #EFF3F8;--hover-background: #F5F7FA;--divider-background: #E4E7EB;--font-color-100: #2A3042;--font-color-200: #616E7C;--font-color-300: #9AA5B1}:root{--font-default: $font-default;--font-code: $font-code}:root{--font-xs: $font-xs;--font-sm: $font-sm;--font-md: $font-md;--font-lg: $font-lg;--font-xl: $font-xl;--font-xxl: $font-xxl}:root{--font-weight-regular: $font-weight-regular;--font-weight-medium: $font-weight-medium}:root{--radii-px: $radii-px;--radii-xs: $radii-xs;--radii-sm: $radii-sm;--radii-md: $radii-md;--radii-lg: $radii-lg;--radii-full: $radii-full}.ellipsis{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.material-icons{font-family:Material Icons;font-weight:400;font-style:normal;font-size:24px;line-height:1;letter-spacing:normal;text-transform:none;display:inline-block;white-space:nowrap;word-wrap:normal;direction:ltr;-webkit-font-feature-settings:\"liga\";-webkit-font-smoothing:antialiased}*{box-sizing:border-box}*,button,select,textarea{font-family:Inter,sans-serif;font-weight:400}input{font-size:1rem}.date-picker-container{display:flex;flex-direction:column}.main-content{display:flex}.periods-list{display:flex;flex-direction:column;justify-content:start;gap:4px;padding:8px 0}.periods-list.show-divider{border-right:1px solid var(--divider-background)}.periods-list>.period{padding:8px 16px;color:var(--font-color-200);background:none;border:none;outline:none;cursor:pointer;transition:color .2s,background-color .2s;text-align:start}.periods-list>.period:hover,.periods-list>.period.selected{background-color:var(--hover-background)}.periods-list>.period:active,.periods-list>.period.selected{color:#ff5724}.footer{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-top:1px solid var(--divider-background)}.footer>.button-tray{display:flex;gap:16px}.date-display{display:flex;font-size:.875rem;color:var(--font-color-200);gap:4px}.date-display>.date{width:79px}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.ButtonComponent, selector: "ask-button", inputs: ["label", "size", "type", "rounded", "disabled", "labelSide"], outputs: ["onClick", "onFocus", "onBlur"] }, { kind: "component", type: i3.DatePickerCalendarComponent, selector: "ask-date-picker-calendar", inputs: ["isRange", "date"], outputs: ["dateChange"] }, { kind: "pipe", type: i4.TranslatePipe, name: "translate" }] }); }
116
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.6", type: DatePickerComponent, selector: "ask-date-picker", inputs: { date: "date", isRange: "isRange" }, outputs: { dateChange: "dateChange", close: "close" }, providers: [VALUE_ACCESSOR], ngImport: i0, template: "<div class=\"date-picker-container\">\n <main class=\"main-content\">\n <div\n class=\"periods-list\"\n *ngIf=\"isRange\"\n [ngClass]=\"{ 'show-divider': isCustomRange }\"\n >\n <button\n *ngFor=\"let period of periods\"\n type=\"button\"\n class=\"period\"\n [ngClass]=\"{ 'selected': period.selected }\"\n (click)=\"selectPeriod(period)\"\n >\n {{ period.label.toString() | translate }}\n </button>\n </div>\n\n <ask-date-picker-calendar\n *ngIf=\"!isRange || (isRange && isCustomRange)\"\n [date]=\"date\"\n (dateChange)=\"handleDateChange($event)\"\n [isRange]=\"isRange\"\n ></ask-date-picker-calendar>\n </main>\n\n <footer class=\"footer\" *ngIf=\"isCustomRange && isRange\">\n <div class=\"date-display\">{{ dateDisplay }}</div>\n\n <div class=\"button-tray\">\n <ask-button\n [size]=\"'xsmall'\"\n [type]=\"'secondary'\"\n (click)=\"handleCancelClick()\"\n >\n {{ 'CANCEL' | translate }}\n </ask-button>\n\n <ask-button\n [size]=\"'xsmall'\"\n [type]=\"'primary'\"\n (click)=\"emitValue()\"\n >\n {{ 'APPLY' | translate }}\n </ask-button>\n </div>\n </footer>\n</div>\n", styles: [":root{--asksuite-orange: #FF5724;--white: #FFF;--grey-50: #F5F7FA;--grey-100: #E4E7EB;--grey-200: #CBD2D9;--grey-300: #9AA5B1;--grey-400: #7B8794;--grey-500: #616E7C;--grey-600: #52606D;--grey-700: #3E4C59;--grey-800: #2A3042;--grey-900: #1F2933;--yellow-50: #FFF8E2;--yellow-200: #FFECB3;--success-green: #4BAF50;--warning-yellow: #FFC107;--error-red: #E8453E;--shadow: rgba(42, 48, 66, .1607843137);--lightblue-tag: #CDF9F3;--lavender-tag: #D4DAF3;--green-tag: #CEEEAA;--pink-tag: #FBC5FF;--orange-tag: #FED5C9;--purple-tag: #DDBFE5;--yellow-tag: #FFE0B2;--blue-tag: #B2E5FD;--brown-tag: #EFC89C;--whatsapp-green: #68B35D;--facebook-blue: #0084FF;--instagram-pink: #D53E91;--google-blue: #345DC8;--telegram-blue: #34AADF;--telephone-yellow: #FECB00;--primary-background: #FFF;--secondary-background: #EFF3F8;--hover-background: #F5F7FA;--divider-background: #E4E7EB;--font-color-100: #2A3042;--font-color-200: #616E7C;--font-color-300: #9AA5B1}:root{--font-default: $font-default;--font-code: $font-code}:root{--font-xs: $font-xs;--font-sm: $font-sm;--font-md: $font-md;--font-lg: $font-lg;--font-xl: $font-xl;--font-xxl: $font-xxl}:root{--font-weight-regular: $font-weight-regular;--font-weight-medium: $font-weight-medium}:root{--radii-px: $radii-px;--radii-xs: $radii-xs;--radii-sm: $radii-sm;--radii-md: $radii-md;--radii-lg: $radii-lg;--radii-full: $radii-full}.ellipsis{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.material-icons{font-family:Material Icons;font-weight:400;font-style:normal;font-size:24px;line-height:1;letter-spacing:normal;text-transform:none;display:inline-block;white-space:nowrap;word-wrap:normal;direction:ltr;-webkit-font-feature-settings:\"liga\";-webkit-font-smoothing:antialiased}*{box-sizing:border-box}*,button,select,textarea{font-family:Inter,sans-serif;font-weight:400}input{font-size:1rem}.date-picker-container{display:flex;flex-direction:column}.main-content{display:flex}.periods-list{display:flex;flex-direction:column;justify-content:start;gap:4px;padding:8px 0}.periods-list.show-divider{border-right:1px solid var(--divider-background)}.periods-list>.period{padding:8px 16px;color:var(--font-color-200);background:none;border:none;outline:none;cursor:pointer;transition:color .2s,background-color .2s;text-align:start}.periods-list>.period:hover,.periods-list>.period.selected{background-color:var(--hover-background)}.periods-list>.period:active,.periods-list>.period.selected{color:#ff5724}.footer{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-top:1px solid var(--divider-background)}.footer>.button-tray{display:flex;gap:16px}.date-display{display:flex;font-size:.875rem;color:var(--font-color-200);gap:4px}.date-display>.date{width:79px}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.ButtonComponent, selector: "ask-button", inputs: ["label", "size", "type", "rounded", "disabled", "labelSide"], outputs: ["onClick", "onFocus", "onBlur"] }, { kind: "component", type: i3.DatePickerCalendarComponent, selector: "ask-date-picker-calendar", inputs: ["isRange", "date"], outputs: ["dateChange"] }, { kind: "pipe", type: i4.TranslatePipe, name: "translate" }] }); }
70
117
  }
71
118
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: DatePickerComponent, decorators: [{
72
119
  type: Component,
73
- args: [{ selector: 'ask-date-picker', template: "<div class=\"date-picker-container\">\n <main class=\"main-content\">\n <div\n class=\"periods-list\"\n *ngIf=\"isRange\"\n [ngClass]=\"{ 'show-divider': isCustomRange }\"\n >\n <button\n *ngFor=\"let period of periods\"\n type=\"button\"\n class=\"period\"\n [ngClass]=\"{ 'selected': period.selected }\"\n (click)=\"selectPeriod(period)\"\n >\n {{ period.label | translate }}\n </button>\n </div>\n\n <ask-date-picker-calendar\n *ngIf=\"!isRange || (isRange && isCustomRange)\"\n [date]=\"date\"\n (dateChange)=\"handleDateChange($event)\"\n [isRange]=\"isRange\"\n ></ask-date-picker-calendar>\n </main>\n\n <footer class=\"footer\" *ngIf=\"isCustomRange && isRange\">\n <div class=\"date-display\">{{ dateDisplay }}</div>\n\n <div class=\"button-tray\">\n <ask-button\n [size]=\"'xsmall'\"\n [type]=\"'secondary'\"\n (click)=\"handleCancelClick()\"\n >\n {{ 'CANCEL' | translate }}\n </ask-button>\n\n <ask-button\n [size]=\"'xsmall'\"\n [type]=\"'primary'\"\n (click)=\"writeValue()\"\n >\n {{ 'APPLY' | translate }}\n </ask-button>\n </div>\n </footer>\n</div>\n", styles: [":root{--asksuite-orange: #FF5724;--white: #FFF;--grey-50: #F5F7FA;--grey-100: #E4E7EB;--grey-200: #CBD2D9;--grey-300: #9AA5B1;--grey-400: #7B8794;--grey-500: #616E7C;--grey-600: #52606D;--grey-700: #3E4C59;--grey-800: #2A3042;--grey-900: #1F2933;--yellow-50: #FFF8E2;--yellow-200: #FFECB3;--success-green: #4BAF50;--warning-yellow: #FFC107;--error-red: #E8453E;--shadow: rgba(42, 48, 66, .1607843137);--lightblue-tag: #CDF9F3;--lavender-tag: #D4DAF3;--green-tag: #CEEEAA;--pink-tag: #FBC5FF;--orange-tag: #FED5C9;--purple-tag: #DDBFE5;--yellow-tag: #FFE0B2;--blue-tag: #B2E5FD;--brown-tag: #EFC89C;--whatsapp-green: #68B35D;--facebook-blue: #0084FF;--instagram-pink: #D53E91;--google-blue: #345DC8;--telegram-blue: #34AADF;--telephone-yellow: #FECB00;--primary-background: #FFF;--secondary-background: #EFF3F8;--hover-background: #F5F7FA;--divider-background: #E4E7EB;--font-color-100: #2A3042;--font-color-200: #616E7C;--font-color-300: #9AA5B1}:root{--font-default: $font-default;--font-code: $font-code}:root{--font-xs: $font-xs;--font-sm: $font-sm;--font-md: $font-md;--font-lg: $font-lg;--font-xl: $font-xl;--font-xxl: $font-xxl}:root{--font-weight-regular: $font-weight-regular;--font-weight-medium: $font-weight-medium}:root{--radii-px: $radii-px;--radii-xs: $radii-xs;--radii-sm: $radii-sm;--radii-md: $radii-md;--radii-lg: $radii-lg;--radii-full: $radii-full}.ellipsis{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.material-icons{font-family:Material Icons;font-weight:400;font-style:normal;font-size:24px;line-height:1;letter-spacing:normal;text-transform:none;display:inline-block;white-space:nowrap;word-wrap:normal;direction:ltr;-webkit-font-feature-settings:\"liga\";-webkit-font-smoothing:antialiased}*{box-sizing:border-box}*,button,select,textarea{font-family:Inter,sans-serif;font-weight:400}input{font-size:1rem}.date-picker-container{display:flex;flex-direction:column}.main-content{display:flex}.periods-list{display:flex;flex-direction:column;justify-content:start;gap:4px;padding:8px 0}.periods-list.show-divider{border-right:1px solid var(--divider-background)}.periods-list>.period{padding:8px 16px;color:var(--font-color-200);background:none;border:none;outline:none;cursor:pointer;transition:color .2s,background-color .2s;text-align:start}.periods-list>.period:hover,.periods-list>.period.selected{background-color:var(--hover-background)}.periods-list>.period:active,.periods-list>.period.selected{color:#ff5724}.footer{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-top:1px solid var(--divider-background)}.footer>.button-tray{display:flex;gap:16px}.date-display{display:flex;font-size:.875rem;color:var(--font-color-200);gap:4px}.date-display>.date{width:79px}\n"] }]
120
+ args: [{ selector: 'ask-date-picker', providers: [VALUE_ACCESSOR], template: "<div class=\"date-picker-container\">\n <main class=\"main-content\">\n <div\n class=\"periods-list\"\n *ngIf=\"isRange\"\n [ngClass]=\"{ 'show-divider': isCustomRange }\"\n >\n <button\n *ngFor=\"let period of periods\"\n type=\"button\"\n class=\"period\"\n [ngClass]=\"{ 'selected': period.selected }\"\n (click)=\"selectPeriod(period)\"\n >\n {{ period.label.toString() | translate }}\n </button>\n </div>\n\n <ask-date-picker-calendar\n *ngIf=\"!isRange || (isRange && isCustomRange)\"\n [date]=\"date\"\n (dateChange)=\"handleDateChange($event)\"\n [isRange]=\"isRange\"\n ></ask-date-picker-calendar>\n </main>\n\n <footer class=\"footer\" *ngIf=\"isCustomRange && isRange\">\n <div class=\"date-display\">{{ dateDisplay }}</div>\n\n <div class=\"button-tray\">\n <ask-button\n [size]=\"'xsmall'\"\n [type]=\"'secondary'\"\n (click)=\"handleCancelClick()\"\n >\n {{ 'CANCEL' | translate }}\n </ask-button>\n\n <ask-button\n [size]=\"'xsmall'\"\n [type]=\"'primary'\"\n (click)=\"emitValue()\"\n >\n {{ 'APPLY' | translate }}\n </ask-button>\n </div>\n </footer>\n</div>\n", styles: [":root{--asksuite-orange: #FF5724;--white: #FFF;--grey-50: #F5F7FA;--grey-100: #E4E7EB;--grey-200: #CBD2D9;--grey-300: #9AA5B1;--grey-400: #7B8794;--grey-500: #616E7C;--grey-600: #52606D;--grey-700: #3E4C59;--grey-800: #2A3042;--grey-900: #1F2933;--yellow-50: #FFF8E2;--yellow-200: #FFECB3;--success-green: #4BAF50;--warning-yellow: #FFC107;--error-red: #E8453E;--shadow: rgba(42, 48, 66, .1607843137);--lightblue-tag: #CDF9F3;--lavender-tag: #D4DAF3;--green-tag: #CEEEAA;--pink-tag: #FBC5FF;--orange-tag: #FED5C9;--purple-tag: #DDBFE5;--yellow-tag: #FFE0B2;--blue-tag: #B2E5FD;--brown-tag: #EFC89C;--whatsapp-green: #68B35D;--facebook-blue: #0084FF;--instagram-pink: #D53E91;--google-blue: #345DC8;--telegram-blue: #34AADF;--telephone-yellow: #FECB00;--primary-background: #FFF;--secondary-background: #EFF3F8;--hover-background: #F5F7FA;--divider-background: #E4E7EB;--font-color-100: #2A3042;--font-color-200: #616E7C;--font-color-300: #9AA5B1}:root{--font-default: $font-default;--font-code: $font-code}:root{--font-xs: $font-xs;--font-sm: $font-sm;--font-md: $font-md;--font-lg: $font-lg;--font-xl: $font-xl;--font-xxl: $font-xxl}:root{--font-weight-regular: $font-weight-regular;--font-weight-medium: $font-weight-medium}:root{--radii-px: $radii-px;--radii-xs: $radii-xs;--radii-sm: $radii-sm;--radii-md: $radii-md;--radii-lg: $radii-lg;--radii-full: $radii-full}.ellipsis{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.material-icons{font-family:Material Icons;font-weight:400;font-style:normal;font-size:24px;line-height:1;letter-spacing:normal;text-transform:none;display:inline-block;white-space:nowrap;word-wrap:normal;direction:ltr;-webkit-font-feature-settings:\"liga\";-webkit-font-smoothing:antialiased}*{box-sizing:border-box}*,button,select,textarea{font-family:Inter,sans-serif;font-weight:400}input{font-size:1rem}.date-picker-container{display:flex;flex-direction:column}.main-content{display:flex}.periods-list{display:flex;flex-direction:column;justify-content:start;gap:4px;padding:8px 0}.periods-list.show-divider{border-right:1px solid var(--divider-background)}.periods-list>.period{padding:8px 16px;color:var(--font-color-200);background:none;border:none;outline:none;cursor:pointer;transition:color .2s,background-color .2s;text-align:start}.periods-list>.period:hover,.periods-list>.period.selected{background-color:var(--hover-background)}.periods-list>.period:active,.periods-list>.period.selected{color:#ff5724}.footer{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-top:1px solid var(--divider-background)}.footer>.button-tray{display:flex;gap:16px}.date-display{display:flex;font-size:.875rem;color:var(--font-color-200);gap:4px}.date-display>.date{width:79px}\n"] }]
74
121
  }], propDecorators: { date: [{
75
122
  type: Input
76
123
  }], isRange: [{
@@ -80,4 +127,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImpor
80
127
  }], close: [{
81
128
  type: Output
82
129
  }] } });
83
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-picker.component.js","sourceRoot":"","sources":["../../../../../../projects/asksuite-citrus/src/lib/components/date-picker/date-picker.component.ts","../../../../../../projects/asksuite-citrus/src/lib/components/date-picker/date-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, EventEmitter, Input, OnInit, Output} from '@angular/core';\nimport moment from 'moment';\nimport {asDate, DatePickerValue, DateRange} from \"./date-picker-calendar/date-picker-calendar.component\";\n\ninterface Period {\n  label: string;\n  getRange: () => DateRange;\n  isCustomRange?: boolean;\n  selected: boolean;\n}\n\n@Component({\n  selector: 'ask-date-picker',\n  templateUrl: './date-picker.component.html',\n  styleUrls: ['./date-picker.component.scss']\n})\nexport class DatePickerComponent implements OnInit {\n\n  periods: Array<Period> = [\n    { label: 'TODAY', getRange: () => ({ from: asDate(moment().startOf('day')), to: asDate(moment().endOf('day')) }), selected: false },\n    { label: 'YESTERDAY', getRange: () => ({ from: asDate(moment().subtract(1, 'day').startOf('day')), to: asDate(moment().subtract(1, 'day').endOf('day')) }), selected: false },\n    { label: 'LAST_7_DAYS', getRange: () => ({ from: asDate(moment().subtract(1, 'week').startOf('day')), to: asDate(moment().endOf('day')) }), selected: false },\n    { label: 'LAST_30_DAYS', getRange: () => ({ from: asDate(moment().subtract(30, 'days').startOf('day')), to: asDate(moment().endOf('day')) }), selected: false },\n    { label: 'THIS_MONTH', getRange: () => ({ from: asDate(moment().startOf('month')), to: asDate(moment().endOf('month')) }), selected: false },\n    { label: 'LAST_QUARTER', getRange: () => ({ from: asDate(moment().subtract(3, 'months').startOf('day')), to: asDate(moment().endOf('month')) }), selected: false },\n    { label: 'CUSTOM_PERIOD', getRange: () => ({}), isCustomRange: true, selected: false },\n  ];\n\n  @Input() date: DatePickerValue = new Date();\n  @Input() isRange: boolean = false;\n\n  @Output() dateChange = new EventEmitter<DatePickerValue>();\n  @Output() close = new EventEmitter();\n\n  isCustomRange = false;\n\n  get from(): Date | undefined {\n    if (this.date instanceof Date) {\n      return;\n    }\n\n    return this.date.from;\n  }\n\n  get to(): Date | undefined {\n    if (this.date instanceof Date) {\n      return;\n    }\n\n    return this.date.to;\n  }\n\n  get dateDisplay(): string {\n    const from = this.from ? moment(this.from).utc(false).format('L') : '';\n    const to = this.to ? moment(this.to).utc(false).format('L') : '';\n\n    return `${from} ${ to ? '- ' + to : '' }`;\n  }\n\n  ngOnInit(): void {\n  }\n\n  selectPeriod(period: Period) {\n    this.periods.forEach(period => period.selected = false);\n\n    this.date = period.getRange();\n    this.date.label = period.label;\n    this.isCustomRange = period.isCustomRange || false;\n    period.selected = true;\n\n    if (!this.isCustomRange) {\n      this.writeValue();\n    }\n  }\n\n  handleDateChange(value: DatePickerValue) {\n    this.date = value;\n\n    if (!this.isRange) {\n      this.writeValue();\n    }\n  }\n\n  writeValue() {\n    this.dateChange.emit(this.date);\n    this.close.emit();\n  }\n\n  handleCancelClick() {\n    this.close.emit();\n  }\n\n}\n","<div class=\"date-picker-container\">\n  <main class=\"main-content\">\n    <div\n      class=\"periods-list\"\n      *ngIf=\"isRange\"\n      [ngClass]=\"{ 'show-divider': isCustomRange }\"\n    >\n      <button\n        *ngFor=\"let period of periods\"\n        type=\"button\"\n        class=\"period\"\n        [ngClass]=\"{ 'selected': period.selected }\"\n        (click)=\"selectPeriod(period)\"\n      >\n        {{ period.label | translate }}\n      </button>\n    </div>\n\n    <ask-date-picker-calendar\n      *ngIf=\"!isRange || (isRange && isCustomRange)\"\n      [date]=\"date\"\n      (dateChange)=\"handleDateChange($event)\"\n      [isRange]=\"isRange\"\n    ></ask-date-picker-calendar>\n  </main>\n\n  <footer class=\"footer\" *ngIf=\"isCustomRange && isRange\">\n    <div class=\"date-display\">{{ dateDisplay }}</div>\n\n    <div class=\"button-tray\">\n      <ask-button\n        [size]=\"'xsmall'\"\n        [type]=\"'secondary'\"\n        (click)=\"handleCancelClick()\"\n      >\n        {{ 'CANCEL' | translate }}\n      </ask-button>\n\n      <ask-button\n        [size]=\"'xsmall'\"\n        [type]=\"'primary'\"\n        (click)=\"writeValue()\"\n      >\n        {{ 'APPLY' | translate }}\n      </ask-button>\n    </div>\n  </footer>\n</div>\n"]}
130
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-picker.component.js","sourceRoot":"","sources":["../../../../../../projects/asksuite-citrus/src/lib/components/date-picker/date-picker.component.ts","../../../../../../projects/asksuite-citrus/src/lib/components/date-picker/date-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, EventEmitter, forwardRef, Input, OnInit, Output, Provider} from '@angular/core';\nimport moment from 'moment';\nimport {DatePickerValue, DateRange, PeriodLabel, formatFrom, formatTo} from \"./date-picker-calendar/date-picker-calendar.component\";\nimport {ControlValueAccessor, NG_VALUE_ACCESSOR} from \"@angular/forms\";\n\ninterface Period {\n  label: PeriodLabel;\n  getRange: () => DateRange;\n  isCustomRange?: boolean;\n  selected: boolean;\n}\n\nconst VALUE_ACCESSOR: Provider = {\n  provide: NG_VALUE_ACCESSOR,\n  multi: true,\n  useExisting: forwardRef(() => DatePickerComponent),\n}\n\n\n\n@Component({\n  selector: 'ask-date-picker',\n  templateUrl: './date-picker.component.html',\n  styleUrls: ['./date-picker.component.scss'],\n  providers: [ VALUE_ACCESSOR ],\n})\nexport class DatePickerComponent implements OnInit, ControlValueAccessor {\n\n  periods: Array<Period> = [\n    { label: PeriodLabel.TODAY, getRange: () => ({ from: formatFrom(moment()), to: formatTo(moment()) }), selected: false },\n    { label: PeriodLabel.YESTERDAY, getRange: () => ({ from: formatFrom(moment().subtract(1, 'day')), to: formatTo(moment().subtract(1, 'day')) }), selected: false },\n    { label: PeriodLabel.LAST_7_DAYS, getRange: () => ({ from: formatFrom(moment().subtract(1, 'week')), to: formatTo(moment()) }), selected: false },\n    { label: PeriodLabel.LAST_30_DAYS, getRange: () => ({ from: formatFrom(moment().subtract(30, 'days')), to: formatTo(moment()) }), selected: false },\n    { label: PeriodLabel.THIS_MONTH, getRange: () => ({ from: formatFrom(moment().startOf('month')), to: formatTo(moment().endOf('month')) }), selected: false },\n    { label: PeriodLabel.LAST_QUARTER, getRange: () => ({ from: formatFrom(moment().subtract(3, 'months')), to: formatTo(moment().endOf('month')) }), selected: false },\n    { label: PeriodLabel.CUSTOM_PERIOD, getRange: () => ({}), isCustomRange: true, selected: false },\n  ];\n\n  @Input() date: DatePickerValue = moment().format();\n  @Input() isRange: boolean = false;\n\n  @Output() dateChange = new EventEmitter<DatePickerValue>();\n  @Output() close = new EventEmitter();\n\n  isCustomRange = false;\n\n  get from(): string | undefined {\n    if (!this.isRange) {\n      return;\n    }\n\n    return (this.date as DateRange).from;\n  }\n\n  get to(): string | undefined {\n    if (!this.isRange) {\n      return;\n    }\n\n    return (this.date as DateRange).to;\n  }\n\n  get dateDisplay(): string {\n    const from = this.from ? moment(this.from).format('L') : '';\n    const to = this.to ? moment(this.to).format('L') : '';\n\n    return `${from} ${ to ? '- ' + to : '' }`;\n  }\n\n  ngOnInit(): void {\n  }\n\n  selectPeriod(period: Period) {\n    this.periods.forEach((period: Period) => period.selected = false);\n\n    this.date = period.getRange();\n    this.date.label = period.label;\n    this.isCustomRange = period.isCustomRange || false;\n    period.selected = true;\n\n    if (!this.isCustomRange) {\n      this.emitValue();\n    }\n  }\n\n  handleDateChange(value: DatePickerValue) {\n    this.date = value;\n\n    if (!this.isRange) {\n      this.emitValue();\n    }\n  }\n\n  emitValue() {\n    this.dateChange.emit(this.date);\n    this.onChange(this.date);\n    this.close.emit();\n  }\n\n  handleCancelClick() {\n    this.close.emit();\n  }\n\n  private getPeriodOrDefault(periodName: PeriodLabel, defaultPeriodName: PeriodLabel = PeriodLabel.TODAY) {\n    return this.periods.find(p => p.label === periodName) ||\n      this.periods.find(p => p.label === defaultPeriodName);\n  }\n\n  checkPeriodShouldBeSelectedByValue() {\n    if (!this.isRange) {\n      return;\n    }\n\n    this.periods.forEach((period: Period) => period.selected = false);\n    const period = this.periods.find(p => p.label === (this.date as DateRange)?.label);\n\n    if (!period) {\n      return;\n    }\n\n    period.selected = true;\n    this.isCustomRange = period.isCustomRange || false;\n  }\n\n  writeValue(value: DatePickerValue) {\n    if (this.isRange) {\n      const valueRange = value as DateRange;\n\n      if (valueRange.label && valueRange.label !== PeriodLabel.CUSTOM_PERIOD) {\n        const period = this.getPeriodOrDefault(valueRange.label)?.getRange() || {};\n        this.date = { ...period, label: valueRange.label };\n      }\n\n      else if (valueRange.from && valueRange.to) {\n        this.date = { from: valueRange.from, to: valueRange.to, label: PeriodLabel.CUSTOM_PERIOD };\n      }\n\n      this.checkPeriodShouldBeSelectedByValue();\n    }\n\n    else {\n      this.date = value;\n    }\n  }\n\n  registerOnChange(fn: (value: DatePickerValue) => void): void {\n    this.onChange = fn;\n  }\n\n  onChange = (value: DatePickerValue) => {};\n\n  registerOnTouched(fn: any): void {\n    this.onTouch = fn;\n  }\n\n  onTouch = () => {};\n}\n","<div class=\"date-picker-container\">\n  <main class=\"main-content\">\n    <div\n      class=\"periods-list\"\n      *ngIf=\"isRange\"\n      [ngClass]=\"{ 'show-divider': isCustomRange }\"\n    >\n      <button\n        *ngFor=\"let period of periods\"\n        type=\"button\"\n        class=\"period\"\n        [ngClass]=\"{ 'selected': period.selected }\"\n        (click)=\"selectPeriod(period)\"\n      >\n        {{ period.label.toString() | translate }}\n      </button>\n    </div>\n\n    <ask-date-picker-calendar\n      *ngIf=\"!isRange || (isRange && isCustomRange)\"\n      [date]=\"date\"\n      (dateChange)=\"handleDateChange($event)\"\n      [isRange]=\"isRange\"\n    ></ask-date-picker-calendar>\n  </main>\n\n  <footer class=\"footer\" *ngIf=\"isCustomRange && isRange\">\n    <div class=\"date-display\">{{ dateDisplay }}</div>\n\n    <div class=\"button-tray\">\n      <ask-button\n        [size]=\"'xsmall'\"\n        [type]=\"'secondary'\"\n        (click)=\"handleCancelClick()\"\n      >\n        {{ 'CANCEL' | translate }}\n      </ask-button>\n\n      <ask-button\n        [size]=\"'xsmall'\"\n        [type]=\"'primary'\"\n        (click)=\"emitValue()\"\n      >\n        {{ 'APPLY' | translate }}\n      </ask-button>\n    </div>\n  </footer>\n</div>\n"]}