asksuite-citrus 0.19.1 → 0.19.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -47,7 +47,6 @@ export class AutocompleteComponent {
47
47
  this._destroy = inject(DestroyRef);
48
48
  this.ITEMS_PER_PAGE = 40;
49
49
  this._pageNumber = 1;
50
- this._reachedEnd = false;
51
50
  this._selectAllMessage = '';
52
51
  this.multiple = false;
53
52
  this.valueProp = '';
@@ -71,7 +70,6 @@ export class AutocompleteComponent {
71
70
  ngOnChanges(changes) {
72
71
  if (changes['options']) {
73
72
  this._pageNumber = 1;
74
- this._reachedEnd = false;
75
73
  this.paginatedFilteredOptions = [];
76
74
  this.filteredOptions = changes['options'].currentValue;
77
75
  this.updateValidation();
@@ -80,7 +78,6 @@ export class AutocompleteComponent {
80
78
  handleInputChange() {
81
79
  this.inputControl.valueChanges.pipe(takeUntilDestroyed(this._destroy), debounceTime(300), tap(() => {
82
80
  this._pageNumber = 1;
83
- this._reachedEnd = false;
84
81
  this.paginatedFilteredOptions = [];
85
82
  }), map(value => this.filterFn ? this.filterFn(value || '') : [])).subscribe(items => {
86
83
  this.filteredOptions = items;
@@ -230,9 +227,6 @@ export class AutocompleteComponent {
230
227
  this.paginatedFilteredOptions = [...this.paginatedFilteredOptions, ...nextPageItems];
231
228
  this._pageNumber += 1;
232
229
  }
233
- else {
234
- this._reachedEnd = true;
235
- }
236
230
  this.updateValidation();
237
231
  this.change.detectChanges();
238
232
  }
@@ -329,4 +323,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImpor
329
323
  type: HostListener,
330
324
  args: ["window:mousedown", ['$event']]
331
325
  }] } });
332
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"autocomplete.component.js","sourceRoot":"","sources":["../../../../../../projects/asksuite-citrus/src/lib/components/autocomplete/autocomplete.component.ts","../../../../../../projects/asksuite-citrus/src/lib/components/autocomplete/autocomplete.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  DestroyRef,\n  ElementRef,\n  EventEmitter,\n  forwardRef,\n  HostListener,\n  inject,\n  Input,\n  OnChanges,\n  Output,\n  Provider,\n  SimpleChanges,\n  TemplateRef,\n  ViewChild,\n  ViewContainerRef\n} from '@angular/core';\nimport {ControlValueAccessor, FormBuilder, FormControl, FormGroup, NG_VALUE_ACCESSOR} from \"@angular/forms\";\nimport {debounceTime, map, tap} from \"rxjs\";\nimport {Overlay, OverlayRef} from \"@angular/cdk/overlay\";\nimport {TemplatePortal} from \"@angular/cdk/portal\";\nimport {takeUntilDestroyed} from \"@angular/core/rxjs-interop\";\nimport { TranslateService } from '@ngx-translate/core';\n\nconst valueAccessor: Provider = {\n  provide: NG_VALUE_ACCESSOR,\n  multi: true,\n  useExisting: forwardRef(() => AutocompleteComponent),\n}\n\n@Component({\n  selector: 'ask-autocomplete',\n  templateUrl: './autocomplete.component.html',\n  styleUrls: ['./autocomplete.component.scss'],\n  providers: [valueAccessor],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class AutocompleteComponent implements AfterViewInit, ControlValueAccessor, OnChanges {\n\n  @ViewChild(\"autocomplete\") input: ElementRef | undefined\n  @ViewChild(\"list\") list: ElementRef | undefined\n  @ViewChild(\"wrapper\") wrapper: ElementRef | undefined\n  @ViewChild('overlayContent') overlayContent: TemplateRef<any> | undefined\n\n  protected inputControl = new FormControl(\"\")\n  protected filteredOptions: any[] = [];\n  protected paginatedFilteredOptions: any[] = [];\n  protected selectedOption?: any;\n  protected selection: any[] = [];\n  protected closed = true;\n  protected chipsCollapsed = true\n  protected checkAllValue = false\n  protected disabled = false;\n  protected showChips = false;\n  protected showAllSelectionBtn = false;\n  protected showPlaceholder = false;\n  protected showExpandedSelectionActions = false;\n  protected showSelectAllCheckbox = false;\n  protected chipsContainerClasses = {\n    \"-two\": false,\n    \"-three\": false,\n    \"-four\": false,\n    \"-many\": false\n  };\n  protected optionsSelected: {[key: string | number]: boolean} = {}\n\n  private _overlayRef: OverlayRef | undefined;\n  private _portal: TemplatePortal<any> | undefined;\n  private _destroy = inject(DestroyRef)\n  private readonly ITEMS_PER_PAGE = 40\n  private _pageNumber = 1\n  private _reachedEnd = false;\n  _selectAllMessage = '';\n\n\n\n  @Input()\n  filterFn?: (item: string) => any[];\n\n  @Input()\n  displayFn?: (item: any) => string;\n\n  @Input()\n  multiple = false;\n\n  @Input()\n  valueProp: string = ''\n\n  @Input()\n  options: any[] = []\n\n  @Input()\n  placeholder = ''\n\n  @Input()\n  emptyMessage = 'NO_OPTIONS';\n\n  @Input()\n  selectAll = false\n\n  @Input()\n  allOptionsSelectedText: string | null = null;\n\n  @Input()\n  selectAllMessage = this.translate.instant('SELECT_ALL');\n  \n  @Input()\n  iconPropReference?: string;\n\n  @Output()\n  itemCheck = new EventEmitter();\n\n  constructor(private formBuilder: FormBuilder,\n              private overlay: Overlay,\n              private viewContainerRef: ViewContainerRef,\n              private change: ChangeDetectorRef,\n              private translate: TranslateService) {\n  }\n\n  ngAfterViewInit() {\n    this.checkAllValue = this.isAllOptionsSelected\n    this.handleInputChange();\n  }\n\n  get isAllOptionsSelected() {\n    return this.selection.length === this.options.length\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes['options']) {\n      this._pageNumber = 1\n      this._reachedEnd = false\n      this.paginatedFilteredOptions = []\n\n      this.filteredOptions = changes['options'].currentValue\n      this.updateValidation()\n    }\n  }\n\n  private handleInputChange() {\n    this.inputControl.valueChanges.pipe(\n      takeUntilDestroyed(this._destroy),\n      debounceTime(300),\n      tap(() => {\n        this._pageNumber = 1\n        this._reachedEnd = false\n        this.paginatedFilteredOptions = []\n      }),\n      map(value => this.filterFn ? this.filterFn(value || '') : [])\n    ).subscribe(items => {\n      this.filteredOptions = items\n      this.getMoreItems()\n    })\n  }\n\n  private handleSelectionChange(values: any[]) {\n    this.selection = values\n    this.checkAllValue = this.isAllOptionsSelected\n\n    if (!this.chipsCollapsed) {\n      this.chipsCollapsed = this.selection.length < 2\n    }\n    this.updateValidation()\n    this.change.detectChanges()\n  }\n\n  private updateChipsContainerClasses() {\n    this.chipsContainerClasses = {\n      \"-two\": this.selectedOptions.length === 2,\n      \"-three\": this.selectedOptions.length === 3,\n      \"-four\": this.selectedOptions.length === 4,\n      \"-many\": this.selectedOptions.length >= 5\n    }\n  }\n\n  handleOptionSelected(item: any) {\n    this.selectedOption = item;\n    this.onChange(this.selectedOption)\n    this.hideOptions()\n    this.change.detectChanges();\n  }\n\n  handleAutocompleteClick(event?: Event) {\n    event?.stopPropagation()\n    if (!this.disabled) {\n      this.chipsCollapsed = true;\n      this.closed\n        ? this.showOptions()\n        : this.hideOptions()\n    }\n    this.updateValidation();\n    this.updateChipsContainerClasses()\n    this.change.detectChanges()\n  }\n\n  protected handleChipsListActionClick(event: Event) {\n    event.stopPropagation()\n    this.chipsCollapsed = !this.chipsCollapsed;\n    this.updateValidation()\n    this.updateChipsContainerClasses()\n    this.change.detectChanges()\n  }\n\n  showOptions() {\n    this.closed = false\n    if (!this._overlayRef && this.wrapper) {\n      this._overlayRef = this.getOverlayConfig(this.wrapper)\n\n      this._portal = new TemplatePortal(this.overlayContent!, this.viewContainerRef)\n    }\n\n    this._overlayRef?.attach(this._portal);\n\n    this.updateValidation();\n    if (this.paginatedFilteredOptions.length === 0) this.getMoreItems()\n  }\n\n  private getOverlayConfig(wrapper: ElementRef) {\n    return this.overlay.create({\n      width: wrapper.nativeElement.offsetWidth,\n      positionStrategy: this.overlay.position()\n        .flexibleConnectedTo(wrapper.nativeElement)\n        .withPositions([{\n          originX: \"start\",\n          originY: \"bottom\",\n          overlayX: \"start\",\n          overlayY: \"top\"\n        }])\n    });\n  }\n\n  hideOptions() {\n    this.closed = true;\n    this.chipsCollapsed = true;\n    this._overlayRef?.detach()\n    this.change.detectChanges()\n    this._pageNumber = 1;\n    this.paginatedFilteredOptions = [];\n    this.updateValidation();\n    this.change.detectChanges()\n  }\n\n  @HostListener(\"window:mousedown\", ['$event'])\n  handleClick(event: MouseEvent) {\n    if (\n      !this.closed\n      && !this.wrapper?.nativeElement.contains(event.target)\n      && !this.list?.nativeElement.contains(event.target)) {\n      this.hideOptions()\n      this.change.detectChanges()\n    }\n  }\n\n  get selectedOptions(): any[] {\n    if (!this.multiple) return this.selectedOption ? [this.selectedOption] : []\n\n    return this.chipsCollapsed\n      ? this.selection.slice(0, 1)\n      : this.selection;\n  }\n\n  handleSelectAll(checked: boolean) {\n    this.selectAllOptions(checked);\n    this.selection = checked ? this.options : []\n    this.onChange(this.selection)\n    this.updateValidation()\n    this.change.detectChanges()\n    this.itemCheck.emit(this.selection);\n  }\n\n  valueChange(option: any, value: boolean) {\n    this.optionsSelected[option[this.valueProp]] = value\n    this.selection = this.options.filter(o => this.optionsSelected[o[this.valueProp]])\n    this.checkAllValue = this.selection.length === this.options.length\n    this.onChange(this.selection)\n    this.onTouched()\n\n    this.updateChipsContainerClasses()\n    this.updateValidation();\n    this.change.detectChanges();\n    this.itemCheck.emit(this.selection);\n  }\n\n  selectAllOptions(selected: boolean) {\n    this.optionsSelected = this.options\n      .reduce((acc, curr) => {\n        acc[curr[this.valueProp]] = selected\n        return acc;\n      }, {} as { [key: string]: boolean })\n  }\n\n  handleChipAction(option: any) {\n    if (this.multiple) {\n      this.optionsSelected[option[this.valueProp]] = false\n      this.selection = this.selection.filter(selectedOption =>\n        selectedOption[this.valueProp] !== option[this.valueProp])\n      this.onChange(this.selection)\n    } else {\n      this.selectedOption = null;\n      this.onChange([])\n    }\n\n    this.updateChipsContainerClasses()\n    this.updateValidation();\n    this.change.detectChanges();\n  }\n\n  display(option: any) {\n    return this.displayFn && this.displayFn(option)\n  }\n\n  getMoreItems() {\n    const sortedFilteredOptions = [...this.filteredOptions];\n\n    this.sortSelectedFirst(sortedFilteredOptions, this.selection, this.valueProp)\n    const nextPageItems = sortedFilteredOptions\n      .slice(\n        this.ITEMS_PER_PAGE * (this._pageNumber - 1),\n        this.ITEMS_PER_PAGE * this._pageNumber\n      );\n\n    if (nextPageItems.length) {\n      this.paginatedFilteredOptions = [...this.paginatedFilteredOptions, ...nextPageItems];\n      this._pageNumber += 1\n    } else {\n      this._reachedEnd = true\n    }\n    this.updateValidation();\n    this.change.detectChanges()\n  }\n\n  sortSelectedFirst(items: Array<any>, selectedItems: Array<any>, prop: string) {\n    items.sort((a, b) => {\n      const aIsSelected = selectedItems.some(item => item[prop] === a[prop]);\n      const bIsSelected = selectedItems.some(item => item[prop] === b[prop]);\n\n      if (aIsSelected && !bIsSelected) {\n        return -1;\n      } else if (!aIsSelected && bIsSelected) {\n        return 1;\n      } else {\n        return 0;\n      }\n    });\n  }\n\n  protected updateValidation() {\n    this.checkAllValue = this.isAllOptionsSelected\n    this.showChips = Boolean(this.selectedOptions.length) && this.closed && (\n      !this.multiple || !this.checkAllValue || (this.checkAllValue && !Boolean(this.allOptionsSelectedText))\n    );\n    this.showAllSelectionBtn = this.multiple && Boolean(this.selection.length > 1) && this.chipsCollapsed;\n    this.showPlaceholder = this.closed && (\n      !this.selectedOptions.length || (this.checkAllValue && Boolean(this.allOptionsSelectedText) && this.multiple)\n    );\n    this.showExpandedSelectionActions = this.multiple && !this.chipsCollapsed;\n    this.showSelectAllCheckbox = Boolean(this.paginatedFilteredOptions.length) && this.selectAll;\n  }\n\n  // Control Value Accessor\n\n  writeValue(obj: any[] | any): void {\n    this.selection = [];\n\n    if (this.multiple && Array.isArray(obj)) {\n      this.optionsSelected = {}\n      obj.forEach(option => this.optionsSelected[option[this.valueProp]] = true)\n    } else {\n      this.selectedOption = obj\n    }\n\n    if (this.multiple) {\n      this.handleSelectionChange(obj)\n    }\n\n    this.change.detectChanges();\n  }\n\n  onChange = (_: any) => {}\n\n  registerOnChange(fn: any): void {\n    this.onChange = fn;\n  }\n\n  onTouched = () => {}\n\n  registerOnTouched(fn: any): void {\n    this.onTouched = fn;\n  }\n\n  setDisabledState(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n  }\n}\n","<div\n  class=\"autocomplete-wrapper\"\n  data-testid=\"autocomplete-wrapper\"\n  [class.-closed]=\"closed\"\n  [class.-opened]=\"!closed\"\n  #wrapper\n  (click)=\"handleAutocompleteClick()\"\n>\n  <div class=\"autocomplete\" #autocomplete>\n    <input\n      class=\"search-field\"\n      askAutofocus\n      *ngIf=\"!closed; else selectionOrPlaceholder\"\n      (click)=\"$event.stopPropagation()\"\n      [formControl]=\"inputControl\"\n      [placeholder]=\"placeholder\"\n    />\n    <ng-template #selectionOrPlaceholder>\n      <ng-container *ngIf=\"showChips\">\n        <div\n          class=\"chip-list\"\n          [class.-collapsed]=\"chipsCollapsed\"\n          [ngClass]=\"chipsContainerClasses\"\n        >\n          <ask-chips\n            [style.max-width]=\"chipsCollapsed ? '85%' : '95%'\"\n            [showAction]=\"true\"\n            *ngFor=\"let option of selectedOptions\"\n            (action)=\"handleChipAction(option)\"\n          >\n            {{ display(option) }}\n          </ask-chips>\n          <span\n            class=\"expand\"\n            data-testid=\"see-more\"\n            *ngIf=\"showAllSelectionBtn\"\n            (click)=\"handleChipsListActionClick($event)\"\n          >\n            +{{ selection.length - 1 }}\n          </span>\n        </div>\n      </ng-container>\n      <span\n        class=\"empty-placeholder\"\n        data-testid=\"placeholder\"\n        *ngIf=\"showPlaceholder\"\n      >\n        {{\n          checkAllValue && allOptionsSelectedText\n            ? allOptionsSelectedText\n            : placeholder\n        }}\n      </span>\n    </ng-template>\n    <span\n      class=\"btn-expand material-icons\"\n      data-testid=\"btn-expand\"\n      [class.-disabled]=\"disabled\"\n      *ngIf=\"chipsCollapsed\"\n    >\n      {{ closed ? \"expand_more\" : \"expand_less\" }}\n    </span>\n  </div>\n  <div class=\"actions\" *ngIf=\"showExpandedSelectionActions\">\n    <span\n      class=\"see-more\"\n      data-testid=\"see-less\"\n      (click)=\"handleChipsListActionClick($event)\"\n    >\n      {{ \"SEE_LESS\" | translate }}\n    </span>\n    <span\n      class=\"btn-expand material-icons\"\n      data-testid=\"btn-expand\"\n      [class.-disabled]=\"disabled\"\n    >\n      {{ closed ? \"expand_more\" : \"expand_less\" }}\n    </span>\n  </div>\n</div>\n\n<ng-template #overlayContent>\n  <div #list class=\"menu-container\" [class.-multiple]=\"multiple\">\n    <ng-container *ngIf=\"!multiple; else multipleSelection\">\n      <div class=\"list\" askScroll [askScrollThreshold]=\"50\">\n        <ng-container *ngFor=\"let option of paginatedFilteredOptions\">\n          <div\n            class=\"option-item\"\n            [class.-highlighted]=\"\n              selectedOption && selectedOption[valueProp] === option[valueProp]\n            \"\n            (click)=\"handleOptionSelected(option)\"\n          >\n            <p class=\"text\">{{ display(option) }}</p>\n          </div>\n        </ng-container>\n      </div>\n    </ng-container>\n    <ng-template #multipleSelection>\n      <div class=\"option-item\" *ngIf=\"showSelectAllCheckbox\">\n        <ask-checkbox\n          (valueChange)=\"handleSelectAll($event)\"\n          [(ngModel)]=\"checkAllValue\"\n          >{{selectAllMessage}}</ask-checkbox\n        >\n      </div>\n      <div\n        askScroll\n        [askScrollThreshold]=\"50\"\n        (scrollEnd)=\"getMoreItems()\"\n        data-testid=\"options-form\"\n        class=\"options-form\"\n        [class.-select-all]=\"showSelectAllCheckbox\"\n      >\n        <ng-container *ngFor=\"let option of paginatedFilteredOptions\">\n          <div class=\"option-item\">\n            <ask-checkbox\n              [value]=\"optionsSelected[option[valueProp]]\"\n              (valueChange)=\"valueChange(option, $event)\"\n            >\n              <div class=\"checkbox-content\">\n                <img\n                  data-testid=\"checkbox-item-icon\"\n                  class=\"icon\"\n                  *ngIf=\"iconPropReference\"\n                  [src]=\"option[iconPropReference]\"\n                  alt=\"\"\n                />\n                {{ display(option) }}\n              </div>\n            </ask-checkbox>\n          </div>\n        </ng-container>\n      </div>\n    </ng-template>\n    <span class=\"empty\" *ngIf=\"!filteredOptions.length\">{{\n      emptyMessage | translate\n    }}</span>\n  </div>\n</ng-template>\n"]}
326
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"autocomplete.component.js","sourceRoot":"","sources":["../../../../../../projects/asksuite-citrus/src/lib/components/autocomplete/autocomplete.component.ts","../../../../../../projects/asksuite-citrus/src/lib/components/autocomplete/autocomplete.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  DestroyRef,\n  ElementRef,\n  EventEmitter,\n  forwardRef,\n  HostListener,\n  inject,\n  Input,\n  OnChanges,\n  Output,\n  Provider,\n  SimpleChanges,\n  TemplateRef,\n  ViewChild,\n  ViewContainerRef\n} from '@angular/core';\nimport {ControlValueAccessor, FormBuilder, FormControl, NG_VALUE_ACCESSOR} from \"@angular/forms\";\nimport {debounceTime, map, tap} from \"rxjs\";\nimport {Overlay, OverlayRef} from \"@angular/cdk/overlay\";\nimport {TemplatePortal} from \"@angular/cdk/portal\";\nimport {takeUntilDestroyed} from \"@angular/core/rxjs-interop\";\nimport { TranslateService } from '@ngx-translate/core';\n\nconst valueAccessor: Provider = {\n  provide: NG_VALUE_ACCESSOR,\n  multi: true,\n  useExisting: forwardRef(() => AutocompleteComponent),\n}\n\n@Component({\n  selector: 'ask-autocomplete',\n  templateUrl: './autocomplete.component.html',\n  styleUrls: ['./autocomplete.component.scss'],\n  providers: [valueAccessor],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class AutocompleteComponent implements AfterViewInit, ControlValueAccessor, OnChanges {\n\n  @ViewChild(\"autocomplete\") input: ElementRef | undefined\n  @ViewChild(\"list\") list: ElementRef | undefined\n  @ViewChild(\"wrapper\") wrapper: ElementRef | undefined\n  @ViewChild('overlayContent') overlayContent: TemplateRef<any> | undefined\n\n  protected inputControl = new FormControl(\"\")\n  protected filteredOptions: any[] = [];\n  protected paginatedFilteredOptions: any[] = [];\n  protected selectedOption?: any;\n  protected selection: any[] = [];\n  protected closed = true;\n  protected chipsCollapsed = true\n  protected checkAllValue = false\n  protected disabled = false;\n  protected showChips = false;\n  protected showAllSelectionBtn = false;\n  protected showPlaceholder = false;\n  protected showExpandedSelectionActions = false;\n  protected showSelectAllCheckbox = false;\n  protected chipsContainerClasses = {\n    \"-two\": false,\n    \"-three\": false,\n    \"-four\": false,\n    \"-many\": false\n  };\n  protected optionsSelected: {[key: string | number]: boolean} = {}\n\n  private _overlayRef: OverlayRef | undefined;\n  private _portal: TemplatePortal<any> | undefined;\n  private _destroy = inject(DestroyRef)\n  private readonly ITEMS_PER_PAGE = 40\n  private _pageNumber = 1\n  _selectAllMessage = '';\n\n\n\n  @Input()\n  filterFn?: (item: string) => any[];\n\n  @Input()\n  displayFn?: (item: any) => string;\n\n  @Input()\n  multiple = false;\n\n  @Input()\n  valueProp: string = ''\n\n  @Input()\n  options: any[] = []\n\n  @Input()\n  placeholder = ''\n\n  @Input()\n  emptyMessage = 'NO_OPTIONS';\n\n  @Input()\n  selectAll = false\n\n  @Input()\n  allOptionsSelectedText: string | null = null;\n\n  @Input()\n  selectAllMessage = this.translate.instant('SELECT_ALL');\n  \n  @Input()\n  iconPropReference?: string;\n\n  @Output()\n  itemCheck = new EventEmitter();\n\n  constructor(private formBuilder: FormBuilder,\n              private overlay: Overlay,\n              private viewContainerRef: ViewContainerRef,\n              private change: ChangeDetectorRef,\n              private translate: TranslateService) {\n  }\n\n  ngAfterViewInit() {\n    this.checkAllValue = this.isAllOptionsSelected\n    this.handleInputChange();\n  }\n\n  get isAllOptionsSelected() {\n    return this.selection.length === this.options.length\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes['options']) {\n      this._pageNumber = 1\n      this.paginatedFilteredOptions = []\n\n      this.filteredOptions = changes['options'].currentValue\n      this.updateValidation()\n    }\n  }\n\n  private handleInputChange() {\n    this.inputControl.valueChanges.pipe(\n      takeUntilDestroyed(this._destroy),\n      debounceTime(300),\n      tap(() => {\n        this._pageNumber = 1\n        this.paginatedFilteredOptions = []\n      }),\n      map(value => this.filterFn ? this.filterFn(value || '') : [])\n    ).subscribe(items => {\n      this.filteredOptions = items\n      this.getMoreItems()\n    })\n  }\n\n  private handleSelectionChange(values: any[]) {\n    this.selection = values\n    this.checkAllValue = this.isAllOptionsSelected\n\n    if (!this.chipsCollapsed) {\n      this.chipsCollapsed = this.selection.length < 2\n    }\n    this.updateValidation()\n    this.change.detectChanges()\n  }\n\n  private updateChipsContainerClasses() {\n    this.chipsContainerClasses = {\n      \"-two\": this.selectedOptions.length === 2,\n      \"-three\": this.selectedOptions.length === 3,\n      \"-four\": this.selectedOptions.length === 4,\n      \"-many\": this.selectedOptions.length >= 5\n    }\n  }\n\n  handleOptionSelected(item: any) {\n    this.selectedOption = item;\n    this.onChange(this.selectedOption)\n    this.hideOptions()\n    this.change.detectChanges();\n  }\n\n  handleAutocompleteClick(event?: Event) {\n    event?.stopPropagation()\n    if (!this.disabled) {\n      this.chipsCollapsed = true;\n      this.closed\n        ? this.showOptions()\n        : this.hideOptions()\n    }\n    this.updateValidation();\n    this.updateChipsContainerClasses()\n    this.change.detectChanges()\n  }\n\n  protected handleChipsListActionClick(event: Event) {\n    event.stopPropagation()\n    this.chipsCollapsed = !this.chipsCollapsed;\n    this.updateValidation()\n    this.updateChipsContainerClasses()\n    this.change.detectChanges()\n  }\n\n  showOptions() {\n    this.closed = false\n    if (!this._overlayRef && this.wrapper) {\n      this._overlayRef = this.getOverlayConfig(this.wrapper)\n\n      this._portal = new TemplatePortal(this.overlayContent!, this.viewContainerRef)\n    }\n\n    this._overlayRef?.attach(this._portal);\n\n    this.updateValidation();\n    if (this.paginatedFilteredOptions.length === 0) this.getMoreItems()\n  }\n\n  private getOverlayConfig(wrapper: ElementRef) {\n    return this.overlay.create({\n      width: wrapper.nativeElement.offsetWidth,\n      positionStrategy: this.overlay.position()\n        .flexibleConnectedTo(wrapper.nativeElement)\n        .withPositions([{\n          originX: \"start\",\n          originY: \"bottom\",\n          overlayX: \"start\",\n          overlayY: \"top\"\n        }])\n    });\n  }\n\n  hideOptions() {\n    this.closed = true;\n    this.chipsCollapsed = true;\n    this._overlayRef?.detach()\n    this.change.detectChanges()\n    this._pageNumber = 1;\n    this.paginatedFilteredOptions = [];\n    this.updateValidation();\n    this.change.detectChanges()\n  }\n\n  @HostListener(\"window:mousedown\", ['$event'])\n  handleClick(event: MouseEvent) {\n    if (\n      !this.closed\n      && !this.wrapper?.nativeElement.contains(event.target)\n      && !this.list?.nativeElement.contains(event.target)) {\n      this.hideOptions()\n      this.change.detectChanges()\n    }\n  }\n\n  get selectedOptions(): any[] {\n    if (!this.multiple) return this.selectedOption ? [this.selectedOption] : []\n\n    return this.chipsCollapsed\n      ? this.selection.slice(0, 1)\n      : this.selection;\n  }\n\n  handleSelectAll(checked: boolean) {\n    this.selectAllOptions(checked);\n    this.selection = checked ? this.options : []\n    this.onChange(this.selection)\n    this.updateValidation()\n    this.change.detectChanges()\n    this.itemCheck.emit(this.selection);\n  }\n\n  valueChange(option: any, value: boolean) {\n    this.optionsSelected[option[this.valueProp]] = value\n    this.selection = this.options.filter(o => this.optionsSelected[o[this.valueProp]])\n    this.checkAllValue = this.selection.length === this.options.length\n    this.onChange(this.selection)\n    this.onTouched()\n\n    this.updateChipsContainerClasses()\n    this.updateValidation();\n    this.change.detectChanges();\n    this.itemCheck.emit(this.selection);\n  }\n\n  selectAllOptions(selected: boolean) {\n    this.optionsSelected = this.options\n      .reduce((acc, curr) => {\n        acc[curr[this.valueProp]] = selected\n        return acc;\n      }, {} as { [key: string]: boolean })\n  }\n\n  handleChipAction(option: any) {\n    if (this.multiple) {\n      this.optionsSelected[option[this.valueProp]] = false\n      this.selection = this.selection.filter(selectedOption =>\n        selectedOption[this.valueProp] !== option[this.valueProp])\n      this.onChange(this.selection)\n    } else {\n      this.selectedOption = null;\n      this.onChange([])\n    }\n\n    this.updateChipsContainerClasses()\n    this.updateValidation();\n    this.change.detectChanges();\n  }\n\n  display(option: any) {\n    return this.displayFn && this.displayFn(option)\n  }\n\n  getMoreItems() {\n    const sortedFilteredOptions = [...this.filteredOptions];\n\n    this.sortSelectedFirst(sortedFilteredOptions, this.selection, this.valueProp)\n    const nextPageItems = sortedFilteredOptions\n      .slice(\n        this.ITEMS_PER_PAGE * (this._pageNumber - 1),\n        this.ITEMS_PER_PAGE * this._pageNumber\n      );\n\n    if (nextPageItems.length) {\n      this.paginatedFilteredOptions = [...this.paginatedFilteredOptions, ...nextPageItems];\n      this._pageNumber += 1\n    }\n    this.updateValidation();\n    this.change.detectChanges()\n  }\n\n  sortSelectedFirst(items: Array<any>, selectedItems: Array<any>, prop: string) {\n    items.sort((a, b) => {\n      const aIsSelected = selectedItems.some(item => item[prop] === a[prop]);\n      const bIsSelected = selectedItems.some(item => item[prop] === b[prop]);\n\n      if (aIsSelected && !bIsSelected) {\n        return -1;\n      } else if (!aIsSelected && bIsSelected) {\n        return 1;\n      } else {\n        return 0;\n      }\n    });\n  }\n\n  protected updateValidation() {\n    this.checkAllValue = this.isAllOptionsSelected\n    this.showChips = Boolean(this.selectedOptions.length) && this.closed && (\n      !this.multiple || !this.checkAllValue || (this.checkAllValue && !Boolean(this.allOptionsSelectedText))\n    );\n    this.showAllSelectionBtn = this.multiple && Boolean(this.selection.length > 1) && this.chipsCollapsed;\n    this.showPlaceholder = this.closed && (\n      !this.selectedOptions.length || (this.checkAllValue && Boolean(this.allOptionsSelectedText) && this.multiple)\n    );\n    this.showExpandedSelectionActions = this.multiple && !this.chipsCollapsed;\n    this.showSelectAllCheckbox = Boolean(this.paginatedFilteredOptions.length) && this.selectAll;\n  }\n\n  // Control Value Accessor\n\n  writeValue(obj: any[] | any): void {\n    this.selection = [];\n    if (this.multiple && Array.isArray(obj)) {\n      this.optionsSelected = {}\n      obj.forEach(option => this.optionsSelected[option[this.valueProp]] = true)\n    } else {\n      this.selectedOption = obj\n    }\n\n    if (this.multiple) {\n      this.handleSelectionChange(obj)\n    }\n\n    this.change.detectChanges();\n  }\n\n  onChange = (_: any) => {}\n\n  registerOnChange(fn: any): void {\n    this.onChange = fn;\n  }\n\n  onTouched = () => {}\n\n  registerOnTouched(fn: any): void {\n    this.onTouched = fn;\n  }\n\n  setDisabledState(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n  }\n}\n","<div\n  class=\"autocomplete-wrapper\"\n  data-testid=\"autocomplete-wrapper\"\n  [class.-closed]=\"closed\"\n  [class.-opened]=\"!closed\"\n  #wrapper\n  (click)=\"handleAutocompleteClick()\"\n>\n  <div class=\"autocomplete\" #autocomplete>\n    <input\n      class=\"search-field\"\n      askAutofocus\n      *ngIf=\"!closed; else selectionOrPlaceholder\"\n      (click)=\"$event.stopPropagation()\"\n      [formControl]=\"inputControl\"\n      [placeholder]=\"placeholder\"\n    />\n    <ng-template #selectionOrPlaceholder>\n      <ng-container *ngIf=\"showChips\">\n        <div\n          class=\"chip-list\"\n          [class.-collapsed]=\"chipsCollapsed\"\n          [ngClass]=\"chipsContainerClasses\"\n        >\n          <ask-chips\n            [style.max-width]=\"chipsCollapsed ? '85%' : '95%'\"\n            [showAction]=\"true\"\n            *ngFor=\"let option of selectedOptions\"\n            (action)=\"handleChipAction(option)\"\n          >\n            {{ display(option) }}\n          </ask-chips>\n          <span\n            class=\"expand\"\n            data-testid=\"see-more\"\n            *ngIf=\"showAllSelectionBtn\"\n            (click)=\"handleChipsListActionClick($event)\"\n          >\n            +{{ selection.length - 1 }}\n          </span>\n        </div>\n      </ng-container>\n      <span\n        class=\"empty-placeholder\"\n        data-testid=\"placeholder\"\n        *ngIf=\"showPlaceholder\"\n      >\n        {{\n          checkAllValue && allOptionsSelectedText\n            ? allOptionsSelectedText\n            : placeholder\n        }}\n      </span>\n    </ng-template>\n    <span\n      class=\"btn-expand material-icons\"\n      data-testid=\"btn-expand\"\n      [class.-disabled]=\"disabled\"\n      *ngIf=\"chipsCollapsed\"\n    >\n      {{ closed ? \"expand_more\" : \"expand_less\" }}\n    </span>\n  </div>\n  <div class=\"actions\" *ngIf=\"showExpandedSelectionActions\">\n    <span\n      class=\"see-more\"\n      data-testid=\"see-less\"\n      (click)=\"handleChipsListActionClick($event)\"\n    >\n      {{ \"SEE_LESS\" | translate }}\n    </span>\n    <span\n      class=\"btn-expand material-icons\"\n      data-testid=\"btn-expand\"\n      [class.-disabled]=\"disabled\"\n    >\n      {{ closed ? \"expand_more\" : \"expand_less\" }}\n    </span>\n  </div>\n</div>\n\n<ng-template #overlayContent>\n  <div #list class=\"menu-container\" [class.-multiple]=\"multiple\">\n    <ng-container *ngIf=\"!multiple; else multipleSelection\">\n      <div class=\"list\" askScroll [askScrollThreshold]=\"50\">\n        <ng-container *ngFor=\"let option of paginatedFilteredOptions\">\n          <div\n            class=\"option-item\"\n            [class.-highlighted]=\"\n              selectedOption && selectedOption[valueProp] === option[valueProp]\n            \"\n            (click)=\"handleOptionSelected(option)\"\n          >\n            <p class=\"text\">{{ display(option) }}</p>\n          </div>\n        </ng-container>\n      </div>\n    </ng-container>\n    <ng-template #multipleSelection>\n      <div class=\"option-item\" *ngIf=\"showSelectAllCheckbox\">\n        <ask-checkbox\n          (valueChange)=\"handleSelectAll($event)\"\n          [(ngModel)]=\"checkAllValue\"\n          >{{selectAllMessage}}</ask-checkbox\n        >\n      </div>\n      <div\n        askScroll\n        [askScrollThreshold]=\"50\"\n        (scrollEnd)=\"getMoreItems()\"\n        data-testid=\"options-form\"\n        class=\"options-form\"\n        [class.-select-all]=\"showSelectAllCheckbox\"\n      >\n        <ng-container *ngFor=\"let option of paginatedFilteredOptions\">\n          <div class=\"option-item\">\n            <ask-checkbox\n              [value]=\"optionsSelected[option[valueProp]]\"\n              (valueChange)=\"valueChange(option, $event)\"\n            >\n              <div class=\"checkbox-content\">\n                <img\n                  data-testid=\"checkbox-item-icon\"\n                  class=\"icon\"\n                  *ngIf=\"iconPropReference\"\n                  [src]=\"option[iconPropReference]\"\n                  alt=\"\"\n                />\n                {{ display(option) }}\n              </div>\n            </ask-checkbox>\n          </div>\n        </ng-container>\n      </div>\n    </ng-template>\n    <span class=\"empty\" *ngIf=\"!filteredOptions.length\">{{\n      emptyMessage | translate\n    }}</span>\n  </div>\n</ng-template>\n"]}
@@ -23,9 +23,6 @@ export class DatePickerCalendarComponent {
23
23
  this._weekDays = [];
24
24
  this._days = [];
25
25
  }
26
- get shouldDisableNextMonth() {
27
- return this.isFutureDate(this.displayDate.clone().add(1, 'month').unix());
28
- }
29
26
  get days() {
30
27
  return this._days;
31
28
  }
@@ -175,34 +172,31 @@ export class DatePickerCalendarComponent {
175
172
  }
176
173
  selectDate(timestamp) {
177
174
  const momentDate = moment.unix(timestamp);
178
- if (this.isRange) {
179
- this.handleRangeSelect(momentDate);
180
- }
181
- else {
182
- this.handleSingleSelect(momentDate);
183
- }
175
+ if (this.isRange)
176
+ return this.handleRangeSelect(momentDate);
177
+ this.handleSingleSelect(momentDate);
184
178
  }
185
179
  handleRangeSelect(selectedDate) {
186
180
  const innerDate = this.innerDate;
187
- // First selection
188
181
  if (!innerDate.from) {
182
+ // First selection
189
183
  innerDate.from = this.getDayFromMoment(selectedDate);
190
184
  }
191
- // Second selection
192
185
  else if (!innerDate.to) {
186
+ // Second selection
193
187
  const actualFrom = moment.unix(innerDate.from.timestamp);
194
- // Selected date is past the previous selected date
195
188
  if (selectedDate.isBefore(actualFrom, 'day')) {
189
+ // Selected date is past the previous selected date
196
190
  innerDate.to = innerDate.from;
197
191
  innerDate.from = this.getDayFromMoment(selectedDate);
198
192
  }
199
- // Selected date is future of the previous selected date
200
193
  else {
194
+ // Selected date is future of the previous selected date
201
195
  innerDate.to = this.getDayFromMoment(selectedDate);
202
196
  }
203
197
  }
204
- // Selection when both from and to are already selected
205
198
  else {
199
+ // Selection when both from and to are already selected
206
200
  innerDate.from = this.getDayFromMoment(selectedDate);
207
201
  innerDate.to = undefined;
208
202
  }
@@ -215,6 +209,8 @@ export class DatePickerCalendarComponent {
215
209
  newRange.from = this.getDateFromDay(range.from);
216
210
  if (range.to)
217
211
  newRange.to = formatTo(moment.unix(range.to.timestamp));
212
+ else
213
+ newRange.to = formatTo(moment.unix(range.from.timestamp));
218
214
  }
219
215
  this.dateChange.emit(newRange);
220
216
  }
@@ -230,11 +226,11 @@ export class DatePickerCalendarComponent {
230
226
  return date.isAfter(now);
231
227
  }
232
228
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: DatePickerCalendarComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
233
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.6", type: DatePickerCalendarComponent, selector: "ask-date-picker-calendar", inputs: { isRange: "isRange", disableFutureDate: "disableFutureDate", 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\n type=\"button\"\n class=\"selector-button\"\n [disabled]=\"shouldDisableNextMonth\"\n (click)=\"incrementMonth(1)\"\n >\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 <button\n *ngFor=\"let day of days\"\n (click)=\"selectDate(day.timestamp)\"\n [disabled]=\"day.isFuture\"\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 </button>\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}.scale-in-center{animation:scale-in-center .3s ease-in-out both}@keyframes scale-in-center{0%{transform:scale(0);opacity:1}to{transform:scale(1);opacity:1}}.scale-out-center{animation:scale-out-center .3s ease-in-out both}@keyframes scale-out-center{0%{transform:scale(1);opacity:1}to{transform:scale(0);opacity:1}}.ask-tooltip{background-color:#7b8794;color:#fff;padding:4px;border-radius:8px;position:relative}.ask-tooltip>div{text-align:center!important}.ask-tooltip:after{position:absolute;content:\"\";width:10px;height:10px;background-color:inherit}.ask-tooltip.-above{margin-bottom:4px}.ask-tooltip.-above:after{bottom:-5px;left:50%;transform:translate(-50%) rotate(45deg)}.ask-tooltip.-below{margin-top:4px}.ask-tooltip.-below:after{top:-5px;left:50%;transform:translate(-50%) rotate(45deg)}.ask-tooltip.-after,.ask-tooltip.-right{margin-left:4px}.ask-tooltip.-after:after,.ask-tooltip.-right:after{left:-5px;top:50%;transform:translateY(-50%) rotate(45deg)}.ask-tooltip.-before,.ask-tooltip.-left{margin-right:4px}.ask-tooltip.-before:after,.ask-tooltip.-left:after{right:-5px;top:50%;transform:translateY(-50%) rotate(45deg)}.ask-button{padding:8px 24px;border-radius:6px;border:none;outline:none;height:48px;font-size:1rem;transition:background-color .1s,box-shadow .1s;cursor:pointer;font-weight:500;background:white;color:var(--grey-500)}.ask-button:not(.-primary,.-secondary){box-shadow:0 1px 2px #2a304229}.ask-button:not(.-primary):hover:not(:disabled){box-shadow:0 0 6px #2a304229}.ask-button:hover:not(:disabled){box-shadow:0 0 6px #ff572466}.ask-button:active:not(:disabled){background-color:#f34915}.ask-button:disabled{cursor:not-allowed;background-color:#9aa5b1}.ask-button.-primary{background:#FF5724;color:#fff}.ask-modal-header{display:block;position:relative;flex-shrink:0;box-sizing:border-box;margin:0 0 1px;padding:0 24px 9px}.ask-modal-body{flex-grow:1;box-sizing:border-box;margin:0;overflow:auto;padding:20px 24px;max-height:65vh;display:block}.ask-modal-footer{display:flex;position:relative;flex-shrink:0;flex-wrap:wrap;align-items:center;justify-content:flex-end;box-sizing:border-box;min-height:52px;margin:0;padding:8px;border-top:1px solid rgba(0,0,0,0)}.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}.ask-badge{position:relative}.ask-badge>.badge{position:absolute;display:flex;justify-content:center;align-items:center;background-color:var(--bg-color);color:#fff;font-size:12px;text-overflow:ellipsis;white-space:nowrap;overflow:hidden;border-radius:50%;box-shadow:0 2px 6px -1px #00000080}.ask-badge>.badge.-primary{--bg-color: var(--asksuite-orange)}.ask-badge>.badge.-secondary{--bg-color: var(--grey-800)}.ask-badge>.badge.-top{top:-10px}.ask-badge>.badge.-bottom{bottom:-10px}.ask-badge>.badge.-left{left:-10px}.ask-badge>.badge.-right{right:-10px}.ask-badge>.badge.-small{width:18px;height:18px;font-size:10px}.ask-badge>.badge.-regular{width:22px;height:22px;font-size:11px}.ask-badge>.badge.-large{width:28px;height:28px;font-size:12px}.ask-dropdown-top-right{margin-left:8px}.ask-dropdown-top-left{margin-right:8px}.ask-dropdown-bottom-right,.ask-dropdown-bottom-left{margin-top:8px}.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:disabled{cursor:default;opacity:0}.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:none;color:var(--font-color-200);background:none;border-radius:99999px;transition:.2s background-color,.2s color,.2s font-weight}.days-block>.day:disabled{text-decoration:line-through;color:var(--font-color-300)}.days-block>.day:disabled:hover{color:var(--font-color-300);background:none;cursor:not-allowed}.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"] }] }); }
229
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.6", type: DatePickerCalendarComponent, selector: "ask-date-picker-calendar", inputs: { isRange: "isRange", disableFutureDate: "disableFutureDate", 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\n type=\"button\"\n class=\"selector-button\"\n (click)=\"incrementMonth(1)\"\n >\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 <button\n *ngFor=\"let day of days\"\n (click)=\"selectDate(day.timestamp)\"\n [disabled]=\"day.isFuture\"\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 </button>\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}.scale-in-center{animation:scale-in-center .3s ease-in-out both}@keyframes scale-in-center{0%{transform:scale(0);opacity:1}to{transform:scale(1);opacity:1}}.scale-out-center{animation:scale-out-center .3s ease-in-out both}@keyframes scale-out-center{0%{transform:scale(1);opacity:1}to{transform:scale(0);opacity:1}}.ask-tooltip{background-color:#7b8794;color:#fff;padding:4px;border-radius:8px;position:relative}.ask-tooltip>div{text-align:center!important}.ask-tooltip:after{position:absolute;content:\"\";width:10px;height:10px;background-color:inherit}.ask-tooltip.-above{margin-bottom:4px}.ask-tooltip.-above:after{bottom:-5px;left:50%;transform:translate(-50%) rotate(45deg)}.ask-tooltip.-below{margin-top:4px}.ask-tooltip.-below:after{top:-5px;left:50%;transform:translate(-50%) rotate(45deg)}.ask-tooltip.-after,.ask-tooltip.-right{margin-left:4px}.ask-tooltip.-after:after,.ask-tooltip.-right:after{left:-5px;top:50%;transform:translateY(-50%) rotate(45deg)}.ask-tooltip.-before,.ask-tooltip.-left{margin-right:4px}.ask-tooltip.-before:after,.ask-tooltip.-left:after{right:-5px;top:50%;transform:translateY(-50%) rotate(45deg)}.ask-button{padding:8px 24px;border-radius:6px;border:none;outline:none;height:48px;font-size:1rem;transition:background-color .1s,box-shadow .1s;cursor:pointer;font-weight:500;background:white;color:var(--grey-500)}.ask-button:not(.-primary,.-secondary){box-shadow:0 1px 2px #2a304229}.ask-button:not(.-primary):hover:not(:disabled){box-shadow:0 0 6px #2a304229}.ask-button:hover:not(:disabled){box-shadow:0 0 6px #ff572466}.ask-button:active:not(:disabled){background-color:#f34915}.ask-button:disabled{cursor:not-allowed;background-color:#9aa5b1}.ask-button.-primary{background:#FF5724;color:#fff}.ask-modal-header{display:block;position:relative;flex-shrink:0;box-sizing:border-box;margin:0 0 1px;padding:0 24px 9px}.ask-modal-body{flex-grow:1;box-sizing:border-box;margin:0;overflow:auto;padding:20px 24px;max-height:65vh;display:block}.ask-modal-footer{display:flex;position:relative;flex-shrink:0;flex-wrap:wrap;align-items:center;justify-content:flex-end;box-sizing:border-box;min-height:52px;margin:0;padding:8px;border-top:1px solid rgba(0,0,0,0)}.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}.ask-badge{position:relative}.ask-badge>.badge{position:absolute;display:flex;justify-content:center;align-items:center;background-color:var(--bg-color);color:#fff;font-size:12px;text-overflow:ellipsis;white-space:nowrap;overflow:hidden;border-radius:50%;box-shadow:0 2px 6px -1px #00000080}.ask-badge>.badge.-primary{--bg-color: var(--asksuite-orange)}.ask-badge>.badge.-secondary{--bg-color: var(--grey-800)}.ask-badge>.badge.-top{top:-10px}.ask-badge>.badge.-bottom{bottom:-10px}.ask-badge>.badge.-left{left:-10px}.ask-badge>.badge.-right{right:-10px}.ask-badge>.badge.-small{width:18px;height:18px;font-size:10px}.ask-badge>.badge.-regular{width:22px;height:22px;font-size:11px}.ask-badge>.badge.-large{width:28px;height:28px;font-size:12px}.ask-dropdown-top-right{margin-left:8px}.ask-dropdown-top-left{margin-right:8px}.ask-dropdown-bottom-right,.ask-dropdown-bottom-left{margin-top:8px}.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:none;color:var(--font-color-200);background:none;border-radius:99999px;transition:.2s background-color,.2s color,.2s font-weight}.days-block>.day:disabled{text-decoration:line-through;color:var(--font-color-300)}.days-block>.day:disabled:hover{color:var(--font-color-300);background:none;cursor:not-allowed}.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"] }] }); }
234
230
  }
235
231
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: DatePickerCalendarComponent, decorators: [{
236
232
  type: Component,
237
- args: [{ selector: 'ask-date-picker-calendar', 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\n type=\"button\"\n class=\"selector-button\"\n [disabled]=\"shouldDisableNextMonth\"\n (click)=\"incrementMonth(1)\"\n >\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 <button\n *ngFor=\"let day of days\"\n (click)=\"selectDate(day.timestamp)\"\n [disabled]=\"day.isFuture\"\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 </button>\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}.scale-in-center{animation:scale-in-center .3s ease-in-out both}@keyframes scale-in-center{0%{transform:scale(0);opacity:1}to{transform:scale(1);opacity:1}}.scale-out-center{animation:scale-out-center .3s ease-in-out both}@keyframes scale-out-center{0%{transform:scale(1);opacity:1}to{transform:scale(0);opacity:1}}.ask-tooltip{background-color:#7b8794;color:#fff;padding:4px;border-radius:8px;position:relative}.ask-tooltip>div{text-align:center!important}.ask-tooltip:after{position:absolute;content:\"\";width:10px;height:10px;background-color:inherit}.ask-tooltip.-above{margin-bottom:4px}.ask-tooltip.-above:after{bottom:-5px;left:50%;transform:translate(-50%) rotate(45deg)}.ask-tooltip.-below{margin-top:4px}.ask-tooltip.-below:after{top:-5px;left:50%;transform:translate(-50%) rotate(45deg)}.ask-tooltip.-after,.ask-tooltip.-right{margin-left:4px}.ask-tooltip.-after:after,.ask-tooltip.-right:after{left:-5px;top:50%;transform:translateY(-50%) rotate(45deg)}.ask-tooltip.-before,.ask-tooltip.-left{margin-right:4px}.ask-tooltip.-before:after,.ask-tooltip.-left:after{right:-5px;top:50%;transform:translateY(-50%) rotate(45deg)}.ask-button{padding:8px 24px;border-radius:6px;border:none;outline:none;height:48px;font-size:1rem;transition:background-color .1s,box-shadow .1s;cursor:pointer;font-weight:500;background:white;color:var(--grey-500)}.ask-button:not(.-primary,.-secondary){box-shadow:0 1px 2px #2a304229}.ask-button:not(.-primary):hover:not(:disabled){box-shadow:0 0 6px #2a304229}.ask-button:hover:not(:disabled){box-shadow:0 0 6px #ff572466}.ask-button:active:not(:disabled){background-color:#f34915}.ask-button:disabled{cursor:not-allowed;background-color:#9aa5b1}.ask-button.-primary{background:#FF5724;color:#fff}.ask-modal-header{display:block;position:relative;flex-shrink:0;box-sizing:border-box;margin:0 0 1px;padding:0 24px 9px}.ask-modal-body{flex-grow:1;box-sizing:border-box;margin:0;overflow:auto;padding:20px 24px;max-height:65vh;display:block}.ask-modal-footer{display:flex;position:relative;flex-shrink:0;flex-wrap:wrap;align-items:center;justify-content:flex-end;box-sizing:border-box;min-height:52px;margin:0;padding:8px;border-top:1px solid rgba(0,0,0,0)}.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}.ask-badge{position:relative}.ask-badge>.badge{position:absolute;display:flex;justify-content:center;align-items:center;background-color:var(--bg-color);color:#fff;font-size:12px;text-overflow:ellipsis;white-space:nowrap;overflow:hidden;border-radius:50%;box-shadow:0 2px 6px -1px #00000080}.ask-badge>.badge.-primary{--bg-color: var(--asksuite-orange)}.ask-badge>.badge.-secondary{--bg-color: var(--grey-800)}.ask-badge>.badge.-top{top:-10px}.ask-badge>.badge.-bottom{bottom:-10px}.ask-badge>.badge.-left{left:-10px}.ask-badge>.badge.-right{right:-10px}.ask-badge>.badge.-small{width:18px;height:18px;font-size:10px}.ask-badge>.badge.-regular{width:22px;height:22px;font-size:11px}.ask-badge>.badge.-large{width:28px;height:28px;font-size:12px}.ask-dropdown-top-right{margin-left:8px}.ask-dropdown-top-left{margin-right:8px}.ask-dropdown-bottom-right,.ask-dropdown-bottom-left{margin-top:8px}.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:disabled{cursor:default;opacity:0}.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:none;color:var(--font-color-200);background:none;border-radius:99999px;transition:.2s background-color,.2s color,.2s font-weight}.days-block>.day:disabled{text-decoration:line-through;color:var(--font-color-300)}.days-block>.day:disabled:hover{color:var(--font-color-300);background:none;cursor:not-allowed}.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"] }]
233
+ args: [{ selector: 'ask-date-picker-calendar', 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\n type=\"button\"\n class=\"selector-button\"\n (click)=\"incrementMonth(1)\"\n >\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 <button\n *ngFor=\"let day of days\"\n (click)=\"selectDate(day.timestamp)\"\n [disabled]=\"day.isFuture\"\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 </button>\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}.scale-in-center{animation:scale-in-center .3s ease-in-out both}@keyframes scale-in-center{0%{transform:scale(0);opacity:1}to{transform:scale(1);opacity:1}}.scale-out-center{animation:scale-out-center .3s ease-in-out both}@keyframes scale-out-center{0%{transform:scale(1);opacity:1}to{transform:scale(0);opacity:1}}.ask-tooltip{background-color:#7b8794;color:#fff;padding:4px;border-radius:8px;position:relative}.ask-tooltip>div{text-align:center!important}.ask-tooltip:after{position:absolute;content:\"\";width:10px;height:10px;background-color:inherit}.ask-tooltip.-above{margin-bottom:4px}.ask-tooltip.-above:after{bottom:-5px;left:50%;transform:translate(-50%) rotate(45deg)}.ask-tooltip.-below{margin-top:4px}.ask-tooltip.-below:after{top:-5px;left:50%;transform:translate(-50%) rotate(45deg)}.ask-tooltip.-after,.ask-tooltip.-right{margin-left:4px}.ask-tooltip.-after:after,.ask-tooltip.-right:after{left:-5px;top:50%;transform:translateY(-50%) rotate(45deg)}.ask-tooltip.-before,.ask-tooltip.-left{margin-right:4px}.ask-tooltip.-before:after,.ask-tooltip.-left:after{right:-5px;top:50%;transform:translateY(-50%) rotate(45deg)}.ask-button{padding:8px 24px;border-radius:6px;border:none;outline:none;height:48px;font-size:1rem;transition:background-color .1s,box-shadow .1s;cursor:pointer;font-weight:500;background:white;color:var(--grey-500)}.ask-button:not(.-primary,.-secondary){box-shadow:0 1px 2px #2a304229}.ask-button:not(.-primary):hover:not(:disabled){box-shadow:0 0 6px #2a304229}.ask-button:hover:not(:disabled){box-shadow:0 0 6px #ff572466}.ask-button:active:not(:disabled){background-color:#f34915}.ask-button:disabled{cursor:not-allowed;background-color:#9aa5b1}.ask-button.-primary{background:#FF5724;color:#fff}.ask-modal-header{display:block;position:relative;flex-shrink:0;box-sizing:border-box;margin:0 0 1px;padding:0 24px 9px}.ask-modal-body{flex-grow:1;box-sizing:border-box;margin:0;overflow:auto;padding:20px 24px;max-height:65vh;display:block}.ask-modal-footer{display:flex;position:relative;flex-shrink:0;flex-wrap:wrap;align-items:center;justify-content:flex-end;box-sizing:border-box;min-height:52px;margin:0;padding:8px;border-top:1px solid rgba(0,0,0,0)}.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}.ask-badge{position:relative}.ask-badge>.badge{position:absolute;display:flex;justify-content:center;align-items:center;background-color:var(--bg-color);color:#fff;font-size:12px;text-overflow:ellipsis;white-space:nowrap;overflow:hidden;border-radius:50%;box-shadow:0 2px 6px -1px #00000080}.ask-badge>.badge.-primary{--bg-color: var(--asksuite-orange)}.ask-badge>.badge.-secondary{--bg-color: var(--grey-800)}.ask-badge>.badge.-top{top:-10px}.ask-badge>.badge.-bottom{bottom:-10px}.ask-badge>.badge.-left{left:-10px}.ask-badge>.badge.-right{right:-10px}.ask-badge>.badge.-small{width:18px;height:18px;font-size:10px}.ask-badge>.badge.-regular{width:22px;height:22px;font-size:11px}.ask-badge>.badge.-large{width:28px;height:28px;font-size:12px}.ask-dropdown-top-right{margin-left:8px}.ask-dropdown-top-left{margin-right:8px}.ask-dropdown-bottom-right,.ask-dropdown-bottom-left{margin-top:8px}.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:none;color:var(--font-color-200);background:none;border-radius:99999px;transition:.2s background-color,.2s color,.2s font-weight}.days-block>.day:disabled{text-decoration:line-through;color:var(--font-color-300)}.days-block>.day:disabled:hover{color:var(--font-color-300);background:none;cursor:not-allowed}.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"] }]
238
234
  }], propDecorators: { isRange: [{
239
235
  type: Input
240
236
  }], disableFutureDate: [{
@@ -244,4 +240,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImpor
244
240
  }], dateChange: [{
245
241
  type: Output
246
242
  }] } });
247
- //# 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  isFuture: boolean;\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() disableFutureDate: 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 shouldDisableNextMonth () {\n    return this.isFutureDate(this.displayDate.clone().add(1, 'month').unix());\n  }\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      isFuture: this.isFutureDate(day.unix())\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  public isFutureDate(timestamp: number) {\n    if (!this.disableFutureDate) return false;\n\n    const date = moment.unix(timestamp);\n    const now = moment();\n\n    return date.isAfter(now);\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\n      type=\"button\"\n      class=\"selector-button\"\n      [disabled]=\"shouldDisableNextMonth\"\n      (click)=\"incrementMonth(1)\"\n    >\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      <button\n        *ngFor=\"let day of days\"\n        (click)=\"selectDate(day.timestamp)\"\n        [disabled]=\"day.isFuture\"\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      </button>\n    </div>\n  </main>\n</div>\n"]}
243
+ //# 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  isFuture: boolean;\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() disableFutureDate: 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      isFuture: this.isFutureDate(day.unix())\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) return this.handleRangeSelect(momentDate);\n    this.handleSingleSelect(momentDate);\n  }\n\n  private handleRangeSelect(selectedDate: moment.Moment) {\n    const innerDate = (this.innerDate as DayRange);\n\n    if (!innerDate.from) {\n      // First selection\n      innerDate.from = this.getDayFromMoment(selectedDate);\n    } else if (!innerDate.to) {\n      // Second selection\n      const actualFrom = moment.unix(innerDate.from.timestamp);\n\n      if (selectedDate.isBefore(actualFrom, 'day')) {\n        // Selected date is past the previous selected date\n        innerDate.to = innerDate.from;\n        innerDate.from = this.getDayFromMoment(selectedDate);\n      } else {\n        // Selected date is future of the previous selected date\n        innerDate.to = this.getDayFromMoment(selectedDate);\n      }\n    }\n    else {\n      // Selection when both from and to are already selected\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      else newRange.to = formatTo(moment.unix(range.from.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  public isFutureDate(timestamp: number) {\n    if (!this.disableFutureDate) return false;\n\n    const date = moment.unix(timestamp);\n    const now = moment();\n\n    return date.isAfter(now);\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\n      type=\"button\"\n      class=\"selector-button\"\n      (click)=\"incrementMonth(1)\"\n    >\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      <button\n        *ngFor=\"let day of days\"\n        (click)=\"selectDate(day.timestamp)\"\n        [disabled]=\"day.isFuture\"\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      </button>\n    </div>\n  </main>\n</div>\n"]}
@@ -29,8 +29,8 @@ export class DatePickerComponent {
29
29
  { label: PeriodLabel.YESTERDAY, getRange: () => ({ from: formatFrom(moment().subtract(1, 'day')), to: formatTo(moment().subtract(1, 'day')) }) },
30
30
  { label: PeriodLabel.LAST_7_DAYS, getRange: () => ({ from: formatFrom(moment().subtract(1, 'week')), to: formatTo(moment()) }) },
31
31
  { label: PeriodLabel.LAST_30_DAYS, getRange: () => ({ from: formatFrom(moment().subtract(30, 'days')), to: formatTo(moment()) }) },
32
- { label: PeriodLabel.THIS_MONTH, getRange: () => ({ from: formatFrom(moment().startOf('month')), to: formatTo(moment().endOf('month')) }) },
33
- { label: PeriodLabel.LAST_QUARTER, getRange: () => ({ from: formatFrom(moment().subtract(3, 'months')), to: formatTo(moment().endOf('month')) }) },
32
+ { label: PeriodLabel.THIS_MONTH, getRange: () => ({ from: formatFrom(moment().startOf('month')), to: formatTo(moment().endOf('day')) }) },
33
+ { label: PeriodLabel.LAST_QUARTER, getRange: () => ({ from: formatFrom(moment().subtract(3, 'months')), to: formatTo(moment().endOf('day')) }) },
34
34
  { label: PeriodLabel.CUSTOM_PERIOD, getRange: () => ({}), isCustomRange: true },
35
35
  ]; }
36
36
  get filteredPeriods() {
@@ -143,4 +143,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImpor
143
143
  }], close: [{
144
144
  type: Output
145
145
  }] } });
146
- //# 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}\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  static readonly PERIODS: Array<Period> = [\n    { label: PeriodLabel.TODAY, getRange: () => ({ from: formatFrom(moment()), to: formatTo(moment()) }) },\n    { label: PeriodLabel.YESTERDAY, getRange: () => ({ from: formatFrom(moment().subtract(1, 'day')), to: formatTo(moment().subtract(1, 'day')) }) },\n    { label: PeriodLabel.LAST_7_DAYS, getRange: () => ({ from: formatFrom(moment().subtract(1, 'week')), to: formatTo(moment()) }) },\n    { label: PeriodLabel.LAST_30_DAYS, getRange: () => ({ from: formatFrom(moment().subtract(30, 'days')), to: formatTo(moment()) }) },\n    { label: PeriodLabel.THIS_MONTH, getRange: () => ({ from: formatFrom(moment().startOf('month')), to: formatTo(moment().endOf('month')) }) },\n    { label: PeriodLabel.LAST_QUARTER, getRange: () => ({ from: formatFrom(moment().subtract(3, 'months')), to: formatTo(moment().endOf('month')) }) },\n    { label: PeriodLabel.CUSTOM_PERIOD, getRange: () => ({}), isCustomRange: true },\n  ];\n\n  @Input() date: DatePickerValue = moment().format();\n  @Input() isRange: boolean = false;\n  @Input() disableFutureDate: boolean = false;\n  @Input() periodsFilter: PeriodLabel[] = [];\n\n  @Output() dateChange = new EventEmitter<DatePickerValue>();\n  @Output() close = new EventEmitter();\n\n  selectedPeriod?: Period;\n  isCustomRange = false;\n\n  get filteredPeriods() {\n    if (!this.periodsFilter?.length) {\n      return DatePickerComponent.PERIODS;\n    }\n\n    return DatePickerComponent.PERIODS.filter(p => this.periodsFilter.includes(p.label));\n  }\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.selectedPeriod = period;\n\n    this.date = {\n      ...(this.date as DateRange),\n      ...period.getRange()\n    };\n    this.date.label = period.label;\n    this.isCustomRange = period.isCustomRange || false;\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    if (this.isCustomRange && !(this.date as DateRange).to) {\n      (this.date as DateRange).to = (this.date as DateRange).from;\n    }\n\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  public static getPeriodOrDefault(periodName: PeriodLabel, defaultPeriodName: PeriodLabel = PeriodLabel.TODAY) {\n    return DatePickerComponent.PERIODS.find(p => p.label === periodName) ||\n      DatePickerComponent.PERIODS.find(p => p.label === defaultPeriodName);\n  }\n\n  checkPeriodShouldBeSelectedByValue() {\n    if (!this.isRange) {\n      return;\n    }\n\n    const period = DatePickerComponent.PERIODS.find(p => p.label === (this.date as DateRange)?.label);\n\n    if (!period) {\n      return;\n    }\n\n    this.selectedPeriod = period;\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 = DatePickerComponent.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 filteredPeriods\"\n        type=\"button\"\n        class=\"period\"\n        [ngClass]=\"{ 'selected': period.label === selectedPeriod?.label }\"\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      [disableFutureDate]=\"disableFutureDate\"\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"]}
146
+ //# 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}\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  static readonly PERIODS: Array<Period> = [\n    { label: PeriodLabel.TODAY, getRange: () => ({ from: formatFrom(moment()), to: formatTo(moment()) }) },\n    { label: PeriodLabel.YESTERDAY, getRange: () => ({ from: formatFrom(moment().subtract(1, 'day')), to: formatTo(moment().subtract(1, 'day')) }) },\n    { label: PeriodLabel.LAST_7_DAYS, getRange: () => ({ from: formatFrom(moment().subtract(1, 'week')), to: formatTo(moment()) }) },\n    { label: PeriodLabel.LAST_30_DAYS, getRange: () => ({ from: formatFrom(moment().subtract(30, 'days')), to: formatTo(moment()) }) },\n    { label: PeriodLabel.THIS_MONTH, getRange: () => ({ from: formatFrom(moment().startOf('month')), to: formatTo(moment().endOf('day')) }) },\n    { label: PeriodLabel.LAST_QUARTER, getRange: () => ({ from: formatFrom(moment().subtract(3, 'months')), to: formatTo(moment().endOf('day')) }) },\n    { label: PeriodLabel.CUSTOM_PERIOD, getRange: () => ({}), isCustomRange: true },\n  ];\n\n  @Input() date: DatePickerValue = moment().format(); \n  @Input() isRange: boolean = false;\n  @Input() disableFutureDate: boolean = false;\n  @Input() periodsFilter: PeriodLabel[] = [];\n\n  @Output() dateChange = new EventEmitter<DatePickerValue>();\n  @Output() close = new EventEmitter();\n\n  selectedPeriod?: Period;\n  isCustomRange = false;\n\n  get filteredPeriods() {\n    if (!this.periodsFilter?.length) {\n      return DatePickerComponent.PERIODS;\n    }\n\n    return DatePickerComponent.PERIODS.filter(p => this.periodsFilter.includes(p.label));\n  }\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.selectedPeriod = period;\n\n    this.date = {\n      ...(this.date as DateRange),\n      ...period.getRange()\n    };\n    this.date.label = period.label;\n    this.isCustomRange = period.isCustomRange || false;\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    if (this.isCustomRange && !(this.date as DateRange).to) {\n      (this.date as DateRange).to = (this.date as DateRange).from;\n    }\n\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  public static getPeriodOrDefault(periodName: PeriodLabel, defaultPeriodName: PeriodLabel = PeriodLabel.TODAY) {\n    return DatePickerComponent.PERIODS.find(p => p.label === periodName) ||\n      DatePickerComponent.PERIODS.find(p => p.label === defaultPeriodName);\n  }\n\n  checkPeriodShouldBeSelectedByValue() {\n    if (!this.isRange) {\n      return;\n    }\n\n    const period = DatePickerComponent.PERIODS.find(p => p.label === (this.date as DateRange)?.label);\n\n    if (!period) {\n      return;\n    }\n\n    this.selectedPeriod = period;\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 = DatePickerComponent.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 filteredPeriods\"\n        type=\"button\"\n        class=\"period\"\n        [ngClass]=\"{ 'selected': period.label === selectedPeriod?.label }\"\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      [disableFutureDate]=\"disableFutureDate\"\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"]}