@acpaas-ui/ngx-forms 6.0.0-beta.1 → 6.0.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.
@@ -2,7 +2,7 @@ import { ChangeDetectionStrategy, Component, EventEmitter, forwardRef, Inject, I
2
2
  import { Subject } from 'rxjs';
3
3
  import { takeUntil } from 'rxjs/operators';
4
4
  import { NG_VALIDATORS, NG_VALUE_ACCESSOR, } from '@angular/forms';
5
- import { DateHelper } from '@acpaas-ui/js-date-utils';
5
+ import { DateHelper } from '@acpaas-ui/ngx-utils';
6
6
  import { FlyoutDirective } from '@acpaas-ui/ngx-flyout';
7
7
  import { CALENDAR_DEFAULT_MONTH_LABELS, CALENDAR_DEFAULT_WEEKDAY_LABELS, CALENDAR_MONTH_LABELS, CALENDAR_WEEKDAY_LABELS, } from '@acpaas-ui/ngx-calendar';
8
8
  import { DATEPICKER_SEPARATOR_CHAR, DATEPICKER_DEFAULT_ERROR_LABELS, DATEPICKER_ERROR_LABELS, } from '../../datepicker.conf';
@@ -270,4 +270,4 @@ export class DatepickerComponent {
270
270
  }], blur: [{
271
271
  type: Output
272
272
  }] }); })();
273
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datepicker.component.js","sourceRoot":"","sources":["../../../../../../src/lib/datepicker/components/datepicker/datepicker.component.ts","../../../../../../src/lib/datepicker/components/datepicker/datepicker.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  forwardRef,\n  Inject,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  SimpleChanges,\n  ViewChild,\n} from '@angular/core';\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport {\n  ControlValueAccessor,\n  UntypedFormBuilder,\n  UntypedFormControl,\n  NG_VALIDATORS,\n  NG_VALUE_ACCESSOR,\n} from '@angular/forms';\nimport { DateHelper, DateRange } from '@acpaas-ui/js-date-utils';\nimport { FlyoutDirective } from '@acpaas-ui/ngx-flyout';\nimport {\n  CALENDAR_DEFAULT_MONTH_LABELS,\n  CALENDAR_DEFAULT_WEEKDAY_LABELS,\n  CALENDAR_MONTH_LABELS,\n  CALENDAR_WEEKDAY_LABELS,\n  CalendarService,\n  DatepickerResult,\n  WeekdayLabelsConfig,\n  MonthLabelsConfig,\n} from '@acpaas-ui/ngx-calendar';\n\nimport {\n  DATEPICKER_SEPARATOR_CHAR,\n  DATEPICKER_DEFAULT_ERROR_LABELS,\n  DATEPICKER_ERROR_LABELS,\n} from '../../datepicker.conf';\nimport { DatepickerValidationErrors } from '../../types/datepicker.types';\nimport { Interval, IntervalBuilder } from '@acpaas-ui/ngx-utils';\n\n@Component({\n  selector: 'aui-datepicker',\n  templateUrl: './datepicker.component.html',\n  styleUrls: ['./datepicker.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => DatepickerComponent), // eslint-disable-line @angular-eslint/no-forward-ref\n      multi: true,\n    },\n    {\n      provide: NG_VALIDATORS,\n      useExisting: forwardRef(() => DatepickerComponent), // eslint-disable-line @angular-eslint/no-forward-ref\n      multi: true,\n    },\n  ],\n})\nexport class DatepickerComponent implements OnInit, OnChanges, OnDestroy, ControlValueAccessor {\n  @ViewChild(FlyoutDirective, { static: true }) flyout: FlyoutDirective;\n  @Input() id: string;\n  @Input() name: string;\n  @Input() placeholder = 'dd/mm/yyyy';\n  @Input() label: string;\n  @Input() description: string;\n  @Input() range: DateRange;\n  @Input()\n  min: Date | null;\n  @Input()\n  max: Date | null;\n  @Input() autocomplete: 'off';\n  @Input() weekdayLabels: WeekdayLabelsConfig;\n  @Input() monthLabels: MonthLabelsConfig;\n\n  // eslint-disable-next-line @angular-eslint/no-output-native\n  @Output() blur = new EventEmitter<Event>();\n\n  public formControl: UntypedFormControl;\n  public selectedDate: Date;\n  public isDisabled = false;\n  public interval: Interval.IInterval<Date>;\n\n  private componentDestroyed$: Subject<boolean> = new Subject<boolean>();\n\n  constructor(\n    @Inject(CALENDAR_MONTH_LABELS) private moduleMonthLabels = CALENDAR_DEFAULT_MONTH_LABELS,\n    @Inject(CALENDAR_WEEKDAY_LABELS) private moduleWeekdayLabels = CALENDAR_DEFAULT_WEEKDAY_LABELS,\n    @Inject(DATEPICKER_ERROR_LABELS) private errorLabels = DATEPICKER_DEFAULT_ERROR_LABELS,\n    public calendarService: CalendarService,\n    private formBuilder: UntypedFormBuilder,\n    private ref: ChangeDetectorRef\n  ) {}\n\n  public ngOnInit(): void {\n    this.weekdayLabels = this.weekdayLabels || this.moduleWeekdayLabels;\n    this.monthLabels = this.monthLabels || this.moduleMonthLabels;\n    this.createInterval();\n    this.formControl = this.formBuilder.control({ value: '', disabled: this.isDisabled });\n    this.formControl.valueChanges.pipe(takeUntil(this.componentDestroyed$)).subscribe((value) => {\n      if (value) {\n        const format = value.split(DATEPICKER_SEPARATOR_CHAR).reverse().join('-');\n        const date = DateHelper.parseDate(format, 'yyyy-MM-dd');\n        if (date) {\n          this.selectedDate = date;\n          this.onChange(date.toISOString());\n        } else {\n          // Change value with original value (and not null or '') so we can add an error in the validate function\n          this.onChange(value);\n        }\n      } else {\n        this.selectedDate = null;\n        this.onChange('');\n      }\n    });\n  }\n\n  public ngOnChanges(changes: SimpleChanges): void {\n    if (changes.min || changes.max) {\n      this.createInterval();\n    }\n  }\n\n  public ngOnDestroy(): void {\n    this.componentDestroyed$.next(true);\n    this.componentDestroyed$.complete();\n  }\n\n  private createInterval() {\n    if (!this.min && !this.max) {\n      return;\n    }\n    // Create an interval if min/max is filled in\n    this.interval = IntervalBuilder.dateInterval(\n      this.min ? new Date(this.min) : null,\n      this.max ? new Date(this.max) : null\n    )\n      .not()\n      .build();\n  }\n\n  public writeValue(value: string | Date): void {\n    this.selectedDate =\n      typeof value === 'string'\n        ? this.isISODateFormat(value)\n          ? new Date(value)\n          : DateHelper.parseDate(value, 'dd/MM/yyyy')\n        : value;\n    const dateString = this.selectedDate ? this.formatDate(this.selectedDate) : '';\n    this.formControl.setValue(dateString);\n  }\n\n  public registerOnChange(onChange: (res: any) => void): void {\n    this.onChange = onChange;\n  }\n\n  public registerOnTouched(onTouched: (_: any) => void): void {\n    this.onTouched = onTouched;\n  }\n\n  public setDisabledState(isDisabled: boolean): void {\n    this.isDisabled = isDisabled;\n\n    if (this.formControl) {\n      if (isDisabled && this.formControl.enabled) {\n        this.formControl.disable();\n      } else if (!isDisabled && this.formControl.disabled) {\n        this.formControl.enable();\n      }\n    }\n\n    this.ref.markForCheck();\n  }\n\n  public selectDateFromCalendar(result: DatepickerResult): void {\n    if (result.complete) {\n      this.formControl.setValue(this.formatDate(result.date));\n      this.flyout.close();\n    }\n  }\n\n  public formatDate(date: Date): string {\n    return DateHelper.formatDate(date, 'DD/MM/YYYY', {\n      leadingZero: true,\n      monthLabels: this.monthLabels,\n      weekdayLabels: this.weekdayLabels,\n    });\n  }\n\n  public validate(ctrl: UntypedFormControl): DatepickerValidationErrors {\n    // no error on empty value (add required validator in app)\n    if (ctrl.value === '' || ctrl.value === null) {\n      return null;\n    }\n\n    // throw format error if no valid date was provided\n    const date = DateHelper.parseDate(ctrl.value);\n    if (!date) {\n      return {\n        format: this.errorLabels.ERRORS_INVALID_DATE,\n      };\n    }\n\n    // no error if valid date an no range provided\n    if (!this.range || !this.range.length) {\n      return null;\n    }\n\n    // throw error when out of range\n    const range = this.calendarService.getRangeForDate(date, this.range);\n\n    return range.indexOf(date.getDate()) >= 0\n      ? {\n          range: this.errorLabels.ERRORS_INVALID_RANGE,\n        }\n      : null;\n  }\n\n  public handleBlur(e: Event): void {\n    this.blur.emit(e);\n    this.onTouched(e);\n  }\n\n  private onChange: (res: any) => void = () => undefined;\n\n  private onTouched: (_: any) => void = () => undefined;\n\n  private isISODateFormat(value: string) {\n    if (typeof value !== 'string') {\n      return false;\n    }\n    return value.match(/\\d{4}-\\d{2}-\\d{2}T.*/);\n  }\n}\n","<div aria-haspopup=\"grid\" auiFlyout class=\"aui-datepicker a-input has-icon-right\">\n  <label class=\"a-input__label\" for=\"id\">{{ label }}</label>\n  <small class=\"a-input__description\" id=\"id\"> {{ description }}</small>\n  <div class=\"a-input__wrapper\">\n    <input\n      (blur)=\"handleBlur($event)\"\n      [attr.disabled]=\"isDisabled ? true : null\"\n      [autocomplete]=\"autocomplete\"\n      [formControl]=\"formControl\"\n      id=\"{{ id }}\"\n      label=\"Pick date\"\n      description=\"Description\"\n      name=\"{{ name }}\"\n      placeholder=\"{{ placeholder }}\"\n      type=\"text\"\n    />\n    <aui-icon *ngIf=\"isDisabled\" name=\"ai-calendar-3\" role=\"button\" tabindex=\"0\"/>\n    <ng-container *ngIf=\"!isDisabled\">\n      <aui-icon\n        auiFlyoutAction\n        [openOnFocus]=\"false\"\n        name=\"ai-calendar-3\"\n        className=\"is-clickable\"\n        role=\"button\"\n        tabindex=\"0\"\n      ></aui-icon>\n    </ng-container>\n\n    <ng-container *ngIf=\"!isDisabled\">\n      <div auiFlyoutZone class=\"m-datepicker m-datepicker--fixed\" role=\"dialog\">\n        <aui-calendar\n          (selectDate)=\"selectDateFromCalendar($event)\"\n          [range]=\"range\"\n          [selectedDate]=\"selectedDate\"\n          [interval]=\"interval\"\n          [weekdayLabels]=\"weekdayLabels\"\n          [monthLabels]=\"monthLabels\"\n        ></aui-calendar>\n      </div>\n    </ng-container>\n  </div>\n</div>\n"]}
273
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datepicker.component.js","sourceRoot":"","sources":["../../../../../../src/lib/datepicker/components/datepicker/datepicker.component.ts","../../../../../../src/lib/datepicker/components/datepicker/datepicker.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  forwardRef,\n  Inject,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  SimpleChanges,\n  ViewChild,\n} from '@angular/core';\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport {\n  ControlValueAccessor,\n  UntypedFormBuilder,\n  UntypedFormControl,\n  NG_VALIDATORS,\n  NG_VALUE_ACCESSOR,\n} from '@angular/forms';\nimport { DateHelper, DateRange } from '@acpaas-ui/ngx-utils';\nimport { FlyoutDirective } from '@acpaas-ui/ngx-flyout';\nimport {\n  CALENDAR_DEFAULT_MONTH_LABELS,\n  CALENDAR_DEFAULT_WEEKDAY_LABELS,\n  CALENDAR_MONTH_LABELS,\n  CALENDAR_WEEKDAY_LABELS,\n  CalendarService,\n  DatepickerResult,\n  WeekdayLabelsConfig,\n  MonthLabelsConfig,\n} from '@acpaas-ui/ngx-calendar';\n\nimport {\n  DATEPICKER_SEPARATOR_CHAR,\n  DATEPICKER_DEFAULT_ERROR_LABELS,\n  DATEPICKER_ERROR_LABELS,\n} from '../../datepicker.conf';\nimport { DatepickerValidationErrors } from '../../types/datepicker.types';\nimport { Interval, IntervalBuilder } from '@acpaas-ui/ngx-utils';\n\n@Component({\n  selector: 'aui-datepicker',\n  templateUrl: './datepicker.component.html',\n  styleUrls: ['./datepicker.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => DatepickerComponent), // eslint-disable-line @angular-eslint/no-forward-ref\n      multi: true,\n    },\n    {\n      provide: NG_VALIDATORS,\n      useExisting: forwardRef(() => DatepickerComponent), // eslint-disable-line @angular-eslint/no-forward-ref\n      multi: true,\n    },\n  ],\n})\nexport class DatepickerComponent implements OnInit, OnChanges, OnDestroy, ControlValueAccessor {\n  @ViewChild(FlyoutDirective, { static: true }) flyout: FlyoutDirective;\n  @Input() id: string;\n  @Input() name: string;\n  @Input() placeholder = 'dd/mm/yyyy';\n  @Input() label: string;\n  @Input() description: string;\n  @Input() range: DateRange;\n  @Input()\n  min: Date | null;\n  @Input()\n  max: Date | null;\n  @Input() autocomplete: 'off';\n  @Input() weekdayLabels: WeekdayLabelsConfig;\n  @Input() monthLabels: MonthLabelsConfig;\n\n  // eslint-disable-next-line @angular-eslint/no-output-native\n  @Output() blur = new EventEmitter<Event>();\n\n  public formControl: UntypedFormControl;\n  public selectedDate: Date;\n  public isDisabled = false;\n  public interval: Interval.IInterval<Date>;\n\n  private componentDestroyed$: Subject<boolean> = new Subject<boolean>();\n\n  constructor(\n    @Inject(CALENDAR_MONTH_LABELS) private moduleMonthLabels = CALENDAR_DEFAULT_MONTH_LABELS,\n    @Inject(CALENDAR_WEEKDAY_LABELS) private moduleWeekdayLabels = CALENDAR_DEFAULT_WEEKDAY_LABELS,\n    @Inject(DATEPICKER_ERROR_LABELS) private errorLabels = DATEPICKER_DEFAULT_ERROR_LABELS,\n    public calendarService: CalendarService,\n    private formBuilder: UntypedFormBuilder,\n    private ref: ChangeDetectorRef\n  ) {}\n\n  public ngOnInit(): void {\n    this.weekdayLabels = this.weekdayLabels || this.moduleWeekdayLabels;\n    this.monthLabels = this.monthLabels || this.moduleMonthLabels;\n    this.createInterval();\n    this.formControl = this.formBuilder.control({ value: '', disabled: this.isDisabled });\n    this.formControl.valueChanges.pipe(takeUntil(this.componentDestroyed$)).subscribe((value) => {\n      if (value) {\n        const format = value.split(DATEPICKER_SEPARATOR_CHAR).reverse().join('-');\n        const date = DateHelper.parseDate(format, 'yyyy-MM-dd');\n        if (date) {\n          this.selectedDate = date;\n          this.onChange(date.toISOString());\n        } else {\n          // Change value with original value (and not null or '') so we can add an error in the validate function\n          this.onChange(value);\n        }\n      } else {\n        this.selectedDate = null;\n        this.onChange('');\n      }\n    });\n  }\n\n  public ngOnChanges(changes: SimpleChanges): void {\n    if (changes.min || changes.max) {\n      this.createInterval();\n    }\n  }\n\n  public ngOnDestroy(): void {\n    this.componentDestroyed$.next(true);\n    this.componentDestroyed$.complete();\n  }\n\n  private createInterval() {\n    if (!this.min && !this.max) {\n      return;\n    }\n    // Create an interval if min/max is filled in\n    this.interval = IntervalBuilder.dateInterval(\n      this.min ? new Date(this.min) : null,\n      this.max ? new Date(this.max) : null\n    )\n      .not()\n      .build();\n  }\n\n  public writeValue(value: string | Date): void {\n    this.selectedDate =\n      typeof value === 'string'\n        ? this.isISODateFormat(value)\n          ? new Date(value)\n          : DateHelper.parseDate(value, 'dd/MM/yyyy')\n        : value;\n    const dateString = this.selectedDate ? this.formatDate(this.selectedDate) : '';\n    this.formControl.setValue(dateString);\n  }\n\n  public registerOnChange(onChange: (res: any) => void): void {\n    this.onChange = onChange;\n  }\n\n  public registerOnTouched(onTouched: (_: any) => void): void {\n    this.onTouched = onTouched;\n  }\n\n  public setDisabledState(isDisabled: boolean): void {\n    this.isDisabled = isDisabled;\n\n    if (this.formControl) {\n      if (isDisabled && this.formControl.enabled) {\n        this.formControl.disable();\n      } else if (!isDisabled && this.formControl.disabled) {\n        this.formControl.enable();\n      }\n    }\n\n    this.ref.markForCheck();\n  }\n\n  public selectDateFromCalendar(result: DatepickerResult): void {\n    if (result.complete) {\n      this.formControl.setValue(this.formatDate(result.date));\n      this.flyout.close();\n    }\n  }\n\n  public formatDate(date: Date): string {\n    return DateHelper.formatDate(date, 'DD/MM/YYYY', {\n      leadingZero: true,\n      monthLabels: this.monthLabels,\n      weekdayLabels: this.weekdayLabels,\n    });\n  }\n\n  public validate(ctrl: UntypedFormControl): DatepickerValidationErrors {\n    // no error on empty value (add required validator in app)\n    if (ctrl.value === '' || ctrl.value === null) {\n      return null;\n    }\n\n    // throw format error if no valid date was provided\n    const date = DateHelper.parseDate(ctrl.value);\n    if (!date) {\n      return {\n        format: this.errorLabels.ERRORS_INVALID_DATE,\n      };\n    }\n\n    // no error if valid date an no range provided\n    if (!this.range || !this.range.length) {\n      return null;\n    }\n\n    // throw error when out of range\n    const range = this.calendarService.getRangeForDate(date, this.range);\n\n    return range.indexOf(date.getDate()) >= 0\n      ? {\n          range: this.errorLabels.ERRORS_INVALID_RANGE,\n        }\n      : null;\n  }\n\n  public handleBlur(e: Event): void {\n    this.blur.emit(e);\n    this.onTouched(e);\n  }\n\n  private onChange: (res: any) => void = () => undefined;\n\n  private onTouched: (_: any) => void = () => undefined;\n\n  private isISODateFormat(value: string) {\n    if (typeof value !== 'string') {\n      return false;\n    }\n    return value.match(/\\d{4}-\\d{2}-\\d{2}T.*/);\n  }\n}\n","<div aria-haspopup=\"grid\" auiFlyout class=\"aui-datepicker a-input has-icon-right\">\n  <label class=\"a-input__label\" for=\"id\">{{ label }}</label>\n  <small class=\"a-input__description\" id=\"id\"> {{ description }}</small>\n  <div class=\"a-input__wrapper\">\n    <input\n      (blur)=\"handleBlur($event)\"\n      [attr.disabled]=\"isDisabled ? true : null\"\n      [autocomplete]=\"autocomplete\"\n      [formControl]=\"formControl\"\n      id=\"{{ id }}\"\n      label=\"Pick date\"\n      description=\"Description\"\n      name=\"{{ name }}\"\n      placeholder=\"{{ placeholder }}\"\n      type=\"text\"\n    />\n    <aui-icon *ngIf=\"isDisabled\" name=\"ai-calendar-3\" role=\"button\" tabindex=\"0\"/>\n    <ng-container *ngIf=\"!isDisabled\">\n      <aui-icon\n        auiFlyoutAction\n        [openOnFocus]=\"false\"\n        name=\"ai-calendar-3\"\n        className=\"is-clickable\"\n        role=\"button\"\n        tabindex=\"0\"\n      ></aui-icon>\n    </ng-container>\n\n    <ng-container *ngIf=\"!isDisabled\">\n      <div auiFlyoutZone class=\"m-datepicker m-datepicker--fixed\" role=\"dialog\">\n        <aui-calendar\n          (selectDate)=\"selectDateFromCalendar($event)\"\n          [range]=\"range\"\n          [selectedDate]=\"selectedDate\"\n          [interval]=\"interval\"\n          [weekdayLabels]=\"weekdayLabels\"\n          [monthLabels]=\"monthLabels\"\n        ></aui-calendar>\n      </div>\n    </ng-container>\n  </div>\n</div>\n"]}
@@ -17,7 +17,7 @@ function SearchFilterComponent_button_8_Template(rf, ctx) { if (rf & 1) {
17
17
  } if (rf & 2) {
18
18
  const ctx_r0 = i0.ɵɵnextContext();
19
19
  i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction2(2, _c0, ctx_r0.size === "large", ctx_r0.size === "small"));
20
- i0.ɵɵattribute("disabled", ctx_r0.isDisabled ? "" : null);
20
+ i0.ɵɵattribute("disabled", ctx_r0.isDisabled || ctx_r0.closeDisabled ? "" : null);
21
21
  } }
22
22
  function SearchFilterComponent_aui_icon_9_Template(rf, ctx) { if (rf & 1) {
23
23
  i0.ɵɵelement(0, "aui-icon", 13);
@@ -85,7 +85,6 @@ export class SearchFilterComponent {
85
85
  this.labelResults = 'Resultaten';
86
86
  this.labelNoResults = 'Geen resultaten gevonden.';
87
87
  this.choices = [];
88
- this.placeholder = 'Zoeken';
89
88
  this.inputDelay = 150;
90
89
  this.onSelect = () => { };
91
90
  this.onClear = () => { };
@@ -96,6 +95,7 @@ export class SearchFilterComponent {
96
95
  this.filteredChoices = [];
97
96
  this.loading = false;
98
97
  this.isDisabled = false;
98
+ this.closeDisabled = false;
99
99
  this.updateModel = () => { };
100
100
  this.filterDataFromSearch = debounce(this.filterData.bind(this), this.inputDelay);
101
101
  }
@@ -157,11 +157,18 @@ export class SearchFilterComponent {
157
157
  return this.filteredChoices?.length && this.query?.length > 1;
158
158
  }
159
159
  getSelectedLabels() {
160
- return this.selectedItems.length ? this.selectedItems.map((el) => el).join(', ') : null;
160
+ if (!this.selectedItems.length) {
161
+ this.closeDisabled = true;
162
+ return null;
163
+ }
164
+ else {
165
+ this.closeDisabled = false;
166
+ return this.selectedItems.map((el) => el).join(', ');
167
+ }
161
168
  }
162
169
  }
163
170
  /** @nocollapse */ SearchFilterComponent.ɵfac = function SearchFilterComponent_Factory(t) { return new (t || SearchFilterComponent)(); };
164
- /** @nocollapse */ SearchFilterComponent.ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: SearchFilterComponent, selectors: [["aui-search-filter"]], inputs: { id: "id", name: "name", flyoutSize: "flyoutSize", flyoutAlign: "flyoutAlign", label: "label", description: "description", labelDeselect: "labelDeselect", labelResults: "labelResults", labelNoResults: "labelNoResults", choices: "choices", remote: "remote", placeholder: "placeholder", inputDelay: "inputDelay", onSelect: "onSelect", onClear: "onClear", size: "size" }, outputs: { search: "search" }, features: [i0.ɵɵProvidersFeature([
171
+ /** @nocollapse */ SearchFilterComponent.ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: SearchFilterComponent, selectors: [["aui-search-filter"]], inputs: { id: "id", name: "name", flyoutSize: "flyoutSize", flyoutAlign: "flyoutAlign", label: "label", description: "description", labelDeselect: "labelDeselect", labelResults: "labelResults", labelNoResults: "labelNoResults", choices: "choices", remote: "remote", inputDelay: "inputDelay", onSelect: "onSelect", onClear: "onClear", size: "size" }, outputs: { search: "search" }, features: [i0.ɵɵProvidersFeature([
165
172
  {
166
173
  provide: NG_VALUE_ACCESSOR,
167
174
  useExisting: forwardRef((() => SearchFilterComponent)),
@@ -172,7 +179,7 @@ export class SearchFilterComponent {
172
179
  i0.ɵɵtext(3);
173
180
  i0.ɵɵelementEnd();
174
181
  i0.ɵɵelementStart(4, "small", 3);
175
- i0.ɵɵtext(5, "Input description");
182
+ i0.ɵɵtext(5);
176
183
  i0.ɵɵelementEnd();
177
184
  i0.ɵɵelementStart(6, "div", 4)(7, "input", 5);
178
185
  i0.ɵɵlistener("input", function SearchFilterComponent_Template_input_input_7_listener() { return ctx.filterDataFromSearch(); })("ngModelChange", function SearchFilterComponent_Template_input_ngModelChange_7_listener($event) { return ctx.query = $event; });
@@ -195,12 +202,14 @@ export class SearchFilterComponent {
195
202
  i0.ɵɵtextInterpolate(ctx.label);
196
203
  i0.ɵɵadvance(1);
197
204
  i0.ɵɵpropertyInterpolate("id", ctx.id + "-description");
198
- i0.ɵɵadvance(3);
205
+ i0.ɵɵadvance(1);
206
+ i0.ɵɵtextInterpolate(ctx.description);
207
+ i0.ɵɵadvance(2);
199
208
  i0.ɵɵpropertyInterpolate("id", ctx.id + "-search");
200
209
  i0.ɵɵpropertyInterpolate("name", ctx.name + "-search");
201
210
  i0.ɵɵpropertyInterpolate("value", ctx.getSelectedLabels());
202
211
  i0.ɵɵproperty("ngModel", ctx.query);
203
- i0.ɵɵattribute("aria-labelledby", ctx.id + "-label")("placeholder", ctx.placeholder)("disabled", ctx.isDisabled ? "" : null);
212
+ i0.ɵɵattribute("aria-labelledby", ctx.id + "-label")("disabled", ctx.isDisabled ? "" : null);
204
213
  i0.ɵɵadvance(1);
205
214
  i0.ɵɵproperty("ngIf", ctx.hasClose);
206
215
  i0.ɵɵadvance(1);
@@ -220,7 +229,7 @@ export class SearchFilterComponent {
220
229
  useExisting: forwardRef((() => SearchFilterComponent)),
221
230
  multi: true,
222
231
  },
223
- ], template: "<div [align]=\"flyoutAlign\" [size]=\"flyoutSize\" aria-haspopup=\"listbox\" auiFlyout class=\"m-search-filter\">\n <div\n class=\"a-input\"\n [ngClass]=\"{\n 'a-input--l': size === 'large',\n 'a-input--s': size === 'small',\n 'has-icon-right': hasClose\n }\"\n >\n <label class=\"a-input__label\" for=\"{{ id + '-search' }}\">{{ label }}</label>\n <small class=\"a-input__description\" id=\"{{ id + '-description' }}\">Input description</small>\n <div class=\"m-search-filter__input\">\n <input\n (input)=\"filterDataFromSearch()\"\n [(ngModel)]=\"query\"\n [attr.aria-labelledby]=\"id + '-label'\"\n [attr.placeholder]=\"placeholder\"\n [attr.disabled]=\"isDisabled ? '' : null\"\n aria-autocomplete=\"list\"\n id=\"{{ id + '-search' }}\"\n name=\"{{ name + '-search' }}\"\n value=\"{{ getSelectedLabels() }}\"\n type=\"text\"\n auiFlyoutAction\n />\n <button\n *ngIf=\"hasClose\"\n [ngClass]=\"{\n 'a-button--l': size === 'large',\n 'a-button--s': size === 'small'\n }\"\n class=\"a-button a-button--outlined has-icon m-search-filter__button a-button--danger\"\n aria-label=\"Zoekopdracht wissen\"\n type=\"button\"\n (click)=\"clear()\"\n [attr.disabled]=\"isDisabled ? '' : null\"\n >\n <aui-icon name=\"ai-close\"></aui-icon>\n </button>\n <aui-icon *ngIf=\"!hasClose\" name=\"ai-close\"></aui-icon>\n </div>\n </div>\n <div auiFlyoutZone class=\"m-search-filter__search m-search-filter__search--scroll\">\n <p *ngIf=\"labelResults\" class=\"h6 m-search-filter__results-title u-margin-bottom-xs\">{{ labelResults }}</p>\n <div *ngIf=\"loading\" class=\"u-text-center u-padding a-spinner\"></div>\n <ul *ngIf=\"!loading\" class=\"a-checkbox-list a-checkbox-list--flushed\">\n <li *ngIf=\"!filteredChoices.length\" class=\"a-checkbox-list__item\">\n <p class=\"u-margin-xs\">{{ labelNoResults }}</p>\n </li>\n <li *ngFor=\"let choice of filteredChoices; index as i\" class=\"a-checkbox-list__item\">\n <div class=\"a-input a-checkbox-list__checkbox\">\n <div class=\"a-input__checkbox\">\n <input\n (change)=\"toggleSelected(choice.label)\"\n [attr.disabled]=\"isDisabled ? true : null\"\n [checked]=\"selectedItems.indexOf(choice.label) >= 0\"\n id=\"{{ 'checkbox--' + i + '--' + id }}\"\n name=\"{{ 'checkbox--' + i + '--' + id }}\"\n type=\"checkbox\"\n />\n <label for=\"{{ 'checkbox--' + i + '--' + id }}\">{{ choice.label }}</label>\n </div>\n </div>\n </li>\n </ul>\n </div>\n</div>\n", styles: [".m-search-filter{display:block}.m-search-filter__input{display:flex;padding:0}.m-search-filter__input input{border-right:none}.m-search-filter__button{display:inline-block;padding:0;position:relative;vertical-align:middle}.m-search-filter__button .ai{position:relative;transform:none!important;top:0}\n"] }]
232
+ ], template: "<div [align]=\"flyoutAlign\" [size]=\"flyoutSize\" aria-haspopup=\"listbox\" auiFlyout class=\"m-search-filter\">\n <div\n class=\"a-input\"\n [ngClass]=\"{\n 'a-input--l': size === 'large',\n 'a-input--s': size === 'small',\n 'has-icon-right': hasClose\n }\"\n >\n <label class=\"a-input__label\" for=\"{{ id + '-search' }}\">{{ label }}</label>\n <small class=\"a-input__description\" id=\"{{ id + '-description' }}\">{{ description }}</small>\n <div class=\"m-search-filter__input\">\n <input\n (input)=\"filterDataFromSearch()\"\n [(ngModel)]=\"query\"\n [attr.aria-labelledby]=\"id + '-label'\"\n [attr.disabled]=\"isDisabled ? '' : null\"\n aria-autocomplete=\"list\"\n id=\"{{ id + '-search' }}\"\n name=\"{{ name + '-search' }}\"\n value=\"{{ getSelectedLabels() }}\"\n type=\"text\"\n auiFlyoutAction\n />\n <button\n *ngIf=\"hasClose\"\n [ngClass]=\"{\n 'a-button--l': size === 'large',\n 'a-button--s': size === 'small'\n }\"\n class=\"a-button a-button--outlined has-icon m-search-filter__button a-button--danger\"\n aria-label=\"Zoekopdracht wissen\"\n type=\"button\"\n (click)=\"clear()\"\n [attr.disabled]=\"isDisabled || closeDisabled ? '' : null\"\n >\n <aui-icon name=\"ai-close\"></aui-icon>\n </button>\n <aui-icon *ngIf=\"!hasClose\" name=\"ai-close\"></aui-icon>\n </div>\n </div>\n <div auiFlyoutZone class=\"m-search-filter__search m-search-filter__search--scroll\">\n <p *ngIf=\"labelResults\" class=\"h6 m-search-filter__results-title u-margin-bottom-xs\">{{ labelResults }}</p>\n <div *ngIf=\"loading\" class=\"u-text-center u-padding a-spinner\"></div>\n <ul *ngIf=\"!loading\" class=\"a-checkbox-list a-checkbox-list--flushed\">\n <li *ngIf=\"!filteredChoices.length\" class=\"a-checkbox-list__item\">\n <p class=\"u-margin-xs\">{{ labelNoResults }}</p>\n </li>\n <li *ngFor=\"let choice of filteredChoices; index as i\" class=\"a-checkbox-list__item\">\n <div class=\"a-input a-checkbox-list__checkbox\">\n <div class=\"a-input__checkbox\">\n <input\n (change)=\"toggleSelected(choice.label)\"\n [attr.disabled]=\"isDisabled ? true : null\"\n [checked]=\"selectedItems.indexOf(choice.label) >= 0\"\n id=\"{{ 'checkbox--' + i + '--' + id }}\"\n name=\"{{ 'checkbox--' + i + '--' + id }}\"\n type=\"checkbox\"\n />\n <label for=\"{{ 'checkbox--' + i + '--' + id }}\">{{ choice.label }}</label>\n </div>\n </div>\n </li>\n </ul>\n </div>\n</div>\n", styles: [".m-search-filter{display:block}.m-search-filter__input{display:flex;padding:0}.m-search-filter__input input{border-right:none}.m-search-filter__button{display:inline-block;padding:0;position:relative;vertical-align:middle}.m-search-filter__button .ai{position:relative;transform:none!important;top:0}\n"] }]
224
233
  }], function () { return []; }, { id: [{
225
234
  type: Input
226
235
  }], name: [{
@@ -243,8 +252,6 @@ export class SearchFilterComponent {
243
252
  type: Input
244
253
  }], remote: [{
245
254
  type: Input
246
- }], placeholder: [{
247
- type: Input
248
255
  }], inputDelay: [{
249
256
  type: Input
250
257
  }], onSelect: [{
@@ -256,4 +263,4 @@ export class SearchFilterComponent {
256
263
  }], search: [{
257
264
  type: Output
258
265
  }] }); })();
259
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"search-filter.component.js","sourceRoot":"","sources":["../../../../../../src/lib/search-filter/components/search-filter/search-filter.component.ts","../../../../../../src/lib/search-filter/components/search-filter/search-filter.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, forwardRef, Input, OnChanges, OnInit, Output, SimpleChanges } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { debounce, get } from 'lodash-es';\n\nimport { FlyoutSize } from '@acpaas-ui/ngx-flyout';\n\nimport { SearchFilterChoice } from '../../types/search-filter.types';\n\n@Component({\n  selector: 'aui-search-filter',\n  templateUrl: './search-filter.component.html',\n  styleUrls: ['./search-filter.component.scss'],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => SearchFilterComponent), // eslint-disable-line @angular-eslint/no-forward-ref\n      multi: true,\n    },\n  ],\n})\nexport class SearchFilterComponent implements OnChanges, ControlValueAccessor {\n  @Input() public id: string;\n  @Input() public name: string;\n  @Input() public flyoutSize = FlyoutSize.Small;\n  @Input() public flyoutAlign;\n  @Input() public label: string;\n  @Input() public description: string;\n  @Input() public labelDeselect = 'Alles deselecteren';\n  @Input() public labelResults = 'Resultaten';\n  @Input() public labelNoResults = 'Geen resultaten gevonden.';\n  @Input() public choices: SearchFilterChoice[] = [];\n  @Input() public remote: boolean;\n  @Input() public placeholder = 'Zoeken';\n  @Input() public inputDelay = 150;\n  @Input() public onSelect: () => void = () => {};\n  @Input() public onClear: () => void = () => {};\n  @Input() public size: 'large' | 'default' | 'small' | 'tiny' = 'default';\n\n  @Output() public search: EventEmitter<string> = new EventEmitter<string>();\n\n  public query = '';\n  public selectedItems: string[] = [];\n  public filteredChoices: SearchFilterChoice[] = [];\n  public loading = false;\n  public isDisabled = false;\n\n  public filterDataFromSearch: () => {};\n\n  constructor() {\n    this.filterDataFromSearch = debounce(this.filterData.bind(this), this.inputDelay);\n  }\n\n  public updateModel: (_) => any = () => {};\n\n  public writeValue(value: string[]): void {\n    this.selectedItems = Array.isArray(value) ? value : [];\n  }\n\n  public registerOnChange(onChange: (_) => any): void {\n    this.updateModel = onChange;\n  }\n\n  public registerOnTouched(): void {}\n\n  public setDisabledState(isDisabled: boolean): void {\n    this.isDisabled = isDisabled;\n  }\n\n  public ngOnChanges(changes: SimpleChanges): void {\n    const choices = get(changes, 'choices.currentValue', null);\n\n    if (!choices) {\n      return;\n    }\n\n    if (this.remote) {\n      this.filteredChoices = [...choices];\n      this.loading = false;\n    } else {\n      this.filterData();\n    }\n  }\n\n  public filterData(): void {\n    if (this.remote) {\n      this.loading = true;\n\n      return this.search.emit(this.query);\n    }\n\n    this.filterChoices();\n  }\n\n  public clear(): void {\n    this.selectedItems = [];\n    this.query = '';\n    this.filterData();\n    this.updateModel(this.selectedItems);\n    this.onClear();\n  }\n\n  public toggleSelected(choice: string): void {\n    const selected = this.selectedItems.indexOf(choice);\n\n    if (selected < 0) {\n      this.selectedItems = this.selectedItems.concat(choice);\n    } else {\n      this.selectedItems = [...this.selectedItems.slice(0, selected), ...this.selectedItems.slice(selected + 1)];\n    }\n\n    this.updateModel(this.selectedItems);\n    this.onSelect();\n  }\n\n  private filterChoices(): void {\n    this.filteredChoices = this.choices.filter((choice: SearchFilterChoice) => {\n      return (\n        this.selectedItems.indexOf(choice.value) < 0 &&\n        choice.label.toLowerCase().indexOf(this.query.toLowerCase()) >= 0\n      );\n    });\n  }\n\n  public hasClose(): boolean {\n    return this.filteredChoices?.length && this.query?.length > 1;\n  }\n\n  public getSelectedLabels(): string {\n    return this.selectedItems.length ? this.selectedItems.map((el) => el).join(', ') : null;\n  }\n}\n","<div [align]=\"flyoutAlign\" [size]=\"flyoutSize\" aria-haspopup=\"listbox\" auiFlyout class=\"m-search-filter\">\n  <div\n    class=\"a-input\"\n    [ngClass]=\"{\n      'a-input--l': size === 'large',\n      'a-input--s': size === 'small',\n      'has-icon-right': hasClose\n    }\"\n  >\n    <label class=\"a-input__label\" for=\"{{ id + '-search' }}\">{{ label }}</label>\n    <small class=\"a-input__description\" id=\"{{ id + '-description' }}\">Input description</small>\n    <div class=\"m-search-filter__input\">\n      <input\n        (input)=\"filterDataFromSearch()\"\n        [(ngModel)]=\"query\"\n        [attr.aria-labelledby]=\"id + '-label'\"\n        [attr.placeholder]=\"placeholder\"\n        [attr.disabled]=\"isDisabled ? '' : null\"\n        aria-autocomplete=\"list\"\n        id=\"{{ id + '-search' }}\"\n        name=\"{{ name + '-search' }}\"\n        value=\"{{ getSelectedLabels() }}\"\n        type=\"text\"\n        auiFlyoutAction\n      />\n      <button\n        *ngIf=\"hasClose\"\n        [ngClass]=\"{\n          'a-button--l': size === 'large',\n          'a-button--s': size === 'small'\n        }\"\n        class=\"a-button a-button--outlined has-icon m-search-filter__button a-button--danger\"\n        aria-label=\"Zoekopdracht wissen\"\n        type=\"button\"\n        (click)=\"clear()\"\n        [attr.disabled]=\"isDisabled ? '' : null\"\n      >\n        <aui-icon name=\"ai-close\"></aui-icon>\n      </button>\n      <aui-icon *ngIf=\"!hasClose\" name=\"ai-close\"></aui-icon>\n    </div>\n  </div>\n  <div auiFlyoutZone class=\"m-search-filter__search m-search-filter__search--scroll\">\n    <p *ngIf=\"labelResults\" class=\"h6 m-search-filter__results-title u-margin-bottom-xs\">{{ labelResults }}</p>\n    <div *ngIf=\"loading\" class=\"u-text-center u-padding a-spinner\"></div>\n    <ul *ngIf=\"!loading\" class=\"a-checkbox-list a-checkbox-list--flushed\">\n      <li *ngIf=\"!filteredChoices.length\" class=\"a-checkbox-list__item\">\n        <p class=\"u-margin-xs\">{{ labelNoResults }}</p>\n      </li>\n      <li *ngFor=\"let choice of filteredChoices; index as i\" class=\"a-checkbox-list__item\">\n        <div class=\"a-input a-checkbox-list__checkbox\">\n          <div class=\"a-input__checkbox\">\n            <input\n              (change)=\"toggleSelected(choice.label)\"\n              [attr.disabled]=\"isDisabled ? true : null\"\n              [checked]=\"selectedItems.indexOf(choice.label) >= 0\"\n              id=\"{{ 'checkbox--' + i + '--' + id }}\"\n              name=\"{{ 'checkbox--' + i + '--' + id }}\"\n              type=\"checkbox\"\n            />\n            <label for=\"{{ 'checkbox--' + i + '--' + id }}\">{{ choice.label }}</label>\n          </div>\n        </div>\n      </li>\n    </ul>\n  </div>\n</div>\n"]}
266
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"search-filter.component.js","sourceRoot":"","sources":["../../../../../../src/lib/search-filter/components/search-filter/search-filter.component.ts","../../../../../../src/lib/search-filter/components/search-filter/search-filter.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, forwardRef, Input, OnChanges, OnInit, Output, SimpleChanges } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { debounce, get } from 'lodash-es';\n\nimport { FlyoutSize } from '@acpaas-ui/ngx-flyout';\n\nimport { SearchFilterChoice } from '../../types/search-filter.types';\n\n@Component({\n  selector: 'aui-search-filter',\n  templateUrl: './search-filter.component.html',\n  styleUrls: ['./search-filter.component.scss'],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => SearchFilterComponent), // eslint-disable-line @angular-eslint/no-forward-ref\n      multi: true,\n    },\n  ],\n})\nexport class SearchFilterComponent implements OnChanges, ControlValueAccessor {\n  @Input() public id: string;\n  @Input() public name: string;\n  @Input() public flyoutSize = FlyoutSize.Small;\n  @Input() public flyoutAlign;\n  @Input() public label: string;\n  @Input() public description: string;\n  @Input() public labelDeselect = 'Alles deselecteren';\n  @Input() public labelResults = 'Resultaten';\n  @Input() public labelNoResults = 'Geen resultaten gevonden.';\n  @Input() public choices: SearchFilterChoice[] = [];\n  @Input() public remote: boolean;\n  @Input() public inputDelay = 150;\n  @Input() public onSelect: () => void = () => {};\n  @Input() public onClear: () => void = () => {};\n  @Input() public size: 'large' | 'default' | 'small' | 'tiny' = 'default';\n\n  @Output() public search: EventEmitter<string> = new EventEmitter<string>();\n\n  public query = '';\n  public selectedItems: string[] = [];\n  public filteredChoices: SearchFilterChoice[] = [];\n  public loading = false;\n  public isDisabled = false;\n  public closeDisabled = false;\n\n  public filterDataFromSearch: () => {};\n\n  constructor() {\n    this.filterDataFromSearch = debounce(this.filterData.bind(this), this.inputDelay);\n  }\n\n  public updateModel: (_) => any = () => {};\n\n  public writeValue(value: string[]): void {\n    this.selectedItems = Array.isArray(value) ? value : [];\n  }\n\n  public registerOnChange(onChange: (_) => any): void {\n    this.updateModel = onChange;\n  }\n\n  public registerOnTouched(): void {}\n\n  public setDisabledState(isDisabled: boolean): void {\n    this.isDisabled = isDisabled;\n  }\n\n  public ngOnChanges(changes: SimpleChanges): void {\n    const choices = get(changes, 'choices.currentValue', null);\n\n    if (!choices) {\n      return;\n    }\n\n    if (this.remote) {\n      this.filteredChoices = [...choices];\n      this.loading = false;\n    } else {\n      this.filterData();\n    }\n  }\n\n  public filterData(): void {\n    if (this.remote) {\n      this.loading = true;\n\n      return this.search.emit(this.query);\n    }\n\n    this.filterChoices();\n  }\n\n  public clear(): void {\n    this.selectedItems = [];\n    this.query = '';\n    this.filterData();\n    this.updateModel(this.selectedItems);\n    this.onClear();\n  }\n\n  public toggleSelected(choice: string): void {\n    const selected = this.selectedItems.indexOf(choice);\n\n    if (selected < 0) {\n      this.selectedItems = this.selectedItems.concat(choice);\n    } else {\n      this.selectedItems = [...this.selectedItems.slice(0, selected), ...this.selectedItems.slice(selected + 1)];\n    }\n\n    this.updateModel(this.selectedItems);\n    this.onSelect();\n  }\n\n  private filterChoices(): void {\n    this.filteredChoices = this.choices.filter((choice: SearchFilterChoice) => {\n      return (\n        this.selectedItems.indexOf(choice.value) < 0 &&\n        choice.label.toLowerCase().indexOf(this.query.toLowerCase()) >= 0\n      );\n    });\n  }\n\n  public hasClose(): boolean {\n    return this.filteredChoices?.length && this.query?.length > 1;\n  }\n\n  public getSelectedLabels(): string {\n    if (!this.selectedItems.length) {\n      this.closeDisabled = true;\n      return null\n    }\n\n    else {\n      this.closeDisabled = false;\n      return this.selectedItems.map((el) => el).join(', ')\n  }}\n  \n\n}\n","<div [align]=\"flyoutAlign\" [size]=\"flyoutSize\" aria-haspopup=\"listbox\" auiFlyout class=\"m-search-filter\">\n  <div\n    class=\"a-input\"\n    [ngClass]=\"{\n      'a-input--l': size === 'large',\n      'a-input--s': size === 'small',\n      'has-icon-right': hasClose\n    }\"\n  >\n    <label class=\"a-input__label\" for=\"{{ id + '-search' }}\">{{ label }}</label>\n    <small class=\"a-input__description\" id=\"{{ id + '-description' }}\">{{ description }}</small>\n    <div class=\"m-search-filter__input\">\n      <input\n        (input)=\"filterDataFromSearch()\"\n        [(ngModel)]=\"query\"\n        [attr.aria-labelledby]=\"id + '-label'\"\n        [attr.disabled]=\"isDisabled ? '' : null\"\n        aria-autocomplete=\"list\"\n        id=\"{{ id + '-search' }}\"\n        name=\"{{ name + '-search' }}\"\n        value=\"{{ getSelectedLabels() }}\"\n        type=\"text\"\n        auiFlyoutAction\n      />\n      <button\n        *ngIf=\"hasClose\"\n        [ngClass]=\"{\n          'a-button--l': size === 'large',\n          'a-button--s': size === 'small'\n        }\"\n        class=\"a-button a-button--outlined has-icon m-search-filter__button a-button--danger\"\n        aria-label=\"Zoekopdracht wissen\"\n        type=\"button\"\n        (click)=\"clear()\"\n        [attr.disabled]=\"isDisabled || closeDisabled ? '' : null\"\n      >\n        <aui-icon name=\"ai-close\"></aui-icon>\n      </button>\n      <aui-icon *ngIf=\"!hasClose\" name=\"ai-close\"></aui-icon>\n    </div>\n  </div>\n  <div auiFlyoutZone class=\"m-search-filter__search m-search-filter__search--scroll\">\n    <p *ngIf=\"labelResults\" class=\"h6 m-search-filter__results-title u-margin-bottom-xs\">{{ labelResults }}</p>\n    <div *ngIf=\"loading\" class=\"u-text-center u-padding a-spinner\"></div>\n    <ul *ngIf=\"!loading\" class=\"a-checkbox-list a-checkbox-list--flushed\">\n      <li *ngIf=\"!filteredChoices.length\" class=\"a-checkbox-list__item\">\n        <p class=\"u-margin-xs\">{{ labelNoResults }}</p>\n      </li>\n      <li *ngFor=\"let choice of filteredChoices; index as i\" class=\"a-checkbox-list__item\">\n        <div class=\"a-input a-checkbox-list__checkbox\">\n          <div class=\"a-input__checkbox\">\n            <input\n              (change)=\"toggleSelected(choice.label)\"\n              [attr.disabled]=\"isDisabled ? true : null\"\n              [checked]=\"selectedItems.indexOf(choice.label) >= 0\"\n              id=\"{{ 'checkbox--' + i + '--' + id }}\"\n              name=\"{{ 'checkbox--' + i + '--' + id }}\"\n              type=\"checkbox\"\n            />\n            <label for=\"{{ 'checkbox--' + i + '--' + id }}\">{{ choice.label }}</label>\n          </div>\n        </div>\n      </li>\n    </ul>\n  </div>\n</div>\n"]}
@@ -2,7 +2,7 @@ import { ChangeDetectionStrategy, Component, forwardRef, Input } from '@angular/
2
2
  import { UntypedFormControl, NG_VALUE_ACCESSOR, } from '@angular/forms';
3
3
  import { Subject } from 'rxjs';
4
4
  import { takeUntil } from 'rxjs/operators';
5
- import { DateHelper } from '@acpaas-ui/js-date-utils';
5
+ import { DateHelper } from '@acpaas-ui/ngx-utils';
6
6
  import { TimepickerInputSize } from '../../types/timepicker.types';
7
7
  import * as i0 from "@angular/core";
8
8
  import * as i1 from "@angular/forms";
@@ -226,4 +226,4 @@ export class TimepickerComponent {
226
226
  }], description: [{
227
227
  type: Input
228
228
  }] }); })();
229
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"timepicker.component.js","sourceRoot":"","sources":["../../../../../../src/lib/timepicker/components/timepicker/timepicker.component.ts","../../../../../../src/lib/timepicker/components/timepicker/timepicker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, forwardRef, Input, OnDestroy, OnInit, Renderer2 } from '@angular/core';\nimport {\n  ControlValueAccessor,\n  UntypedFormBuilder,\n  UntypedFormControl,\n  UntypedFormGroup,\n  NG_VALUE_ACCESSOR,\n} from '@angular/forms';\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { DateHelper } from '@acpaas-ui/js-date-utils';\n\nimport { TimepickerInputSize } from '../../types/timepicker.types';\n\n@Component({\n  selector: 'aui-timepicker',\n  templateUrl: './timepicker.component.html',\n  styleUrls: ['./timepicker.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => TimepickerComponent), // eslint-disable-line @angular-eslint/no-forward-ref\n      multi: true,\n    },\n  ],\n})\nexport class TimepickerComponent implements OnInit, OnDestroy, ControlValueAccessor {\n  @Input() public id = 'aui-timepicker-' + Math.random().toString(36).substring(2);\n  @Input() public hoursPlaceholder = 'uu';\n  @Input() public minutesPlaceholder = 'mm';\n  @Input() public hasError = false;\n  @Input() public size: TimepickerInputSize = TimepickerInputSize.Auto;\n  @Input() public ariaLabelHours = 'Uur';\n  @Input() public ariaLabelMinutes = 'Minuten';\n  @Input() public label: string;\n  @Input() public description: string;\n\n  public shouldUseFallback = false;\n  public minutes: string[] = [];\n  public hours: string[] = [];\n  public updateModel: (value: string) => any;\n\n  public timeControl = new UntypedFormControl();\n  public fallbackForm: UntypedFormGroup;\n\n  private componentDestroyed$: Subject<boolean> = new Subject<boolean>();\n\n  constructor(private formBuilder: UntypedFormBuilder, private renderer: Renderer2) {}\n\n  public ngOnInit() {\n    this.shouldUseFallback = this.supportsNativeTimepicker();\n    this.minutes = this.getMinutes();\n    this.hours = this.getHours();\n\n    this.fallbackForm = this.formBuilder.group({\n      hours: null,\n      minutes: null,\n    });\n\n    this.fallbackForm.valueChanges.pipe(takeUntil(this.componentDestroyed$)).subscribe((formData) => {\n      if (formData.hours && formData.minutes) {\n        this.updateModel(`${formData.hours}:${formData.minutes}`);\n      } else {\n        this.updateModel('');\n      }\n    });\n\n    this.timeControl.valueChanges.pipe(takeUntil(this.componentDestroyed$)).subscribe((time) => {\n      this.updateModel(time);\n    });\n  }\n\n  public ngOnDestroy() {\n    this.componentDestroyed$.next(true);\n    this.componentDestroyed$.complete();\n  }\n\n  public writeValue(value: any): void {\n    this.timeControl.setValue(value, { emitEvent: false });\n\n    if (value) {\n      const splitted = value.split(':');\n      this.fallbackForm.get('hours').setValue(splitted[0], { emitEvent: false });\n      this.fallbackForm.get('minutes').setValue(splitted[1], { emitEvent: false });\n    }\n  }\n\n  public registerOnChange(onChange): void {\n    this.updateModel = onChange;\n  }\n\n  public registerOnTouched(): void {}\n\n  public setDisabledState(isDisabled: boolean) {\n    if (isDisabled) {\n      this.timeControl.disable({ emitEvent: false });\n      this.fallbackForm.disable({ emitEvent: false });\n    } else {\n      this.timeControl.enable({ emitEvent: false });\n      this.fallbackForm.enable({ emitEvent: false });\n    }\n  }\n\n  private supportsNativeTimepicker(): boolean {\n    const element = this.renderer.createElement('input');\n    element.type = 'time';\n\n    return element.type === 'text';\n  }\n\n  private getMinutes(): string[] {\n    return Array(60)\n      .fill('')\n      .map((value, index) => {\n        return DateHelper.addLeadingZero(index);\n      });\n  }\n\n  private getHours(): string[] {\n    return Array(24)\n      .fill('')\n      .map((value, index) => {\n        return DateHelper.addLeadingZero(index);\n      });\n  }\n}\n","<div class=\"m-timepicker\">\n  <div *ngIf=\"!shouldUseFallback\" [class]=\"'a-input--' + size\" [ngClass]=\"{ 'has-error': hasError }\" class=\"a-input\">\n    <label class=\"a-input__label\" for=\"id\">{{ label }}</label>\n    <small class=\"a-input__description\" id=\"id\" [ngClass]=\"{ 'is-error': hasError }\">\n      <aui-icon *ngIf=\"hasError\" name=\"ai-alert-triangle\"></aui-icon>\n      {{ description }}</small\n    >\n    <input\n      [attr.aria-label]=\"ariaLabelHours + ':' + ariaLabelMinutes\"\n      [formControl]=\"timeControl\"\n      [id]=\"id\"\n      type=\"time\"\n    />\n  </div>\n\n  <div *ngIf=\"shouldUseFallback\" [formGroup]=\"fallbackForm\">\n    <div [class]=\"'a-input--' + size\" [ngClass]=\"{ 'has-error': hasError }\" class=\"a-input has-icon-right\">\n      <div class=\"a-input__wrapper\">\n        <select [attr.aria-label]=\"ariaLabelHours\" [id]=\"id\" formControlName=\"hours\">\n          <option disabled value=\"null\">{{ hoursPlaceholder }}</option>\n          <option *ngFor=\"let hour of hours\" [value]=\"hour\">{{ hour }}</option>\n        </select>\n        <aui-icon name=\"ai-arrow-down-1\"></aui-icon>\n      </div>\n    </div>\n\n    <div [class]=\"'a-input--' + size\" [ngClass]=\"{ 'has-error': hasError }\" class=\"a-input has-icon-right\">\n      <div class=\"a-input__wrapper\">\n        <select [attr.aria-label]=\"ariaLabelMinutes\" formControlName=\"minutes\">\n          <option disabled value=\"null\">{{ minutesPlaceholder }}</option>\n          <option *ngFor=\"let minute of minutes\" [value]=\"minute\">{{ minute }}</option>\n        </select>\n        <aui-icon name=\"ai-arrow-down-1\"></aui-icon>\n      </div>\n    </div>\n  </div>\n</div>\n"]}
229
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"timepicker.component.js","sourceRoot":"","sources":["../../../../../../src/lib/timepicker/components/timepicker/timepicker.component.ts","../../../../../../src/lib/timepicker/components/timepicker/timepicker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, forwardRef, Input, OnDestroy, OnInit, Renderer2 } from '@angular/core';\nimport {\n  ControlValueAccessor,\n  UntypedFormBuilder,\n  UntypedFormControl,\n  UntypedFormGroup,\n  NG_VALUE_ACCESSOR,\n} from '@angular/forms';\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { DateHelper } from '@acpaas-ui/ngx-utils';\n\nimport { TimepickerInputSize } from '../../types/timepicker.types';\n\n@Component({\n  selector: 'aui-timepicker',\n  templateUrl: './timepicker.component.html',\n  styleUrls: ['./timepicker.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => TimepickerComponent), // eslint-disable-line @angular-eslint/no-forward-ref\n      multi: true,\n    },\n  ],\n})\nexport class TimepickerComponent implements OnInit, OnDestroy, ControlValueAccessor {\n  @Input() public id = 'aui-timepicker-' + Math.random().toString(36).substring(2);\n  @Input() public hoursPlaceholder = 'uu';\n  @Input() public minutesPlaceholder = 'mm';\n  @Input() public hasError = false;\n  @Input() public size: TimepickerInputSize = TimepickerInputSize.Auto;\n  @Input() public ariaLabelHours = 'Uur';\n  @Input() public ariaLabelMinutes = 'Minuten';\n  @Input() public label: string;\n  @Input() public description: string;\n\n  public shouldUseFallback = false;\n  public minutes: string[] = [];\n  public hours: string[] = [];\n  public updateModel: (value: string) => any;\n\n  public timeControl = new UntypedFormControl();\n  public fallbackForm: UntypedFormGroup;\n\n  private componentDestroyed$: Subject<boolean> = new Subject<boolean>();\n\n  constructor(private formBuilder: UntypedFormBuilder, private renderer: Renderer2) {}\n\n  public ngOnInit() {\n    this.shouldUseFallback = this.supportsNativeTimepicker();\n    this.minutes = this.getMinutes();\n    this.hours = this.getHours();\n\n    this.fallbackForm = this.formBuilder.group({\n      hours: null,\n      minutes: null,\n    });\n\n    this.fallbackForm.valueChanges.pipe(takeUntil(this.componentDestroyed$)).subscribe((formData) => {\n      if (formData.hours && formData.minutes) {\n        this.updateModel(`${formData.hours}:${formData.minutes}`);\n      } else {\n        this.updateModel('');\n      }\n    });\n\n    this.timeControl.valueChanges.pipe(takeUntil(this.componentDestroyed$)).subscribe((time) => {\n      this.updateModel(time);\n    });\n  }\n\n  public ngOnDestroy() {\n    this.componentDestroyed$.next(true);\n    this.componentDestroyed$.complete();\n  }\n\n  public writeValue(value: any): void {\n    this.timeControl.setValue(value, { emitEvent: false });\n\n    if (value) {\n      const splitted = value.split(':');\n      this.fallbackForm.get('hours').setValue(splitted[0], { emitEvent: false });\n      this.fallbackForm.get('minutes').setValue(splitted[1], { emitEvent: false });\n    }\n  }\n\n  public registerOnChange(onChange): void {\n    this.updateModel = onChange;\n  }\n\n  public registerOnTouched(): void {}\n\n  public setDisabledState(isDisabled: boolean) {\n    if (isDisabled) {\n      this.timeControl.disable({ emitEvent: false });\n      this.fallbackForm.disable({ emitEvent: false });\n    } else {\n      this.timeControl.enable({ emitEvent: false });\n      this.fallbackForm.enable({ emitEvent: false });\n    }\n  }\n\n  private supportsNativeTimepicker(): boolean {\n    const element = this.renderer.createElement('input');\n    element.type = 'time';\n\n    return element.type === 'text';\n  }\n\n  private getMinutes(): string[] {\n    return Array(60)\n      .fill('')\n      .map((value, index) => {\n        return DateHelper.addLeadingZero(index);\n      });\n  }\n\n  private getHours(): string[] {\n    return Array(24)\n      .fill('')\n      .map((value, index) => {\n        return DateHelper.addLeadingZero(index);\n      });\n  }\n}\n","<div class=\"m-timepicker\">\n  <div *ngIf=\"!shouldUseFallback\" [class]=\"'a-input--' + size\" [ngClass]=\"{ 'has-error': hasError }\" class=\"a-input\">\n    <label class=\"a-input__label\" for=\"id\">{{ label }}</label>\n    <small class=\"a-input__description\" id=\"id\" [ngClass]=\"{ 'is-error': hasError }\">\n      <aui-icon *ngIf=\"hasError\" name=\"ai-alert-triangle\"></aui-icon>\n      {{ description }}</small\n    >\n    <input\n      [attr.aria-label]=\"ariaLabelHours + ':' + ariaLabelMinutes\"\n      [formControl]=\"timeControl\"\n      [id]=\"id\"\n      type=\"time\"\n    />\n  </div>\n\n  <div *ngIf=\"shouldUseFallback\" [formGroup]=\"fallbackForm\">\n    <div [class]=\"'a-input--' + size\" [ngClass]=\"{ 'has-error': hasError }\" class=\"a-input has-icon-right\">\n      <div class=\"a-input__wrapper\">\n        <select [attr.aria-label]=\"ariaLabelHours\" [id]=\"id\" formControlName=\"hours\">\n          <option disabled value=\"null\">{{ hoursPlaceholder }}</option>\n          <option *ngFor=\"let hour of hours\" [value]=\"hour\">{{ hour }}</option>\n        </select>\n        <aui-icon name=\"ai-arrow-down-1\"></aui-icon>\n      </div>\n    </div>\n\n    <div [class]=\"'a-input--' + size\" [ngClass]=\"{ 'has-error': hasError }\" class=\"a-input has-icon-right\">\n      <div class=\"a-input__wrapper\">\n        <select [attr.aria-label]=\"ariaLabelMinutes\" formControlName=\"minutes\">\n          <option disabled value=\"null\">{{ minutesPlaceholder }}</option>\n          <option *ngFor=\"let minute of minutes\" [value]=\"minute\">{{ minute }}</option>\n        </select>\n        <aui-icon name=\"ai-arrow-down-1\"></aui-icon>\n      </div>\n    </div>\n  </div>\n</div>\n"]}
@@ -11,10 +11,9 @@ import { SelectableListModule } from '@acpaas-ui/ngx-selectable-list';
11
11
  import { get, isEqual, debounce } from 'lodash-es';
12
12
  import { Subject, Observable } from 'rxjs';
13
13
  import { takeUntil } from 'rxjs/operators';
14
- import { DateHelper } from '@acpaas-ui/js-date-utils';
14
+ import { DateHelper, IntervalBuilder } from '@acpaas-ui/ngx-utils';
15
15
  import * as i1$2 from '@acpaas-ui/ngx-calendar';
16
16
  import { CALENDAR_DEFAULT_MONTH_LABELS, CALENDAR_DEFAULT_WEEKDAY_LABELS, CALENDAR_MONTH_LABELS, CALENDAR_WEEKDAY_LABELS, CalendarModule } from '@acpaas-ui/ngx-calendar';
17
- import { IntervalBuilder } from '@acpaas-ui/ngx-utils';
18
17
  import * as i4$1 from '@acpaas-ui/ngx-icon';
19
18
  import { IconModule } from '@acpaas-ui/ngx-icon';
20
19
  import * as i2 from '@acpaas-ui/ngx-progress-bar';
@@ -1151,7 +1150,7 @@ function SearchFilterComponent_button_8_Template(rf, ctx) {
1151
1150
  if (rf & 2) {
1152
1151
  const ctx_r0 = i0.ɵɵnextContext();
1153
1152
  i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction2(2, _c0$4, ctx_r0.size === "large", ctx_r0.size === "small"));
1154
- i0.ɵɵattribute("disabled", ctx_r0.isDisabled ? "" : null);
1153
+ i0.ɵɵattribute("disabled", ctx_r0.isDisabled || ctx_r0.closeDisabled ? "" : null);
1155
1154
  }
1156
1155
  }
1157
1156
  function SearchFilterComponent_aui_icon_9_Template(rf, ctx) {
@@ -1236,7 +1235,6 @@ class SearchFilterComponent {
1236
1235
  this.labelResults = 'Resultaten';
1237
1236
  this.labelNoResults = 'Geen resultaten gevonden.';
1238
1237
  this.choices = [];
1239
- this.placeholder = 'Zoeken';
1240
1238
  this.inputDelay = 150;
1241
1239
  this.onSelect = () => { };
1242
1240
  this.onClear = () => { };
@@ -1247,6 +1245,7 @@ class SearchFilterComponent {
1247
1245
  this.filteredChoices = [];
1248
1246
  this.loading = false;
1249
1247
  this.isDisabled = false;
1248
+ this.closeDisabled = false;
1250
1249
  this.updateModel = () => { };
1251
1250
  this.filterDataFromSearch = debounce(this.filterData.bind(this), this.inputDelay);
1252
1251
  }
@@ -1309,11 +1308,18 @@ class SearchFilterComponent {
1309
1308
  return ((_a = this.filteredChoices) === null || _a === void 0 ? void 0 : _a.length) && ((_b = this.query) === null || _b === void 0 ? void 0 : _b.length) > 1;
1310
1309
  }
1311
1310
  getSelectedLabels() {
1312
- return this.selectedItems.length ? this.selectedItems.map((el) => el).join(', ') : null;
1311
+ if (!this.selectedItems.length) {
1312
+ this.closeDisabled = true;
1313
+ return null;
1314
+ }
1315
+ else {
1316
+ this.closeDisabled = false;
1317
+ return this.selectedItems.map((el) => el).join(', ');
1318
+ }
1313
1319
  }
1314
1320
  }
1315
1321
  /** @nocollapse */ SearchFilterComponent.ɵfac = function SearchFilterComponent_Factory(t) { return new (t || SearchFilterComponent)(); };
1316
- /** @nocollapse */ SearchFilterComponent.ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: SearchFilterComponent, selectors: [["aui-search-filter"]], inputs: { id: "id", name: "name", flyoutSize: "flyoutSize", flyoutAlign: "flyoutAlign", label: "label", description: "description", labelDeselect: "labelDeselect", labelResults: "labelResults", labelNoResults: "labelNoResults", choices: "choices", remote: "remote", placeholder: "placeholder", inputDelay: "inputDelay", onSelect: "onSelect", onClear: "onClear", size: "size" }, outputs: { search: "search" }, features: [i0.ɵɵProvidersFeature([
1322
+ /** @nocollapse */ SearchFilterComponent.ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: SearchFilterComponent, selectors: [["aui-search-filter"]], inputs: { id: "id", name: "name", flyoutSize: "flyoutSize", flyoutAlign: "flyoutAlign", label: "label", description: "description", labelDeselect: "labelDeselect", labelResults: "labelResults", labelNoResults: "labelNoResults", choices: "choices", remote: "remote", inputDelay: "inputDelay", onSelect: "onSelect", onClear: "onClear", size: "size" }, outputs: { search: "search" }, features: [i0.ɵɵProvidersFeature([
1317
1323
  {
1318
1324
  provide: NG_VALUE_ACCESSOR,
1319
1325
  useExisting: forwardRef((() => SearchFilterComponent)),
@@ -1325,7 +1331,7 @@ class SearchFilterComponent {
1325
1331
  i0.ɵɵtext(3);
1326
1332
  i0.ɵɵelementEnd();
1327
1333
  i0.ɵɵelementStart(4, "small", 3);
1328
- i0.ɵɵtext(5, "Input description");
1334
+ i0.ɵɵtext(5);
1329
1335
  i0.ɵɵelementEnd();
1330
1336
  i0.ɵɵelementStart(6, "div", 4)(7, "input", 5);
1331
1337
  i0.ɵɵlistener("input", function SearchFilterComponent_Template_input_input_7_listener() { return ctx.filterDataFromSearch(); })("ngModelChange", function SearchFilterComponent_Template_input_ngModelChange_7_listener($event) { return ctx.query = $event; });
@@ -1349,12 +1355,14 @@ class SearchFilterComponent {
1349
1355
  i0.ɵɵtextInterpolate(ctx.label);
1350
1356
  i0.ɵɵadvance(1);
1351
1357
  i0.ɵɵpropertyInterpolate("id", ctx.id + "-description");
1352
- i0.ɵɵadvance(3);
1358
+ i0.ɵɵadvance(1);
1359
+ i0.ɵɵtextInterpolate(ctx.description);
1360
+ i0.ɵɵadvance(2);
1353
1361
  i0.ɵɵpropertyInterpolate("id", ctx.id + "-search");
1354
1362
  i0.ɵɵpropertyInterpolate("name", ctx.name + "-search");
1355
1363
  i0.ɵɵpropertyInterpolate("value", ctx.getSelectedLabels());
1356
1364
  i0.ɵɵproperty("ngModel", ctx.query);
1357
- i0.ɵɵattribute("aria-labelledby", ctx.id + "-label")("placeholder", ctx.placeholder)("disabled", ctx.isDisabled ? "" : null);
1365
+ i0.ɵɵattribute("aria-labelledby", ctx.id + "-label")("disabled", ctx.isDisabled ? "" : null);
1358
1366
  i0.ɵɵadvance(1);
1359
1367
  i0.ɵɵproperty("ngIf", ctx.hasClose);
1360
1368
  i0.ɵɵadvance(1);
@@ -1376,7 +1384,7 @@ class SearchFilterComponent {
1376
1384
  useExisting: forwardRef((() => SearchFilterComponent)),
1377
1385
  multi: true,
1378
1386
  },
1379
- ], template: "<div [align]=\"flyoutAlign\" [size]=\"flyoutSize\" aria-haspopup=\"listbox\" auiFlyout class=\"m-search-filter\">\n <div\n class=\"a-input\"\n [ngClass]=\"{\n 'a-input--l': size === 'large',\n 'a-input--s': size === 'small',\n 'has-icon-right': hasClose\n }\"\n >\n <label class=\"a-input__label\" for=\"{{ id + '-search' }}\">{{ label }}</label>\n <small class=\"a-input__description\" id=\"{{ id + '-description' }}\">Input description</small>\n <div class=\"m-search-filter__input\">\n <input\n (input)=\"filterDataFromSearch()\"\n [(ngModel)]=\"query\"\n [attr.aria-labelledby]=\"id + '-label'\"\n [attr.placeholder]=\"placeholder\"\n [attr.disabled]=\"isDisabled ? '' : null\"\n aria-autocomplete=\"list\"\n id=\"{{ id + '-search' }}\"\n name=\"{{ name + '-search' }}\"\n value=\"{{ getSelectedLabels() }}\"\n type=\"text\"\n auiFlyoutAction\n />\n <button\n *ngIf=\"hasClose\"\n [ngClass]=\"{\n 'a-button--l': size === 'large',\n 'a-button--s': size === 'small'\n }\"\n class=\"a-button a-button--outlined has-icon m-search-filter__button a-button--danger\"\n aria-label=\"Zoekopdracht wissen\"\n type=\"button\"\n (click)=\"clear()\"\n [attr.disabled]=\"isDisabled ? '' : null\"\n >\n <aui-icon name=\"ai-close\"></aui-icon>\n </button>\n <aui-icon *ngIf=\"!hasClose\" name=\"ai-close\"></aui-icon>\n </div>\n </div>\n <div auiFlyoutZone class=\"m-search-filter__search m-search-filter__search--scroll\">\n <p *ngIf=\"labelResults\" class=\"h6 m-search-filter__results-title u-margin-bottom-xs\">{{ labelResults }}</p>\n <div *ngIf=\"loading\" class=\"u-text-center u-padding a-spinner\"></div>\n <ul *ngIf=\"!loading\" class=\"a-checkbox-list a-checkbox-list--flushed\">\n <li *ngIf=\"!filteredChoices.length\" class=\"a-checkbox-list__item\">\n <p class=\"u-margin-xs\">{{ labelNoResults }}</p>\n </li>\n <li *ngFor=\"let choice of filteredChoices; index as i\" class=\"a-checkbox-list__item\">\n <div class=\"a-input a-checkbox-list__checkbox\">\n <div class=\"a-input__checkbox\">\n <input\n (change)=\"toggleSelected(choice.label)\"\n [attr.disabled]=\"isDisabled ? true : null\"\n [checked]=\"selectedItems.indexOf(choice.label) >= 0\"\n id=\"{{ 'checkbox--' + i + '--' + id }}\"\n name=\"{{ 'checkbox--' + i + '--' + id }}\"\n type=\"checkbox\"\n />\n <label for=\"{{ 'checkbox--' + i + '--' + id }}\">{{ choice.label }}</label>\n </div>\n </div>\n </li>\n </ul>\n </div>\n</div>\n", styles: [".m-search-filter{display:block}.m-search-filter__input{display:flex;padding:0}.m-search-filter__input input{border-right:none}.m-search-filter__button{display:inline-block;padding:0;position:relative;vertical-align:middle}.m-search-filter__button .ai{position:relative;transform:none!important;top:0}\n"] }]
1387
+ ], template: "<div [align]=\"flyoutAlign\" [size]=\"flyoutSize\" aria-haspopup=\"listbox\" auiFlyout class=\"m-search-filter\">\n <div\n class=\"a-input\"\n [ngClass]=\"{\n 'a-input--l': size === 'large',\n 'a-input--s': size === 'small',\n 'has-icon-right': hasClose\n }\"\n >\n <label class=\"a-input__label\" for=\"{{ id + '-search' }}\">{{ label }}</label>\n <small class=\"a-input__description\" id=\"{{ id + '-description' }}\">{{ description }}</small>\n <div class=\"m-search-filter__input\">\n <input\n (input)=\"filterDataFromSearch()\"\n [(ngModel)]=\"query\"\n [attr.aria-labelledby]=\"id + '-label'\"\n [attr.disabled]=\"isDisabled ? '' : null\"\n aria-autocomplete=\"list\"\n id=\"{{ id + '-search' }}\"\n name=\"{{ name + '-search' }}\"\n value=\"{{ getSelectedLabels() }}\"\n type=\"text\"\n auiFlyoutAction\n />\n <button\n *ngIf=\"hasClose\"\n [ngClass]=\"{\n 'a-button--l': size === 'large',\n 'a-button--s': size === 'small'\n }\"\n class=\"a-button a-button--outlined has-icon m-search-filter__button a-button--danger\"\n aria-label=\"Zoekopdracht wissen\"\n type=\"button\"\n (click)=\"clear()\"\n [attr.disabled]=\"isDisabled || closeDisabled ? '' : null\"\n >\n <aui-icon name=\"ai-close\"></aui-icon>\n </button>\n <aui-icon *ngIf=\"!hasClose\" name=\"ai-close\"></aui-icon>\n </div>\n </div>\n <div auiFlyoutZone class=\"m-search-filter__search m-search-filter__search--scroll\">\n <p *ngIf=\"labelResults\" class=\"h6 m-search-filter__results-title u-margin-bottom-xs\">{{ labelResults }}</p>\n <div *ngIf=\"loading\" class=\"u-text-center u-padding a-spinner\"></div>\n <ul *ngIf=\"!loading\" class=\"a-checkbox-list a-checkbox-list--flushed\">\n <li *ngIf=\"!filteredChoices.length\" class=\"a-checkbox-list__item\">\n <p class=\"u-margin-xs\">{{ labelNoResults }}</p>\n </li>\n <li *ngFor=\"let choice of filteredChoices; index as i\" class=\"a-checkbox-list__item\">\n <div class=\"a-input a-checkbox-list__checkbox\">\n <div class=\"a-input__checkbox\">\n <input\n (change)=\"toggleSelected(choice.label)\"\n [attr.disabled]=\"isDisabled ? true : null\"\n [checked]=\"selectedItems.indexOf(choice.label) >= 0\"\n id=\"{{ 'checkbox--' + i + '--' + id }}\"\n name=\"{{ 'checkbox--' + i + '--' + id }}\"\n type=\"checkbox\"\n />\n <label for=\"{{ 'checkbox--' + i + '--' + id }}\">{{ choice.label }}</label>\n </div>\n </div>\n </li>\n </ul>\n </div>\n</div>\n", styles: [".m-search-filter{display:block}.m-search-filter__input{display:flex;padding:0}.m-search-filter__input input{border-right:none}.m-search-filter__button{display:inline-block;padding:0;position:relative;vertical-align:middle}.m-search-filter__button .ai{position:relative;transform:none!important;top:0}\n"] }]
1380
1388
  }], function () { return []; }, { id: [{
1381
1389
  type: Input
1382
1390
  }], name: [{
@@ -1399,8 +1407,6 @@ class SearchFilterComponent {
1399
1407
  type: Input
1400
1408
  }], remote: [{
1401
1409
  type: Input
1402
- }], placeholder: [{
1403
- type: Input
1404
1410
  }], inputDelay: [{
1405
1411
  type: Input
1406
1412
  }], onSelect: [{