asksuite-citrus 1.1.0 → 1.2.0

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.
@@ -1,6 +1,6 @@
1
1
  import { ChangeDetectionStrategy, Component, DestroyRef, EventEmitter, forwardRef, HostListener, inject, Input, Output, ViewChild } from '@angular/core';
2
2
  import { FormControl, NG_VALUE_ACCESSOR } from "@angular/forms";
3
- import { debounceTime, map, tap } from "rxjs";
3
+ import { debounceTime, fromEvent, map, tap } from "rxjs";
4
4
  import { TemplatePortal } from "@angular/cdk/portal";
5
5
  import { takeUntilDestroyed } from "@angular/core/rxjs-interop";
6
6
  import * as i0 from "@angular/core";
@@ -128,7 +128,7 @@ export class AutocompleteComponent {
128
128
  }
129
129
  showOptions() {
130
130
  this.closed = false;
131
- if (!this._overlayRef && this.wrapper) {
131
+ if (this.wrapper) {
132
132
  this._overlayRef = this.getOverlayConfig(this.wrapper);
133
133
  this._portal = new TemplatePortal(this.overlayContent, this.viewContainerRef);
134
134
  }
@@ -136,6 +136,8 @@ export class AutocompleteComponent {
136
136
  this.updateValidation();
137
137
  if (this.paginatedFilteredOptions.length === 0)
138
138
  this.getMoreItems();
139
+ this.scrollSub = fromEvent(window, 'scroll')
140
+ .subscribe(this.onScroll.bind(this));
139
141
  }
140
142
  getOverlayConfig(wrapper) {
141
143
  return this.overlay.create({
@@ -150,6 +152,9 @@ export class AutocompleteComponent {
150
152
  }])
151
153
  });
152
154
  }
155
+ onScroll() {
156
+ this._overlayRef?.updatePosition();
157
+ }
153
158
  hideOptions() {
154
159
  this.closed = true;
155
160
  this.chipsCollapsed = true;
@@ -159,6 +164,7 @@ export class AutocompleteComponent {
159
164
  this.paginatedFilteredOptions = [];
160
165
  this.updateValidation();
161
166
  this.change.detectChanges();
167
+ this.scrollSub?.unsubscribe();
162
168
  }
163
169
  handleClick(event) {
164
170
  if (!this.closed
@@ -323,4 +329,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImpor
323
329
  type: HostListener,
324
330
  args: ["window:mousedown", ['$event']]
325
331
  }] } });
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"]}
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, NG_VALUE_ACCESSOR} from \"@angular/forms\";\nimport {debounceTime, fromEvent, map, Subscription, 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  private scrollSub?: Subscription;\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.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    this.scrollSub = fromEvent(window, 'scroll')\n      .subscribe(this.onScroll.bind(this));\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  public onScroll(): void {\n    this._overlayRef?.updatePosition();\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    this.scrollSub?.unsubscribe();\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"]}
@@ -11,7 +11,7 @@ export class SkeletonComponent {
11
11
  this.barsCount = 0;
12
12
  this.baseTheme = {
13
13
  'border-radius': '',
14
- height: 100 + 'px',
14
+ height: '100px',
15
15
  margin: 0,
16
16
  display: 'block',
17
17
  };
@@ -21,7 +21,7 @@ export class SkeletonComponent {
21
21
  this.barsCount = Math.round(height / this.barsHeight) || 1;
22
22
  this.baseTheme = {
23
23
  ...this.baseTheme,
24
- ...(this.appearance !== 'circle' && { 'border-radius': 5 + 'px' }),
24
+ ...(this.appearance !== 'circle' && { 'border-radius': '5px' }),
25
25
  ...this.customTheme,
26
26
  };
27
27
  }
@@ -40,4 +40,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImpor
40
40
  }], appearance: [{
41
41
  type: Input
42
42
  }] } });
43
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2tlbGV0b24uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYXNrc3VpdGUtY2l0cnVzL3NyYy9saWIvY29tcG9uZW50cy9za2VsZXRvbi9za2VsZXRvbi5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hc2tzdWl0ZS1jaXRydXMvc3JjL2xpYi9jb21wb25lbnRzL3NrZWxldG9uL3NrZWxldG9uLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQWMsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7QUFPN0QsTUFBTSxPQUFPLGlCQUFpQjtJQWE1QixZQUFvQixVQUFtQztRQUFuQyxlQUFVLEdBQVYsVUFBVSxDQUF5QjtRQVo5QyxlQUFVLEdBQUcsR0FBRyxDQUFDO1FBQ2pCLFdBQU0sR0FBRyxDQUFDLENBQUM7UUFDWCxnQkFBVyxHQUEwQixFQUFFLENBQUE7UUFDdkMsZUFBVSxHQUFzQixNQUFNLENBQUM7UUFDekMsY0FBUyxHQUFHLENBQUMsQ0FBQztRQUNYLGNBQVMsR0FBRztZQUNwQixlQUFlLEVBQUUsRUFBRTtZQUNuQixNQUFNLEVBQUUsR0FBRyxHQUFDLElBQUk7WUFDaEIsTUFBTSxFQUFFLENBQUM7WUFDVCxPQUFPLEVBQUUsT0FBTztTQUNqQixDQUFBO0lBRXlELENBQUM7SUFFM0QsUUFBUTtRQUNOLE1BQU0sTUFBTSxHQUFHLElBQUksQ0FBQyxVQUFVLENBQUMsYUFBYSxDQUFDLFlBQVksQ0FBQztRQUMxRCxJQUFJLENBQUMsU0FBUyxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsTUFBTSxHQUFHLElBQUksQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDM0QsSUFBSSxDQUFDLFNBQVMsR0FBRztZQUNmLEdBQUcsSUFBSSxDQUFDLFNBQVM7WUFDakIsR0FBRyxDQUFDLElBQUksQ0FBQyxVQUFVLEtBQUssUUFBUSxJQUFJLEVBQUUsZUFBZSxFQUFFLENBQUMsR0FBRyxJQUFJLEVBQUUsQ0FBQztZQUNsRSxHQUFHLElBQUksQ0FBQyxXQUFXO1NBQ3BCLENBQUE7SUFDSCxDQUFDOzhHQXZCVSxpQkFBaUI7a0dBQWpCLGlCQUFpQixrS0NQOUIsK05BUUE7OzJGRERhLGlCQUFpQjtrQkFMN0IsU0FBUzsrQkFDRSxjQUFjO2lHQUtmLFVBQVU7c0JBQWxCLEtBQUs7Z0JBQ0csTUFBTTtzQkFBZCxLQUFLO2dCQUNHLFdBQVc7c0JBQW5CLEtBQUs7Z0JBQ0csVUFBVTtzQkFBbEIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgRWxlbWVudFJlZiwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnYXNrLXNrZWxldG9uJyxcbiAgdGVtcGxhdGVVcmw6ICcuL3NrZWxldG9uLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vc2tlbGV0b24uY29tcG9uZW50LnNjc3MnXSxcbn0pXG5leHBvcnQgY2xhc3MgU2tlbGV0b25Db21wb25lbnQge1xuICBASW5wdXQoKSBiYXJzSGVpZ2h0ID0gMTAwO1xuICBASW5wdXQoKSByYWRpdXMgPSA1O1xuICBASW5wdXQoKSBjdXN0b21UaGVtZToge2JhY2tncm91bmQ/OiBzdHJpbmd9ID0ge31cbiAgQElucHV0KCkgYXBwZWFyYW5jZTogJ2xpbmUnIHwgJ2NpcmNsZScgPSAnbGluZSc7XG4gIHB1YmxpYyBiYXJzQ291bnQgPSAwO1xuICBwcm90ZWN0ZWQgYmFzZVRoZW1lID0ge1xuICAgICdib3JkZXItcmFkaXVzJzogJycsXG4gICAgaGVpZ2h0OiAxMDArJ3B4JyxcbiAgICBtYXJnaW46IDAsXG4gICAgZGlzcGxheTogJ2Jsb2NrJyxcbiAgfVxuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgZWxlbWVudFJlZjogRWxlbWVudFJlZjxIVE1MRWxlbWVudD4pIHt9XG5cbiAgbmdPbkluaXQoKSB7XG4gICAgY29uc3QgaGVpZ2h0ID0gdGhpcy5lbGVtZW50UmVmLm5hdGl2ZUVsZW1lbnQuY2xpZW50SGVpZ2h0O1xuICAgIHRoaXMuYmFyc0NvdW50ID0gTWF0aC5yb3VuZChoZWlnaHQgLyB0aGlzLmJhcnNIZWlnaHQpIHx8IDE7XG4gICAgdGhpcy5iYXNlVGhlbWUgPSB7XG4gICAgICAuLi50aGlzLmJhc2VUaGVtZSxcbiAgICAgIC4uLih0aGlzLmFwcGVhcmFuY2UgIT09ICdjaXJjbGUnICYmIHsgJ2JvcmRlci1yYWRpdXMnOiA1ICsgJ3B4JyB9KSxcbiAgICAgIC4uLnRoaXMuY3VzdG9tVGhlbWUsXG4gICAgfVxuICB9XG59XG4iLCI8bmd4LXNrZWxldG9uLWxvYWRlclxuICBbY291bnRdPVwiYmFyc0NvdW50XCJcbiAgZGF0YS10ZXN0aWQ9XCJza2VsZXRvbi1sb2FkZXJcIlxuICBjbGFzcz1cInNrZWxldG9uLWNvbXBvbmVudFwiXG4gIFthcHBlYXJhbmNlXT1cImFwcGVhcmFuY2VcIlxuICBhbmltYXRpb249XCJwcm9ncmVzc1wiXG4gIFt0aGVtZV09XCJiYXNlVGhlbWVcIlxuPjwvbmd4LXNrZWxldG9uLWxvYWRlcj5cbiJdfQ==
43
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2tlbGV0b24uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYXNrc3VpdGUtY2l0cnVzL3NyYy9saWIvY29tcG9uZW50cy9za2VsZXRvbi9za2VsZXRvbi5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hc2tzdWl0ZS1jaXRydXMvc3JjL2xpYi9jb21wb25lbnRzL3NrZWxldG9uL3NrZWxldG9uLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQWMsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7QUFPN0QsTUFBTSxPQUFPLGlCQUFpQjtJQWE1QixZQUFvQixVQUFtQztRQUFuQyxlQUFVLEdBQVYsVUFBVSxDQUF5QjtRQVo5QyxlQUFVLEdBQUcsR0FBRyxDQUFDO1FBQ2pCLFdBQU0sR0FBRyxDQUFDLENBQUM7UUFDWCxnQkFBVyxHQUF3QixFQUFFLENBQUE7UUFDckMsZUFBVSxHQUFzQixNQUFNLENBQUM7UUFDekMsY0FBUyxHQUFHLENBQUMsQ0FBQztRQUNYLGNBQVMsR0FBRztZQUNwQixlQUFlLEVBQUUsRUFBRTtZQUNuQixNQUFNLEVBQUUsT0FBTztZQUNmLE1BQU0sRUFBRSxDQUFDO1lBQ1QsT0FBTyxFQUFFLE9BQU87U0FDakIsQ0FBQTtJQUV5RCxDQUFDO0lBRTNELFFBQVE7UUFDTixNQUFNLE1BQU0sR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDLGFBQWEsQ0FBQyxZQUFZLENBQUM7UUFDMUQsSUFBSSxDQUFDLFNBQVMsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLE1BQU0sR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQzNELElBQUksQ0FBQyxTQUFTLEdBQUc7WUFDZixHQUFHLElBQUksQ0FBQyxTQUFTO1lBQ2pCLEdBQUcsQ0FBQyxJQUFJLENBQUMsVUFBVSxLQUFLLFFBQVEsSUFBSSxFQUFFLGVBQWUsRUFBRSxLQUFLLEVBQUUsQ0FBQztZQUMvRCxHQUFHLElBQUksQ0FBQyxXQUFXO1NBQ3BCLENBQUE7SUFDSCxDQUFDOzhHQXZCVSxpQkFBaUI7a0dBQWpCLGlCQUFpQixrS0NQOUIsK05BUUE7OzJGRERhLGlCQUFpQjtrQkFMN0IsU0FBUzsrQkFDRSxjQUFjO2lHQUtmLFVBQVU7c0JBQWxCLEtBQUs7Z0JBQ0csTUFBTTtzQkFBZCxLQUFLO2dCQUNHLFdBQVc7c0JBQW5CLEtBQUs7Z0JBQ0csVUFBVTtzQkFBbEIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgRWxlbWVudFJlZiwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnYXNrLXNrZWxldG9uJyxcbiAgdGVtcGxhdGVVcmw6ICcuL3NrZWxldG9uLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vc2tlbGV0b24uY29tcG9uZW50LnNjc3MnXSxcbn0pXG5leHBvcnQgY2xhc3MgU2tlbGV0b25Db21wb25lbnQge1xuICBASW5wdXQoKSBiYXJzSGVpZ2h0ID0gMTAwO1xuICBASW5wdXQoKSByYWRpdXMgPSA1O1xuICBASW5wdXQoKSBjdXN0b21UaGVtZTogUmVjb3JkPHN0cmluZywgYW55PiA9IHt9XG4gIEBJbnB1dCgpIGFwcGVhcmFuY2U6ICdsaW5lJyB8ICdjaXJjbGUnID0gJ2xpbmUnO1xuICBwdWJsaWMgYmFyc0NvdW50ID0gMDtcbiAgcHJvdGVjdGVkIGJhc2VUaGVtZSA9IHtcbiAgICAnYm9yZGVyLXJhZGl1cyc6ICcnLFxuICAgIGhlaWdodDogJzEwMHB4JyxcbiAgICBtYXJnaW46IDAsXG4gICAgZGlzcGxheTogJ2Jsb2NrJyxcbiAgfVxuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgZWxlbWVudFJlZjogRWxlbWVudFJlZjxIVE1MRWxlbWVudD4pIHt9XG5cbiAgbmdPbkluaXQoKSB7XG4gICAgY29uc3QgaGVpZ2h0ID0gdGhpcy5lbGVtZW50UmVmLm5hdGl2ZUVsZW1lbnQuY2xpZW50SGVpZ2h0O1xuICAgIHRoaXMuYmFyc0NvdW50ID0gTWF0aC5yb3VuZChoZWlnaHQgLyB0aGlzLmJhcnNIZWlnaHQpIHx8IDE7XG4gICAgdGhpcy5iYXNlVGhlbWUgPSB7XG4gICAgICAuLi50aGlzLmJhc2VUaGVtZSxcbiAgICAgIC4uLih0aGlzLmFwcGVhcmFuY2UgIT09ICdjaXJjbGUnICYmIHsgJ2JvcmRlci1yYWRpdXMnOiAnNXB4JyB9KSxcbiAgICAgIC4uLnRoaXMuY3VzdG9tVGhlbWUsXG4gICAgfVxuICB9XG59XG4iLCI8bmd4LXNrZWxldG9uLWxvYWRlclxuICBbY291bnRdPVwiYmFyc0NvdW50XCJcbiAgZGF0YS10ZXN0aWQ9XCJza2VsZXRvbi1sb2FkZXJcIlxuICBjbGFzcz1cInNrZWxldG9uLWNvbXBvbmVudFwiXG4gIFthcHBlYXJhbmNlXT1cImFwcGVhcmFuY2VcIlxuICBhbmltYXRpb249XCJwcm9ncmVzc1wiXG4gIFt0aGVtZV09XCJiYXNlVGhlbWVcIlxuPjwvbmd4LXNrZWxldG9uLWxvYWRlcj5cbiJdfQ==
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3Bpbm5lci1zaXplLnR5cGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hc2tzdWl0ZS1jaXRydXMvc3JjL2xpYi9kaXJlY3RpdmVzL3NwaW5uZXIvc3Bpbm5lci1zaXplLnR5cGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB0eXBlIFNwaW5uZXJTaXplID0gJ3NtYWxsJyB8ICdtZWRpdW0nIHwgJ21lZGl1bS1iaWcnIHwgJ2JpZyc7Il19
@@ -3,15 +3,21 @@ import * as i0 from "@angular/core";
3
3
  import * as i1 from "@angular/common";
4
4
  export class SpinnerComponent {
5
5
  constructor() {
6
- this.size = 'small';
6
+ this.sizeClass = {};
7
+ this.color = '';
8
+ }
9
+ set size(newSize) {
10
+ this.sizeClass = { [`-${newSize}`]: true };
7
11
  }
8
12
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: SpinnerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
9
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.6", type: SpinnerComponent, selector: "app-spinner", inputs: { size: "size" }, ngImport: i0, template: "<span class=\"spin-circle\" [ngClass]=\"{\n '-big': size === 'big',\n '-medium': size === 'medium'\n}\"></span>\n", styles: [":host{position:absolute;border-radius:inherit;inset:0;overflow:hidden;z-index:9999;display:flex;justify-content:center;align-items:center;visibility:visible;transition:background-color .1s,box-shadow .1s}:host.-blur:before{content:\"\";position:absolute;inset:0;background-color:var(--grey-200);opacity:.2;z-index:-1}:host .spin-circle{opacity:1;animation:spin .8s infinite linear;border-radius:50%;border:2px solid var(--grey-400);border-top-color:transparent;width:1em;height:1em}:host .spin-circle.-medium{width:2em;height:2em;border:3px solid var(--grey-400);border-top-color:transparent}:host .spin-circle.-big{width:4em;height:4em;border:5px solid var(--grey-400);border-top-color:transparent}@keyframes spin{0%{transform:rotate(0)}40%{transform:rotate(230deg)}to{transform:rotate(360deg)}}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }] }); }
13
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.6", type: SpinnerComponent, selector: "app-spinner", inputs: { size: "size", color: "color" }, ngImport: i0, template: "<span\n class=\"spin-circle\"\n [ngClass]=\"sizeClass\"\n [ngStyle]=\"{\n 'border-color': color\n }\"\n></span>", styles: [":host{position:absolute;border-radius:inherit;inset:0;overflow:hidden;z-index:9999;display:flex;justify-content:center;align-items:center;visibility:visible;transition:background-color .1s,box-shadow .1s}:host.-blur:before{content:\"\";position:absolute;inset:0;background-color:var(--grey-200);opacity:.2;z-index:-1}:host .spin-circle{opacity:1;animation:spin .8s infinite linear;border-radius:50%;border:2px solid var(--grey-400);border-top-color:transparent!important;width:1em;height:1em}:host .spin-circle.-medium{width:2em;height:2em;border-width:3px}:host .spin-circle.-medium-big{width:24px;height:24px;border-width:2px}:host .spin-circle.-big{width:4em;height:4em;border-width:5px}@keyframes spin{0%{transform:rotate(0)}40%{transform:rotate(230deg)}to{transform:rotate(360deg)}}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }] }); }
10
14
  }
11
15
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: SpinnerComponent, decorators: [{
12
16
  type: Component,
13
- args: [{ selector: 'app-spinner', template: "<span class=\"spin-circle\" [ngClass]=\"{\n '-big': size === 'big',\n '-medium': size === 'medium'\n}\"></span>\n", styles: [":host{position:absolute;border-radius:inherit;inset:0;overflow:hidden;z-index:9999;display:flex;justify-content:center;align-items:center;visibility:visible;transition:background-color .1s,box-shadow .1s}:host.-blur:before{content:\"\";position:absolute;inset:0;background-color:var(--grey-200);opacity:.2;z-index:-1}:host .spin-circle{opacity:1;animation:spin .8s infinite linear;border-radius:50%;border:2px solid var(--grey-400);border-top-color:transparent;width:1em;height:1em}:host .spin-circle.-medium{width:2em;height:2em;border:3px solid var(--grey-400);border-top-color:transparent}:host .spin-circle.-big{width:4em;height:4em;border:5px solid var(--grey-400);border-top-color:transparent}@keyframes spin{0%{transform:rotate(0)}40%{transform:rotate(230deg)}to{transform:rotate(360deg)}}\n"] }]
17
+ args: [{ selector: 'app-spinner', template: "<span\n class=\"spin-circle\"\n [ngClass]=\"sizeClass\"\n [ngStyle]=\"{\n 'border-color': color\n }\"\n></span>", styles: [":host{position:absolute;border-radius:inherit;inset:0;overflow:hidden;z-index:9999;display:flex;justify-content:center;align-items:center;visibility:visible;transition:background-color .1s,box-shadow .1s}:host.-blur:before{content:\"\";position:absolute;inset:0;background-color:var(--grey-200);opacity:.2;z-index:-1}:host .spin-circle{opacity:1;animation:spin .8s infinite linear;border-radius:50%;border:2px solid var(--grey-400);border-top-color:transparent!important;width:1em;height:1em}:host .spin-circle.-medium{width:2em;height:2em;border-width:3px}:host .spin-circle.-medium-big{width:24px;height:24px;border-width:2px}:host .spin-circle.-big{width:4em;height:4em;border-width:5px}@keyframes spin{0%{transform:rotate(0)}40%{transform:rotate(230deg)}to{transform:rotate(360deg)}}\n"] }]
14
18
  }], propDecorators: { size: [{
15
19
  type: Input
20
+ }], color: [{
21
+ type: Input
16
22
  }] } });
17
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3Bpbm5lci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hc2tzdWl0ZS1jaXRydXMvc3JjL2xpYi9kaXJlY3RpdmVzL3NwaW5uZXIvc3Bpbm5lci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hc2tzdWl0ZS1jaXRydXMvc3JjL2xpYi9kaXJlY3RpdmVzL3NwaW5uZXIvc3Bpbm5lci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFFLEtBQUssRUFBQyxNQUFNLGVBQWUsQ0FBQzs7O0FBTy9DLE1BQU0sT0FBTyxnQkFBZ0I7SUFMN0I7UUFNVyxTQUFJLEdBQStCLE9BQU8sQ0FBQTtLQUNwRDs4R0FGWSxnQkFBZ0I7a0dBQWhCLGdCQUFnQiw2RUNQN0IscUhBSUE7OzJGREdhLGdCQUFnQjtrQkFMNUIsU0FBUzsrQkFDRSxhQUFhOzhCQUtkLElBQUk7c0JBQVosS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q29tcG9uZW50LCBJbnB1dH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2FwcC1zcGlubmVyJyxcbiAgdGVtcGxhdGVVcmw6ICcuL3NwaW5uZXIuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9zcGlubmVyLmNvbXBvbmVudC5zY3NzJ11cbn0pXG5leHBvcnQgY2xhc3MgU3Bpbm5lckNvbXBvbmVudCB7XG4gIEBJbnB1dCgpIHNpemU6ICdtZWRpdW0nIHwgJ3NtYWxsJyB8ICdiaWcnID0gJ3NtYWxsJ1xufVxuIiwiPHNwYW4gY2xhc3M9XCJzcGluLWNpcmNsZVwiIFtuZ0NsYXNzXT1cIntcbiAgJy1iaWcnOiBzaXplID09PSAnYmlnJyxcbiAgJy1tZWRpdW0nOiBzaXplID09PSAnbWVkaXVtJ1xufVwiPjwvc3Bhbj5cbiJdfQ==
23
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3Bpbm5lci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hc2tzdWl0ZS1jaXRydXMvc3JjL2xpYi9kaXJlY3RpdmVzL3NwaW5uZXIvc3Bpbm5lci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hc2tzdWl0ZS1jaXRydXMvc3JjL2xpYi9kaXJlY3RpdmVzL3NwaW5uZXIvc3Bpbm5lci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQzs7O0FBUWpELE1BQU0sT0FBTyxnQkFBZ0I7SUFMN0I7UUFNRSxjQUFTLEdBQStCLEVBQUUsQ0FBQztRQUtsQyxVQUFLLEdBQVcsRUFBRSxDQUFDO0tBQzdCO0lBSkMsSUFBYSxJQUFJLENBQUMsT0FBb0I7UUFDcEMsSUFBSSxDQUFDLFNBQVMsR0FBRyxFQUFFLENBQUMsSUFBSSxPQUFPLEVBQUUsQ0FBQyxFQUFFLElBQUksRUFBRSxDQUFDO0lBQzdDLENBQUM7OEdBTFUsZ0JBQWdCO2tHQUFoQixnQkFBZ0IsNkZDUjdCLHdIQU1ROzsyRkRFSyxnQkFBZ0I7a0JBTDVCLFNBQVM7K0JBQ0UsYUFBYTs4QkFPVixJQUFJO3NCQUFoQixLQUFLO2dCQUdHLEtBQUs7c0JBQWIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFNwaW5uZXJTaXplIH0gZnJvbSAnLi9zcGlubmVyLXNpemUudHlwZSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2FwcC1zcGlubmVyJyxcbiAgdGVtcGxhdGVVcmw6ICcuL3NwaW5uZXIuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9zcGlubmVyLmNvbXBvbmVudC5zY3NzJ10sXG59KVxuZXhwb3J0IGNsYXNzIFNwaW5uZXJDb21wb25lbnQge1xuICBzaXplQ2xhc3M6IHsgW2tleTogc3RyaW5nXTogYm9vbGVhbiB9ID0ge307XG5cbiAgQElucHV0KCkgc2V0IHNpemUobmV3U2l6ZTogU3Bpbm5lclNpemUpIHtcbiAgICB0aGlzLnNpemVDbGFzcyA9IHsgW2AtJHtuZXdTaXplfWBdOiB0cnVlIH07XG4gIH1cbiAgQElucHV0KCkgY29sb3I6IHN0cmluZyA9ICcnO1xufVxuIiwiPHNwYW5cbiAgY2xhc3M9XCJzcGluLWNpcmNsZVwiXG4gIFtuZ0NsYXNzXT1cInNpemVDbGFzc1wiXG4gIFtuZ1N0eWxlXT1cIntcbiAgICAnYm9yZGVyLWNvbG9yJzogY29sb3JcbiAgfVwiXG4+PC9zcGFuPiJdfQ==
@@ -17,6 +17,7 @@ export class SpinnerDirective {
17
17
  this.shouldShow = false;
18
18
  this.spinnerSize = 'small';
19
19
  this.spinnerBlur = true;
20
+ this.spinnerColor = '';
20
21
  this.isSpinnerExist = false;
21
22
  }
22
23
  ngOnInit() {
@@ -34,6 +35,7 @@ export class SpinnerDirective {
34
35
  if (!this.isSpinnerExist) {
35
36
  this.spinner = this.directiveView.createComponent(SpinnerComponent);
36
37
  this.spinner.instance.size = this.spinnerSize;
38
+ this.spinner.instance.color = this.spinnerColor;
37
39
  this.spinner.changeDetectorRef.detectChanges();
38
40
  if (this.spinnerBlur) {
39
41
  this.directiveElement.nativeElement.classList.add('-blur');
@@ -44,7 +46,7 @@ export class SpinnerDirective {
44
46
  }
45
47
  }
46
48
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: SpinnerDirective, deps: [{ token: i0.ViewContainerRef }, { token: i0.Renderer2 }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); }
47
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.1.6", type: SpinnerDirective, selector: "[askSpinner]", inputs: { nbSpinner: ["askSpinner", "nbSpinner"], spinnerSize: "spinnerSize", spinnerBlur: "spinnerBlur" }, host: { properties: { "class.nb-spinner-container": "this.isSpinnerExist" } }, ngImport: i0 }); }
49
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.1.6", type: SpinnerDirective, selector: "[askSpinner]", inputs: { nbSpinner: ["askSpinner", "nbSpinner"], spinnerSize: "spinnerSize", spinnerBlur: "spinnerBlur", spinnerColor: "spinnerColor" }, host: { properties: { "class.nb-spinner-container": "this.isSpinnerExist" } }, ngImport: i0 }); }
48
50
  }
49
51
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: SpinnerDirective, decorators: [{
50
52
  type: Directive,
@@ -58,8 +60,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImpor
58
60
  type: Input
59
61
  }], spinnerBlur: [{
60
62
  type: Input
63
+ }], spinnerColor: [{
64
+ type: Input
61
65
  }], isSpinnerExist: [{
62
66
  type: HostBinding,
63
67
  args: ['class.nb-spinner-container']
64
68
  }] } });
65
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3Bpbm5lci5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hc2tzdWl0ZS1jaXRydXMvc3JjL2xpYi9kaXJlY3RpdmVzL3NwaW5uZXIvc3Bpbm5lci5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUVMLFNBQVMsRUFFVCxXQUFXLEVBQ1gsS0FBSyxHQUdOLE1BQU0sZUFBZSxDQUFDO0FBQ3ZCLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHFCQUFxQixDQUFDOztBQUt2RCxNQUFNLE9BQU8sZ0JBQWdCO0lBSTNCLElBQ0ksU0FBUyxDQUFDLEdBQVk7UUFDeEIsSUFBSSxHQUFHLEVBQUU7WUFDUCxJQUFJLENBQUMsSUFBSSxFQUFFLENBQUM7U0FDYjthQUFNO1lBQ0wsSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDO1NBQ2I7SUFDSCxDQUFDO0lBT0QsWUFDVSxhQUErQixFQUMvQixRQUFtQixFQUNuQixnQkFBNEI7UUFGNUIsa0JBQWEsR0FBYixhQUFhLENBQWtCO1FBQy9CLGFBQVEsR0FBUixRQUFRLENBQVc7UUFDbkIscUJBQWdCLEdBQWhCLGdCQUFnQixDQUFZO1FBcEI5QixlQUFVLEdBQUcsS0FBSyxDQUFDO1FBWWxCLGdCQUFXLEdBQStCLE9BQU8sQ0FBQTtRQUNqRCxnQkFBVyxHQUFHLElBQUksQ0FBQTtRQUVnQixtQkFBYyxHQUFHLEtBQUssQ0FBQztJQU0vRCxDQUFDO0lBRUosUUFBUTtRQUNOLElBQUksSUFBSSxDQUFDLFVBQVUsRUFBRTtZQUNuQixJQUFJLENBQUMsSUFBSSxFQUFFLENBQUM7U0FDYjtJQUNILENBQUM7SUFFRCxJQUFJO1FBQ0YsSUFBSSxJQUFJLENBQUMsY0FBYyxFQUFFO1lBQ3ZCLElBQUksQ0FBQyxhQUFhLENBQUMsTUFBTSxFQUFFLENBQUM7WUFDNUIsSUFBSSxDQUFDLGNBQWMsR0FBRyxLQUFLLENBQUM7U0FDN0I7SUFDSCxDQUFDO0lBRUQsSUFBSTtRQUNGLElBQUksQ0FBQyxJQUFJLENBQUMsY0FBYyxFQUFFO1lBQ3hCLElBQUksQ0FBQyxPQUFPLEdBQUcsSUFBSSxDQUFDLGFBQWEsQ0FBQyxlQUFlLENBQUMsZ0JBQWdCLENBQUMsQ0FBQztZQUNwRSxJQUFJLENBQUMsT0FBTyxDQUFDLFFBQVEsQ0FBQyxJQUFJLEdBQUcsSUFBSSxDQUFDLFdBQVcsQ0FBQTtZQUM3QyxJQUFJLENBQUMsT0FBTyxDQUFDLGlCQUFpQixDQUFDLGFBQWEsRUFBRSxDQUFDO1lBQy9DLElBQUksSUFBSSxDQUFDLFdBQVcsRUFBRTtnQkFDcEIsSUFBSSxDQUFDLGdCQUFnQixDQUFDLGFBQWEsQ0FBQyxTQUFTLENBQUMsR0FBRyxDQUFDLE9BQU8sQ0FBQyxDQUFBO2FBQzNEO1lBQ0QsSUFBSSxDQUFDLFFBQVEsQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLGdCQUFnQixDQUFDLGFBQWEsRUFBRSxVQUFVLEVBQUUsVUFBVSxDQUFDLENBQUM7WUFDcEYsSUFBSSxDQUFDLFFBQVEsQ0FBQyxXQUFXLENBQ3ZCLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxhQUFhLEVBQ25DLElBQUksQ0FBQyxPQUFPLENBQUMsUUFBUSxDQUFDLGFBQWEsQ0FDcEMsQ0FBQztZQUNGLElBQUksQ0FBQyxjQUFjLEdBQUcsSUFBSSxDQUFDO1NBQzVCO0lBQ0gsQ0FBQzs4R0FwRFUsZ0JBQWdCO2tHQUFoQixnQkFBZ0I7OzJGQUFoQixnQkFBZ0I7a0JBSDVCLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLGNBQWM7aUJBQ3pCO3dKQU1LLFNBQVM7c0JBRFosS0FBSzt1QkFBQyxZQUFZO2dCQVNWLFdBQVc7c0JBQW5CLEtBQUs7Z0JBQ0csV0FBVztzQkFBbkIsS0FBSztnQkFFcUMsY0FBYztzQkFBeEQsV0FBVzt1QkFBQyw0QkFBNEIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBDb21wb25lbnRSZWYsXG4gIERpcmVjdGl2ZSxcbiAgRWxlbWVudFJlZixcbiAgSG9zdEJpbmRpbmcsXG4gIElucHV0LFxuICBSZW5kZXJlcjIsXG4gIFZpZXdDb250YWluZXJSZWYsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgU3Bpbm5lckNvbXBvbmVudCB9IGZyb20gJy4vc3Bpbm5lci5jb21wb25lbnQnO1xuXG5ARGlyZWN0aXZlKHtcbiAgc2VsZWN0b3I6ICdbYXNrU3Bpbm5lcl0nLFxufSlcbmV4cG9ydCBjbGFzcyBTcGlubmVyRGlyZWN0aXZlIHtcbiAgcHJpdmF0ZSBzaG91bGRTaG93ID0gZmFsc2U7XG4gIHNwaW5uZXI6IENvbXBvbmVudFJlZjxTcGlubmVyQ29tcG9uZW50PiB8IHVuZGVmaW5lZDtcblxuICBASW5wdXQoJ2Fza1NwaW5uZXInKVxuICBzZXQgbmJTcGlubmVyKHZhbDogYm9vbGVhbikge1xuICAgIGlmICh2YWwpIHtcbiAgICAgIHRoaXMuc2hvdygpO1xuICAgIH0gZWxzZSB7XG4gICAgICB0aGlzLmhpZGUoKTtcbiAgICB9XG4gIH1cblxuICBASW5wdXQoKSBzcGlubmVyU2l6ZTogJ3NtYWxsJyB8ICdtZWRpdW0nIHwgJ2JpZycgPSAnc21hbGwnXG4gIEBJbnB1dCgpIHNwaW5uZXJCbHVyID0gdHJ1ZVxuXG4gIEBIb3N0QmluZGluZygnY2xhc3MubmItc3Bpbm5lci1jb250YWluZXInKSBpc1NwaW5uZXJFeGlzdCA9IGZhbHNlO1xuXG4gIGNvbnN0cnVjdG9yKFxuICAgIHByaXZhdGUgZGlyZWN0aXZlVmlldzogVmlld0NvbnRhaW5lclJlZixcbiAgICBwcml2YXRlIHJlbmRlcmVyOiBSZW5kZXJlcjIsXG4gICAgcHJpdmF0ZSBkaXJlY3RpdmVFbGVtZW50OiBFbGVtZW50UmVmXG4gICkge31cblxuICBuZ09uSW5pdCgpIHtcbiAgICBpZiAodGhpcy5zaG91bGRTaG93KSB7XG4gICAgICB0aGlzLnNob3coKTtcbiAgICB9XG4gIH1cblxuICBoaWRlKCkge1xuICAgIGlmICh0aGlzLmlzU3Bpbm5lckV4aXN0KSB7XG4gICAgICB0aGlzLmRpcmVjdGl2ZVZpZXcucmVtb3ZlKCk7XG4gICAgICB0aGlzLmlzU3Bpbm5lckV4aXN0ID0gZmFsc2U7XG4gICAgfVxuICB9XG5cbiAgc2hvdygpIHtcbiAgICBpZiAoIXRoaXMuaXNTcGlubmVyRXhpc3QpIHtcbiAgICAgIHRoaXMuc3Bpbm5lciA9IHRoaXMuZGlyZWN0aXZlVmlldy5jcmVhdGVDb21wb25lbnQoU3Bpbm5lckNvbXBvbmVudCk7XG4gICAgICB0aGlzLnNwaW5uZXIuaW5zdGFuY2Uuc2l6ZSA9IHRoaXMuc3Bpbm5lclNpemVcbiAgICAgIHRoaXMuc3Bpbm5lci5jaGFuZ2VEZXRlY3RvclJlZi5kZXRlY3RDaGFuZ2VzKCk7XG4gICAgICBpZiAodGhpcy5zcGlubmVyQmx1cikge1xuICAgICAgICB0aGlzLmRpcmVjdGl2ZUVsZW1lbnQubmF0aXZlRWxlbWVudC5jbGFzc0xpc3QuYWRkKCctYmx1cicpXG4gICAgICB9XG4gICAgICB0aGlzLnJlbmRlcmVyLnNldFN0eWxlKHRoaXMuZGlyZWN0aXZlRWxlbWVudC5uYXRpdmVFbGVtZW50LCAncG9zaXRpb24nLCAncmVsYXRpdmUnKTtcbiAgICAgIHRoaXMucmVuZGVyZXIuYXBwZW5kQ2hpbGQoXG4gICAgICAgIHRoaXMuZGlyZWN0aXZlRWxlbWVudC5uYXRpdmVFbGVtZW50LFxuICAgICAgICB0aGlzLnNwaW5uZXIubG9jYXRpb24ubmF0aXZlRWxlbWVudFxuICAgICAgKTtcbiAgICAgIHRoaXMuaXNTcGlubmVyRXhpc3QgPSB0cnVlO1xuICAgIH1cbiAgfVxufVxuIl19
69
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3Bpbm5lci5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hc2tzdWl0ZS1jaXRydXMvc3JjL2xpYi9kaXJlY3RpdmVzL3NwaW5uZXIvc3Bpbm5lci5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUVMLFNBQVMsRUFFVCxXQUFXLEVBQ1gsS0FBSyxHQUdOLE1BQU0sZUFBZSxDQUFDO0FBQ3ZCLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHFCQUFxQixDQUFDOztBQU12RCxNQUFNLE9BQU8sZ0JBQWdCO0lBSTNCLElBQ0ksU0FBUyxDQUFDLEdBQVk7UUFDeEIsSUFBSSxHQUFHLEVBQUU7WUFDUCxJQUFJLENBQUMsSUFBSSxFQUFFLENBQUM7U0FDYjthQUFNO1lBQ0wsSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDO1NBQ2I7SUFDSCxDQUFDO0lBUUQsWUFDVSxhQUErQixFQUMvQixRQUFtQixFQUNuQixnQkFBNEI7UUFGNUIsa0JBQWEsR0FBYixhQUFhLENBQWtCO1FBQy9CLGFBQVEsR0FBUixRQUFRLENBQVc7UUFDbkIscUJBQWdCLEdBQWhCLGdCQUFnQixDQUFZO1FBckI5QixlQUFVLEdBQUcsS0FBSyxDQUFDO1FBWWxCLGdCQUFXLEdBQWdCLE9BQU8sQ0FBQTtRQUNsQyxnQkFBVyxHQUFHLElBQUksQ0FBQTtRQUNsQixpQkFBWSxHQUFXLEVBQUUsQ0FBQTtRQUVTLG1CQUFjLEdBQUcsS0FBSyxDQUFDO0lBTS9ELENBQUM7SUFFSixRQUFRO1FBQ04sSUFBSSxJQUFJLENBQUMsVUFBVSxFQUFFO1lBQ25CLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQztTQUNiO0lBQ0gsQ0FBQztJQUVELElBQUk7UUFDRixJQUFJLElBQUksQ0FBQyxjQUFjLEVBQUU7WUFDdkIsSUFBSSxDQUFDLGFBQWEsQ0FBQyxNQUFNLEVBQUUsQ0FBQztZQUM1QixJQUFJLENBQUMsY0FBYyxHQUFHLEtBQUssQ0FBQztTQUM3QjtJQUNILENBQUM7SUFFRCxJQUFJO1FBQ0YsSUFBSSxDQUFDLElBQUksQ0FBQyxjQUFjLEVBQUU7WUFDeEIsSUFBSSxDQUFDLE9BQU8sR0FBRyxJQUFJLENBQUMsYUFBYSxDQUFDLGVBQWUsQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDO1lBQ3BFLElBQUksQ0FBQyxPQUFPLENBQUMsUUFBUSxDQUFDLElBQUksR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFBO1lBQzdDLElBQUksQ0FBQyxPQUFPLENBQUMsUUFBUSxDQUFDLEtBQUssR0FBRyxJQUFJLENBQUMsWUFBWSxDQUFBO1lBQy9DLElBQUksQ0FBQyxPQUFPLENBQUMsaUJBQWlCLENBQUMsYUFBYSxFQUFFLENBQUM7WUFDL0MsSUFBSSxJQUFJLENBQUMsV0FBVyxFQUFFO2dCQUNwQixJQUFJLENBQUMsZ0JBQWdCLENBQUMsYUFBYSxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsT0FBTyxDQUFDLENBQUE7YUFDM0Q7WUFDRCxJQUFJLENBQUMsUUFBUSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsYUFBYSxFQUFFLFVBQVUsRUFBRSxVQUFVLENBQUMsQ0FBQztZQUNwRixJQUFJLENBQUMsUUFBUSxDQUFDLFdBQVcsQ0FDdkIsSUFBSSxDQUFDLGdCQUFnQixDQUFDLGFBQWEsRUFDbkMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxRQUFRLENBQUMsYUFBYSxDQUNwQyxDQUFDO1lBQ0YsSUFBSSxDQUFDLGNBQWMsR0FBRyxJQUFJLENBQUM7U0FDNUI7SUFDSCxDQUFDOzhHQXREVSxnQkFBZ0I7a0dBQWhCLGdCQUFnQjs7MkZBQWhCLGdCQUFnQjtrQkFINUIsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsY0FBYztpQkFDekI7d0pBTUssU0FBUztzQkFEWixLQUFLO3VCQUFDLFlBQVk7Z0JBU1YsV0FBVztzQkFBbkIsS0FBSztnQkFDRyxXQUFXO3NCQUFuQixLQUFLO2dCQUNHLFlBQVk7c0JBQXBCLEtBQUs7Z0JBRXFDLGNBQWM7c0JBQXhELFdBQVc7dUJBQUMsNEJBQTRCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgQ29tcG9uZW50UmVmLFxuICBEaXJlY3RpdmUsXG4gIEVsZW1lbnRSZWYsXG4gIEhvc3RCaW5kaW5nLFxuICBJbnB1dCxcbiAgUmVuZGVyZXIyLFxuICBWaWV3Q29udGFpbmVyUmVmLFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFNwaW5uZXJDb21wb25lbnQgfSBmcm9tICcuL3NwaW5uZXIuY29tcG9uZW50JztcbmltcG9ydCB7IFNwaW5uZXJTaXplIH0gZnJvbSAnLi9zcGlubmVyLXNpemUudHlwZSc7XG5cbkBEaXJlY3RpdmUoe1xuICBzZWxlY3RvcjogJ1thc2tTcGlubmVyXScsXG59KVxuZXhwb3J0IGNsYXNzIFNwaW5uZXJEaXJlY3RpdmUge1xuICBwcml2YXRlIHNob3VsZFNob3cgPSBmYWxzZTtcbiAgc3Bpbm5lcjogQ29tcG9uZW50UmVmPFNwaW5uZXJDb21wb25lbnQ+IHwgdW5kZWZpbmVkO1xuXG4gIEBJbnB1dCgnYXNrU3Bpbm5lcicpXG4gIHNldCBuYlNwaW5uZXIodmFsOiBib29sZWFuKSB7XG4gICAgaWYgKHZhbCkge1xuICAgICAgdGhpcy5zaG93KCk7XG4gICAgfSBlbHNlIHtcbiAgICAgIHRoaXMuaGlkZSgpO1xuICAgIH1cbiAgfVxuXG4gIEBJbnB1dCgpIHNwaW5uZXJTaXplOiBTcGlubmVyU2l6ZSA9ICdzbWFsbCdcbiAgQElucHV0KCkgc3Bpbm5lckJsdXIgPSB0cnVlXG4gIEBJbnB1dCgpIHNwaW5uZXJDb2xvcjogc3RyaW5nID0gJydcblxuICBASG9zdEJpbmRpbmcoJ2NsYXNzLm5iLXNwaW5uZXItY29udGFpbmVyJykgaXNTcGlubmVyRXhpc3QgPSBmYWxzZTtcblxuICBjb25zdHJ1Y3RvcihcbiAgICBwcml2YXRlIGRpcmVjdGl2ZVZpZXc6IFZpZXdDb250YWluZXJSZWYsXG4gICAgcHJpdmF0ZSByZW5kZXJlcjogUmVuZGVyZXIyLFxuICAgIHByaXZhdGUgZGlyZWN0aXZlRWxlbWVudDogRWxlbWVudFJlZlxuICApIHt9XG5cbiAgbmdPbkluaXQoKSB7XG4gICAgaWYgKHRoaXMuc2hvdWxkU2hvdykge1xuICAgICAgdGhpcy5zaG93KCk7XG4gICAgfVxuICB9XG5cbiAgaGlkZSgpIHtcbiAgICBpZiAodGhpcy5pc1NwaW5uZXJFeGlzdCkge1xuICAgICAgdGhpcy5kaXJlY3RpdmVWaWV3LnJlbW92ZSgpO1xuICAgICAgdGhpcy5pc1NwaW5uZXJFeGlzdCA9IGZhbHNlO1xuICAgIH1cbiAgfVxuXG4gIHNob3coKSB7XG4gICAgaWYgKCF0aGlzLmlzU3Bpbm5lckV4aXN0KSB7XG4gICAgICB0aGlzLnNwaW5uZXIgPSB0aGlzLmRpcmVjdGl2ZVZpZXcuY3JlYXRlQ29tcG9uZW50KFNwaW5uZXJDb21wb25lbnQpO1xuICAgICAgdGhpcy5zcGlubmVyLmluc3RhbmNlLnNpemUgPSB0aGlzLnNwaW5uZXJTaXplXG4gICAgICB0aGlzLnNwaW5uZXIuaW5zdGFuY2UuY29sb3IgPSB0aGlzLnNwaW5uZXJDb2xvclxuICAgICAgdGhpcy5zcGlubmVyLmNoYW5nZURldGVjdG9yUmVmLmRldGVjdENoYW5nZXMoKTtcbiAgICAgIGlmICh0aGlzLnNwaW5uZXJCbHVyKSB7XG4gICAgICAgIHRoaXMuZGlyZWN0aXZlRWxlbWVudC5uYXRpdmVFbGVtZW50LmNsYXNzTGlzdC5hZGQoJy1ibHVyJylcbiAgICAgIH1cbiAgICAgIHRoaXMucmVuZGVyZXIuc2V0U3R5bGUodGhpcy5kaXJlY3RpdmVFbGVtZW50Lm5hdGl2ZUVsZW1lbnQsICdwb3NpdGlvbicsICdyZWxhdGl2ZScpO1xuICAgICAgdGhpcy5yZW5kZXJlci5hcHBlbmRDaGlsZChcbiAgICAgICAgdGhpcy5kaXJlY3RpdmVFbGVtZW50Lm5hdGl2ZUVsZW1lbnQsXG4gICAgICAgIHRoaXMuc3Bpbm5lci5sb2NhdGlvbi5uYXRpdmVFbGVtZW50XG4gICAgICApO1xuICAgICAgdGhpcy5pc1NwaW5uZXJFeGlzdCA9IHRydWU7XG4gICAgfVxuICB9XG59XG4iXX0=
@@ -6,7 +6,7 @@ import * as i1$2 from '@angular/material/tooltip';
6
6
  import { MatTooltip, MatTooltipModule } from '@angular/material/tooltip';
7
7
  import * as i1$1 from '@angular/forms';
8
8
  import { NG_VALUE_ACCESSOR, FormControl, FormsModule, ReactiveFormsModule } from '@angular/forms';
9
- import { debounceTime, tap, map, Subject } from 'rxjs';
9
+ import { debounceTime, tap, map, fromEvent, Subject } from 'rxjs';
10
10
  import { TemplatePortal, ComponentPortal } from '@angular/cdk/portal';
11
11
  import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
12
12
  import * as i1$3 from '@angular/cdk/overlay';
@@ -677,7 +677,7 @@ class AutocompleteComponent {
677
677
  }
678
678
  showOptions() {
679
679
  this.closed = false;
680
- if (!this._overlayRef && this.wrapper) {
680
+ if (this.wrapper) {
681
681
  this._overlayRef = this.getOverlayConfig(this.wrapper);
682
682
  this._portal = new TemplatePortal(this.overlayContent, this.viewContainerRef);
683
683
  }
@@ -685,6 +685,8 @@ class AutocompleteComponent {
685
685
  this.updateValidation();
686
686
  if (this.paginatedFilteredOptions.length === 0)
687
687
  this.getMoreItems();
688
+ this.scrollSub = fromEvent(window, 'scroll')
689
+ .subscribe(this.onScroll.bind(this));
688
690
  }
689
691
  getOverlayConfig(wrapper) {
690
692
  return this.overlay.create({
@@ -699,6 +701,9 @@ class AutocompleteComponent {
699
701
  }])
700
702
  });
701
703
  }
704
+ onScroll() {
705
+ this._overlayRef?.updatePosition();
706
+ }
702
707
  hideOptions() {
703
708
  this.closed = true;
704
709
  this.chipsCollapsed = true;
@@ -708,6 +713,7 @@ class AutocompleteComponent {
708
713
  this.paginatedFilteredOptions = [];
709
714
  this.updateValidation();
710
715
  this.change.detectChanges();
716
+ this.scrollSub?.unsubscribe();
711
717
  }
712
718
  handleClick(event) {
713
719
  if (!this.closed
@@ -1279,7 +1285,7 @@ class SkeletonComponent {
1279
1285
  this.barsCount = 0;
1280
1286
  this.baseTheme = {
1281
1287
  'border-radius': '',
1282
- height: 100 + 'px',
1288
+ height: '100px',
1283
1289
  margin: 0,
1284
1290
  display: 'block',
1285
1291
  };
@@ -1289,7 +1295,7 @@ class SkeletonComponent {
1289
1295
  this.barsCount = Math.round(height / this.barsHeight) || 1;
1290
1296
  this.baseTheme = {
1291
1297
  ...this.baseTheme,
1292
- ...(this.appearance !== 'circle' && { 'border-radius': 5 + 'px' }),
1298
+ ...(this.appearance !== 'circle' && { 'border-radius': '5px' }),
1293
1299
  ...this.customTheme,
1294
1300
  };
1295
1301
  }
@@ -1389,16 +1395,22 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImpor
1389
1395
 
1390
1396
  class SpinnerComponent {
1391
1397
  constructor() {
1392
- this.size = 'small';
1398
+ this.sizeClass = {};
1399
+ this.color = '';
1400
+ }
1401
+ set size(newSize) {
1402
+ this.sizeClass = { [`-${newSize}`]: true };
1393
1403
  }
1394
1404
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: SpinnerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
1395
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.6", type: SpinnerComponent, selector: "app-spinner", inputs: { size: "size" }, ngImport: i0, template: "<span class=\"spin-circle\" [ngClass]=\"{\n '-big': size === 'big',\n '-medium': size === 'medium'\n}\"></span>\n", styles: [":host{position:absolute;border-radius:inherit;inset:0;overflow:hidden;z-index:9999;display:flex;justify-content:center;align-items:center;visibility:visible;transition:background-color .1s,box-shadow .1s}:host.-blur:before{content:\"\";position:absolute;inset:0;background-color:var(--grey-200);opacity:.2;z-index:-1}:host .spin-circle{opacity:1;animation:spin .8s infinite linear;border-radius:50%;border:2px solid var(--grey-400);border-top-color:transparent;width:1em;height:1em}:host .spin-circle.-medium{width:2em;height:2em;border:3px solid var(--grey-400);border-top-color:transparent}:host .spin-circle.-big{width:4em;height:4em;border:5px solid var(--grey-400);border-top-color:transparent}@keyframes spin{0%{transform:rotate(0)}40%{transform:rotate(230deg)}to{transform:rotate(360deg)}}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }] }); }
1405
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.6", type: SpinnerComponent, selector: "app-spinner", inputs: { size: "size", color: "color" }, ngImport: i0, template: "<span\n class=\"spin-circle\"\n [ngClass]=\"sizeClass\"\n [ngStyle]=\"{\n 'border-color': color\n }\"\n></span>", styles: [":host{position:absolute;border-radius:inherit;inset:0;overflow:hidden;z-index:9999;display:flex;justify-content:center;align-items:center;visibility:visible;transition:background-color .1s,box-shadow .1s}:host.-blur:before{content:\"\";position:absolute;inset:0;background-color:var(--grey-200);opacity:.2;z-index:-1}:host .spin-circle{opacity:1;animation:spin .8s infinite linear;border-radius:50%;border:2px solid var(--grey-400);border-top-color:transparent!important;width:1em;height:1em}:host .spin-circle.-medium{width:2em;height:2em;border-width:3px}:host .spin-circle.-medium-big{width:24px;height:24px;border-width:2px}:host .spin-circle.-big{width:4em;height:4em;border-width:5px}@keyframes spin{0%{transform:rotate(0)}40%{transform:rotate(230deg)}to{transform:rotate(360deg)}}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }] }); }
1396
1406
  }
1397
1407
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: SpinnerComponent, decorators: [{
1398
1408
  type: Component,
1399
- args: [{ selector: 'app-spinner', template: "<span class=\"spin-circle\" [ngClass]=\"{\n '-big': size === 'big',\n '-medium': size === 'medium'\n}\"></span>\n", styles: [":host{position:absolute;border-radius:inherit;inset:0;overflow:hidden;z-index:9999;display:flex;justify-content:center;align-items:center;visibility:visible;transition:background-color .1s,box-shadow .1s}:host.-blur:before{content:\"\";position:absolute;inset:0;background-color:var(--grey-200);opacity:.2;z-index:-1}:host .spin-circle{opacity:1;animation:spin .8s infinite linear;border-radius:50%;border:2px solid var(--grey-400);border-top-color:transparent;width:1em;height:1em}:host .spin-circle.-medium{width:2em;height:2em;border:3px solid var(--grey-400);border-top-color:transparent}:host .spin-circle.-big{width:4em;height:4em;border:5px solid var(--grey-400);border-top-color:transparent}@keyframes spin{0%{transform:rotate(0)}40%{transform:rotate(230deg)}to{transform:rotate(360deg)}}\n"] }]
1409
+ args: [{ selector: 'app-spinner', template: "<span\n class=\"spin-circle\"\n [ngClass]=\"sizeClass\"\n [ngStyle]=\"{\n 'border-color': color\n }\"\n></span>", styles: [":host{position:absolute;border-radius:inherit;inset:0;overflow:hidden;z-index:9999;display:flex;justify-content:center;align-items:center;visibility:visible;transition:background-color .1s,box-shadow .1s}:host.-blur:before{content:\"\";position:absolute;inset:0;background-color:var(--grey-200);opacity:.2;z-index:-1}:host .spin-circle{opacity:1;animation:spin .8s infinite linear;border-radius:50%;border:2px solid var(--grey-400);border-top-color:transparent!important;width:1em;height:1em}:host .spin-circle.-medium{width:2em;height:2em;border-width:3px}:host .spin-circle.-medium-big{width:24px;height:24px;border-width:2px}:host .spin-circle.-big{width:4em;height:4em;border-width:5px}@keyframes spin{0%{transform:rotate(0)}40%{transform:rotate(230deg)}to{transform:rotate(360deg)}}\n"] }]
1400
1410
  }], propDecorators: { size: [{
1401
1411
  type: Input
1412
+ }], color: [{
1413
+ type: Input
1402
1414
  }] } });
1403
1415
 
1404
1416
  class BadgeDirective {
@@ -1526,6 +1538,7 @@ class SpinnerDirective {
1526
1538
  this.shouldShow = false;
1527
1539
  this.spinnerSize = 'small';
1528
1540
  this.spinnerBlur = true;
1541
+ this.spinnerColor = '';
1529
1542
  this.isSpinnerExist = false;
1530
1543
  }
1531
1544
  ngOnInit() {
@@ -1543,6 +1556,7 @@ class SpinnerDirective {
1543
1556
  if (!this.isSpinnerExist) {
1544
1557
  this.spinner = this.directiveView.createComponent(SpinnerComponent);
1545
1558
  this.spinner.instance.size = this.spinnerSize;
1559
+ this.spinner.instance.color = this.spinnerColor;
1546
1560
  this.spinner.changeDetectorRef.detectChanges();
1547
1561
  if (this.spinnerBlur) {
1548
1562
  this.directiveElement.nativeElement.classList.add('-blur');
@@ -1553,7 +1567,7 @@ class SpinnerDirective {
1553
1567
  }
1554
1568
  }
1555
1569
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: SpinnerDirective, deps: [{ token: i0.ViewContainerRef }, { token: i0.Renderer2 }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); }
1556
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.1.6", type: SpinnerDirective, selector: "[askSpinner]", inputs: { nbSpinner: ["askSpinner", "nbSpinner"], spinnerSize: "spinnerSize", spinnerBlur: "spinnerBlur" }, host: { properties: { "class.nb-spinner-container": "this.isSpinnerExist" } }, ngImport: i0 }); }
1570
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.1.6", type: SpinnerDirective, selector: "[askSpinner]", inputs: { nbSpinner: ["askSpinner", "nbSpinner"], spinnerSize: "spinnerSize", spinnerBlur: "spinnerBlur", spinnerColor: "spinnerColor" }, host: { properties: { "class.nb-spinner-container": "this.isSpinnerExist" } }, ngImport: i0 }); }
1557
1571
  }
1558
1572
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: SpinnerDirective, decorators: [{
1559
1573
  type: Directive,
@@ -1567,6 +1581,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImpor
1567
1581
  type: Input
1568
1582
  }], spinnerBlur: [{
1569
1583
  type: Input
1584
+ }], spinnerColor: [{
1585
+ type: Input
1570
1586
  }], isSpinnerExist: [{
1571
1587
  type: HostBinding,
1572
1588
  args: ['class.nb-spinner-container']