@quadrel-enterprise-ui/framework 18.24.0 → 18.24.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -118,11 +118,8 @@ export class QdCalendarComponent {
118
118
  this.weeks = Array.from({ length: Math.ceil(dates.length / 7) }, () => dates.splice(0, 7));
119
119
  }
120
120
  fillDates(momentObj) {
121
- const firstOfMonth = moment(momentObj).startOf('month').day();
122
121
  const lastOfMonth = moment(momentObj).endOf('month').day();
123
- const firstDayOfGrid = moment(momentObj)
124
- .startOf('month')
125
- .subtract(firstOfMonth === 0 ? 6 : firstOfMonth - 1, 'days');
122
+ const firstDayOfGrid = moment(momentObj).locale(this.language).startOf('month').startOf('week');
126
123
  const lastDayOfGrid = moment(momentObj).endOf('month').subtract(lastOfMonth, 'days').add(7, 'days');
127
124
  const startCalendar = firstDayOfGrid.date();
128
125
  return range(startCalendar, startCalendar + lastDayOfGrid.diff(firstDayOfGrid, 'days')).map(date => {
@@ -183,4 +180,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImpor
183
180
  }], selectedChange: [{
184
181
  type: Output
185
182
  }] } });
186
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar.component.js","sourceRoot":"","sources":["../../../../../../../libs/qd-ui/src/lib/forms/datepicker/calendar/calendar.component.ts","../../../../../../../libs/qd-ui/src/lib/forms/datepicker/calendar/calendar.component.html"],"names":[],"mappings":"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","sourcesContent":["// @ts-strict-ignore\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnInit,\n  Output,\n  SimpleChanges\n} from '@angular/core';\nimport { range } from 'lodash';\nimport moment, { Moment } from 'moment';\nimport { QdCalendarDay, QdCalendarMode, QdDisabledDates } from '../../model/datepicker';\nimport { QdDateAdapter } from '../adapter/date-adapter';\n\nconst YearsBefore = 9;\nconst YearsAfter = 2;\n\n@Component({\n  selector: 'qd-calendar',\n  templateUrl: './calendar.component.html',\n  styleUrls: ['./calendar.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class QdCalendarComponent implements OnInit, OnChanges {\n  /**\n   * This property is used to highlight the selected date in the calendar. It should be in the format for example 'DD.MM.YYYY' or 'MM/DD/YYYY' depending on the language used.\n   *\n   * @example '2022-12-25'\n   */\n  @Input()\n  selectedDate: QdCalendarDay['formatted'];\n\n  /**\n   * This property determines the language used for displaying the weekdays and formatting the dates in the calendar. It should be a valid language code supported by the moment.js library.\n   *\n   * @example 'de'\n   */\n  @Input()\n  language: string;\n\n  /**\n   * This property disables the given date ranges.The ranges have a \"from\" and \"to\" date.\n   * If \"from\" is empty, it will set the default value 1900\n   * If \"to\" is empty, it will be set to the default 2100\n   *\n   */\n  @Input()\n  disabledDates: QdDisabledDates[];\n\n  /**\n   * Outputs a value when the user selects a date in the calendar. The newly selected date is output as a formatted date string.\n   */\n  @Output()\n  selectedChange = new EventEmitter<QdCalendarDay['formatted']>();\n\n  currentDate: Moment;\n  todayDate: Moment;\n\n  weekdays: string[];\n  weeks: Array<QdCalendarDay[]> = [];\n  months: string[];\n  years: number[];\n\n  mode: QdCalendarMode = QdCalendarMode.Default;\n\n  protected readonly QdCalendarMode = QdCalendarMode;\n\n  ngOnInit(): void {\n    moment.locale(this.language);\n\n    this.weekdays = moment.weekdaysMin(true);\n    this.todayDate = moment();\n\n    this.months = moment.months();\n    this.years = this.getYears(\n      (QdDateAdapter.parseToMoment(this.selectedDate)?.isValid()\n        ? moment(this.selectedDate, 'L', this.language)\n        : this.todayDate\n      ).year()\n    );\n\n    this.setCurrentDate();\n    this.generateCalendar(this.currentDate);\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['language']) moment.locale(this.language);\n    if (changes['disabledDates'] && !changes['disabledDates'].isFirstChange()) this.generateCalendar(this.currentDate);\n  }\n\n  isSameYearMonth(day: Moment): boolean {\n    return day.isSame(this.currentDate, 'month');\n  }\n\n  isSameMonth(month): boolean {\n    return this.currentDate.month() === month;\n  }\n\n  isSameYear(year: number): boolean {\n    return QdDateAdapter.parseToMoment(this.selectedDate).year() === year;\n  }\n\n  prev(): void {\n    if (this.mode === QdCalendarMode.Default) {\n      this.currentDate.subtract(1, 'months');\n      this.generateCalendar(this.currentDate);\n    } else if (this.mode === QdCalendarMode.YearPicker) {\n      this.currentDate.set('year', this.currentDate.year() - (YearsBefore + YearsAfter + 1));\n      this.years = this.getYears(this.currentDate.year());\n    } else {\n      this.currentDate.set('year', this.currentDate.year() - 1);\n    }\n  }\n\n  next(): void {\n    if (this.mode === QdCalendarMode.Default) {\n      this.currentDate.add(1, 'months');\n      this.generateCalendar(this.currentDate);\n    } else if (this.mode === QdCalendarMode.YearPicker) {\n      this.currentDate.set('year', this.currentDate.year() + (YearsBefore + YearsAfter + 1));\n      this.years = this.getYears(this.currentDate.year());\n    } else {\n      this.currentDate.set('year', this.currentDate.year() + 1);\n    }\n  }\n\n  isSelected(momentObj: Moment): boolean {\n    if (!this.selectedDate) return false;\n\n    return QdDateAdapter.formatToLocalizedDateString(momentObj) === this.selectedDate;\n  }\n\n  selectDate(date: QdCalendarDay | any): void {\n    this.selectedChange.emit(date.formatted);\n  }\n\n  selectYear(year: number): void {\n    this.currentDate.set('year', year);\n    this.mode = QdCalendarMode.MonthPicker;\n  }\n\n  selectMonth(month: number): void {\n    this.currentDate.set('month', month);\n    this.generateCalendar(this.currentDate);\n    this.mode = QdCalendarMode.Default;\n  }\n\n  changeMode(nr: QdCalendarMode): void {\n    this.mode = nr;\n  }\n\n  private generateCalendar(momentObj: Moment): void {\n    const dates = this.fillDates(momentObj);\n    this.weeks = Array.from({ length: Math.ceil(dates.length / 7) }, () => dates.splice(0, 7));\n  }\n\n  private fillDates(momentObj: Moment): QdCalendarDay[] {\n    const firstOfMonth = moment(momentObj).startOf('month').day();\n    const lastOfMonth = moment(momentObj).endOf('month').day();\n    const firstDayOfGrid = moment(momentObj)\n      .startOf('month')\n      .subtract(firstOfMonth === 0 ? 6 : firstOfMonth - 1, 'days');\n    const lastDayOfGrid = moment(momentObj).endOf('month').subtract(lastOfMonth, 'days').add(7, 'days');\n    const startCalendar = firstDayOfGrid.date();\n\n    return range(startCalendar, startCalendar + lastDayOfGrid.diff(firstDayOfGrid, 'days')).map(date => {\n      const newDate = moment(firstDayOfGrid).date(date);\n\n      return {\n        formatted: QdDateAdapter.formatToLocalizedDateString(newDate),\n        moment: newDate,\n        selected: this.isSelected(newDate),\n        today: this.isToday(newDate),\n        disabled: this.isDisabled(newDate)\n      };\n    });\n  }\n\n  private isToday(momentObj: Moment): boolean {\n    return this.todayDate.isSame(momentObj, 'day');\n  }\n\n  private setCurrentDate(): void {\n    const currentDate: Moment = (this.currentDate = QdDateAdapter.parseToMoment(this.selectedDate)?.isValid()\n      ? moment(this.selectedDate, 'L', 'de')\n      : this.todayDate);\n\n    this.currentDate = currentDate;\n    this.selectedDate = QdDateAdapter.formatToLocalizedDateString(currentDate);\n  }\n\n  private getYears(year: number): number[] {\n    const yearsBefore = YearsBefore;\n    const yearsAfter = YearsAfter;\n    const result: number[] = [];\n\n    for (let i = year - yearsBefore; i <= year + yearsAfter; i++) {\n      result.push(i);\n    }\n\n    return result;\n  }\n\n  private isDisabled(date: Moment): boolean {\n    if (!this.disabledDates) return false;\n    return this.disabledDates.some(disabledDate => {\n      let fromDate = moment(disabledDate.from);\n      let toDate = moment(disabledDate.to);\n      if (!disabledDate.from) fromDate = moment('1900-01-01T00:00:00.000Z');\n      if (!disabledDate.to) toDate = moment('2100-01-01T00:00:00.000Z');\n\n      return date.isAfter(fromDate, 'day') && date.isBefore(toDate, 'day');\n    });\n  }\n}\n","<div class=\"nav\">\n  <button (click)=\"prev()\">\n    <qd-icon icon=\"arrowLeft\"></qd-icon>\n  </button>\n\n  <ng-container>\n    <span\n      *ngIf=\"mode === QdCalendarMode.Default\"\n      class=\"current-month-year\"\n      (click)=\"changeMode(QdCalendarMode.YearPicker)\"\n    >\n      {{ currentDate.locale(language).format(\"MMMM\") }} {{ currentDate?.format(\"YYYY\") }}\n    </span>\n    <span\n      *ngIf=\"mode === QdCalendarMode.YearPicker\"\n      class=\"current-years-list\"\n      (click)=\"changeMode(QdCalendarMode.MonthPicker)\"\n    >\n      {{ years[0] }} - {{ years[years.length - 1] }}\n    </span>\n    <span\n      *ngIf=\"mode === QdCalendarMode.MonthPicker\"\n      class=\"current-year\"\n      (click)=\"changeMode(QdCalendarMode.YearPicker)\"\n    >\n      {{ currentDate?.format(\"YYYY\") }}\n    </span>\n  </ng-container>\n\n  <button (click)=\"next()\">\n    <qd-icon icon=\"arrowRight\"></qd-icon>\n  </button>\n</div>\n\n<table *ngIf=\"mode === QdCalendarMode.Default\">\n  <thead></thead>\n  <tbody>\n    <tr>\n      <td class=\"weekday\" *ngFor=\"let name of weekdays\">{{ name }}</td>\n    </tr>\n    <tr *ngFor=\"let week of weeks\">\n      <td\n        class=\"day {{ day.moment.date() }}\"\n        *ngFor=\"let day of week\"\n        (click)=\"selectDate(day)\"\n        [ngClass]=\"{\n          today: day.today,\n          selected: day.selected,\n          hidden: !isSameYearMonth(day.moment),\n          disabled: day.disabled\n        }\"\n      >\n        {{ day.moment.date() }}\n      </td>\n    </tr>\n  </tbody>\n</table>\n\n<div class=\"calendar\" *ngIf=\"mode !== QdCalendarMode.Default\">\n  <div class=\"picker\" *ngIf=\"mode === QdCalendarMode.YearPicker\">\n    <div class=\"col {{ year }}\" *ngFor=\"let year of years\">\n      <div class=\"entry\" (click)=\"selectYear(year)\" [ngClass]=\"{ selected: isSameYear(year) }\">\n        {{ year }}\n      </div>\n    </div>\n  </div>\n\n  <div class=\"picker\" *ngIf=\"mode === QdCalendarMode.MonthPicker\">\n    <div class=\"col {{ month }}\" *ngFor=\"let month of months; let i = index\">\n      <div class=\"entry\" (click)=\"selectMonth(i)\" [ngClass]=\"{ selected: isSameMonth(i), month }\">\n        {{ month }}\n      </div>\n    </div>\n  </div>\n</div>\n"]}
183
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar.component.js","sourceRoot":"","sources":["../../../../../../../libs/qd-ui/src/lib/forms/datepicker/calendar/calendar.component.ts","../../../../../../../libs/qd-ui/src/lib/forms/datepicker/calendar/calendar.component.html"],"names":[],"mappings":"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","sourcesContent":["// @ts-strict-ignore\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnInit,\n  Output,\n  SimpleChanges\n} from '@angular/core';\nimport { range } from 'lodash';\nimport moment, { Moment } from 'moment';\nimport { QdCalendarDay, QdCalendarMode, QdDisabledDates } from '../../model/datepicker';\nimport { QdDateAdapter } from '../adapter/date-adapter';\n\nconst YearsBefore = 9;\nconst YearsAfter = 2;\n\n@Component({\n  selector: 'qd-calendar',\n  templateUrl: './calendar.component.html',\n  styleUrls: ['./calendar.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class QdCalendarComponent implements OnInit, OnChanges {\n  /**\n   * This property is used to highlight the selected date in the calendar. It should be in the format for example 'DD.MM.YYYY' or 'MM/DD/YYYY' depending on the language used.\n   *\n   * @example '2022-12-25'\n   */\n  @Input()\n  selectedDate: QdCalendarDay['formatted'];\n\n  /**\n   * This property determines the language used for displaying the weekdays and formatting the dates in the calendar. It should be a valid language code supported by the moment.js library.\n   *\n   * @example 'de'\n   */\n  @Input()\n  language: string;\n\n  /**\n   * This property disables the given date ranges.The ranges have a \"from\" and \"to\" date.\n   * If \"from\" is empty, it will set the default value 1900\n   * If \"to\" is empty, it will be set to the default 2100\n   *\n   */\n  @Input()\n  disabledDates: QdDisabledDates[];\n\n  /**\n   * Outputs a value when the user selects a date in the calendar. The newly selected date is output as a formatted date string.\n   */\n  @Output()\n  selectedChange = new EventEmitter<QdCalendarDay['formatted']>();\n\n  currentDate: Moment;\n  todayDate: Moment;\n\n  weekdays: string[];\n  weeks: Array<QdCalendarDay[]> = [];\n  months: string[];\n  years: number[];\n\n  mode: QdCalendarMode = QdCalendarMode.Default;\n\n  protected readonly QdCalendarMode = QdCalendarMode;\n\n  ngOnInit(): void {\n    moment.locale(this.language);\n\n    this.weekdays = moment.weekdaysMin(true);\n    this.todayDate = moment();\n\n    this.months = moment.months();\n    this.years = this.getYears(\n      (QdDateAdapter.parseToMoment(this.selectedDate)?.isValid()\n        ? moment(this.selectedDate, 'L', this.language)\n        : this.todayDate\n      ).year()\n    );\n\n    this.setCurrentDate();\n    this.generateCalendar(this.currentDate);\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['language']) moment.locale(this.language);\n    if (changes['disabledDates'] && !changes['disabledDates'].isFirstChange()) this.generateCalendar(this.currentDate);\n  }\n\n  isSameYearMonth(day: Moment): boolean {\n    return day.isSame(this.currentDate, 'month');\n  }\n\n  isSameMonth(month): boolean {\n    return this.currentDate.month() === month;\n  }\n\n  isSameYear(year: number): boolean {\n    return QdDateAdapter.parseToMoment(this.selectedDate).year() === year;\n  }\n\n  prev(): void {\n    if (this.mode === QdCalendarMode.Default) {\n      this.currentDate.subtract(1, 'months');\n      this.generateCalendar(this.currentDate);\n    } else if (this.mode === QdCalendarMode.YearPicker) {\n      this.currentDate.set('year', this.currentDate.year() - (YearsBefore + YearsAfter + 1));\n      this.years = this.getYears(this.currentDate.year());\n    } else {\n      this.currentDate.set('year', this.currentDate.year() - 1);\n    }\n  }\n\n  next(): void {\n    if (this.mode === QdCalendarMode.Default) {\n      this.currentDate.add(1, 'months');\n      this.generateCalendar(this.currentDate);\n    } else if (this.mode === QdCalendarMode.YearPicker) {\n      this.currentDate.set('year', this.currentDate.year() + (YearsBefore + YearsAfter + 1));\n      this.years = this.getYears(this.currentDate.year());\n    } else {\n      this.currentDate.set('year', this.currentDate.year() + 1);\n    }\n  }\n\n  isSelected(momentObj: Moment): boolean {\n    if (!this.selectedDate) return false;\n\n    return QdDateAdapter.formatToLocalizedDateString(momentObj) === this.selectedDate;\n  }\n\n  selectDate(date: QdCalendarDay | any): void {\n    this.selectedChange.emit(date.formatted);\n  }\n\n  selectYear(year: number): void {\n    this.currentDate.set('year', year);\n    this.mode = QdCalendarMode.MonthPicker;\n  }\n\n  selectMonth(month: number): void {\n    this.currentDate.set('month', month);\n    this.generateCalendar(this.currentDate);\n    this.mode = QdCalendarMode.Default;\n  }\n\n  changeMode(nr: QdCalendarMode): void {\n    this.mode = nr;\n  }\n\n  private generateCalendar(momentObj: Moment): void {\n    const dates = this.fillDates(momentObj);\n    this.weeks = Array.from({ length: Math.ceil(dates.length / 7) }, () => dates.splice(0, 7));\n  }\n\n  private fillDates(momentObj: Moment): QdCalendarDay[] {\n    const lastOfMonth = moment(momentObj).endOf('month').day();\n    const firstDayOfGrid = moment(momentObj).locale(this.language).startOf('month').startOf('week');\n    const lastDayOfGrid = moment(momentObj).endOf('month').subtract(lastOfMonth, 'days').add(7, 'days');\n    const startCalendar = firstDayOfGrid.date();\n\n    return range(startCalendar, startCalendar + lastDayOfGrid.diff(firstDayOfGrid, 'days')).map(date => {\n      const newDate = moment(firstDayOfGrid).date(date);\n\n      return {\n        formatted: QdDateAdapter.formatToLocalizedDateString(newDate),\n        moment: newDate,\n        selected: this.isSelected(newDate),\n        today: this.isToday(newDate),\n        disabled: this.isDisabled(newDate)\n      };\n    });\n  }\n\n  private isToday(momentObj: Moment): boolean {\n    return this.todayDate.isSame(momentObj, 'day');\n  }\n\n  private setCurrentDate(): void {\n    const currentDate: Moment = (this.currentDate = QdDateAdapter.parseToMoment(this.selectedDate)?.isValid()\n      ? moment(this.selectedDate, 'L', 'de')\n      : this.todayDate);\n\n    this.currentDate = currentDate;\n    this.selectedDate = QdDateAdapter.formatToLocalizedDateString(currentDate);\n  }\n\n  private getYears(year: number): number[] {\n    const yearsBefore = YearsBefore;\n    const yearsAfter = YearsAfter;\n    const result: number[] = [];\n\n    for (let i = year - yearsBefore; i <= year + yearsAfter; i++) {\n      result.push(i);\n    }\n\n    return result;\n  }\n\n  private isDisabled(date: Moment): boolean {\n    if (!this.disabledDates) return false;\n    return this.disabledDates.some(disabledDate => {\n      let fromDate = moment(disabledDate.from);\n      let toDate = moment(disabledDate.to);\n      if (!disabledDate.from) fromDate = moment('1900-01-01T00:00:00.000Z');\n      if (!disabledDate.to) toDate = moment('2100-01-01T00:00:00.000Z');\n\n      return date.isAfter(fromDate, 'day') && date.isBefore(toDate, 'day');\n    });\n  }\n}\n","<div class=\"nav\">\n  <button (click)=\"prev()\">\n    <qd-icon icon=\"arrowLeft\"></qd-icon>\n  </button>\n\n  <ng-container>\n    <span\n      *ngIf=\"mode === QdCalendarMode.Default\"\n      class=\"current-month-year\"\n      (click)=\"changeMode(QdCalendarMode.YearPicker)\"\n    >\n      {{ currentDate.locale(language).format(\"MMMM\") }} {{ currentDate?.format(\"YYYY\") }}\n    </span>\n    <span\n      *ngIf=\"mode === QdCalendarMode.YearPicker\"\n      class=\"current-years-list\"\n      (click)=\"changeMode(QdCalendarMode.MonthPicker)\"\n    >\n      {{ years[0] }} - {{ years[years.length - 1] }}\n    </span>\n    <span\n      *ngIf=\"mode === QdCalendarMode.MonthPicker\"\n      class=\"current-year\"\n      (click)=\"changeMode(QdCalendarMode.YearPicker)\"\n    >\n      {{ currentDate?.format(\"YYYY\") }}\n    </span>\n  </ng-container>\n\n  <button (click)=\"next()\">\n    <qd-icon icon=\"arrowRight\"></qd-icon>\n  </button>\n</div>\n\n<table *ngIf=\"mode === QdCalendarMode.Default\">\n  <thead></thead>\n  <tbody>\n    <tr>\n      <td class=\"weekday\" *ngFor=\"let name of weekdays\">{{ name }}</td>\n    </tr>\n    <tr *ngFor=\"let week of weeks\">\n      <td\n        class=\"day {{ day.moment.date() }}\"\n        *ngFor=\"let day of week\"\n        (click)=\"selectDate(day)\"\n        [ngClass]=\"{\n          today: day.today,\n          selected: day.selected,\n          hidden: !isSameYearMonth(day.moment),\n          disabled: day.disabled\n        }\"\n      >\n        {{ day.moment.date() }}\n      </td>\n    </tr>\n  </tbody>\n</table>\n\n<div class=\"calendar\" *ngIf=\"mode !== QdCalendarMode.Default\">\n  <div class=\"picker\" *ngIf=\"mode === QdCalendarMode.YearPicker\">\n    <div class=\"col {{ year }}\" *ngFor=\"let year of years\">\n      <div class=\"entry\" (click)=\"selectYear(year)\" [ngClass]=\"{ selected: isSameYear(year) }\">\n        {{ year }}\n      </div>\n    </div>\n  </div>\n\n  <div class=\"picker\" *ngIf=\"mode === QdCalendarMode.MonthPicker\">\n    <div class=\"col {{ month }}\" *ngFor=\"let month of months; let i = index\">\n      <div class=\"entry\" (click)=\"selectMonth(i)\" [ngClass]=\"{ selected: isSameMonth(i), month }\">\n        {{ month }}\n      </div>\n    </div>\n  </div>\n</div>\n"]}
@@ -397,13 +397,13 @@ export class QdMultiInputComponent {
397
397
  return this.optionsListForView.findIndex(option => this.getTranslation(option) === optionName);
398
398
  }
399
399
  addItem(option) {
400
+ this.filterOptions = '';
400
401
  if (this.formArray) {
401
402
  this.formArray.push(option.value);
402
403
  this.formArray.markAsTouched();
403
404
  return;
404
405
  }
405
406
  this.multiInputService.addSelectedItem(option);
406
- this.filterOptions = '';
407
407
  this.changeValue();
408
408
  this.writeValue(this.multiInputService.getItemValues());
409
409
  }
@@ -537,4 +537,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImpor
537
537
  type: HostListener,
538
538
  args: ['document:click', ['$event']]
539
539
  }] } });
540
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"multi-input.component.js","sourceRoot":"","sources":["../../../../../../libs/qd-ui/src/lib/forms/multi-input/multi-input.component.ts","../../../../../../libs/qd-ui/src/lib/forms/multi-input/multi-input.component.html"],"names":[],"mappings":"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","sourcesContent":["// @ts-strict-ignore\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  forwardRef,\n  Host,\n  HostBinding,\n  HostListener,\n  Input,\n  NgIterable,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  QueryList,\n  SkipSelf,\n  ViewChild,\n  ViewChildren\n} from '@angular/core';\nimport {\n  ControlContainer,\n  ControlValueAccessor,\n  FormControl,\n  NG_VALUE_ACCESSOR,\n  UntypedFormControl\n} from '@angular/forms';\nimport isEqual from 'lodash/isEqual';\nimport { Subscription } from 'rxjs';\nimport { v4 as uuid } from 'uuid';\n\nimport { QdFormMultiInputConfiguration, QdMultiInputOption } from '../model/forms.interface';\nimport { QdFormArray } from '../reactive-forms/controls/form-array';\nimport { QdFormArrayFactoryService } from '../reactive-forms/controls/form-array-factory.service';\nimport {\n  getDisabled,\n  getHintAction,\n  getLabel,\n  getMultiInputOptions,\n  getReadonly,\n  getReadonlyAction,\n  getViewonly,\n  getViewonlyAction\n} from '../shared/helpers/forms.helpers';\nimport { QdFormsActionEmitterService } from '../shared/services/action-emitter.service';\nimport { QdMultiInputService } from './multi-input-service/multi-input.service';\nimport { QdPopoverOnClickDirective } from '../../core/popover/popover-on-click/popover-on-click.directive';\nimport { QdMultiInputMenuComponent } from './multi-input-menu/multi-input-menu.component';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { QdEventBrokerService } from '../../core/services/event-broker.service';\n\n/**\n * The **QdMultiInput** is a component that provides a user interface for entering multiple inputs.<br />\n * It is designed to enhance the user experience when dealing with multiple inputs and can be used with Quadrel Reactive Forms or with model binding.\n *\n * ####**Usage with Reactive Forms**\n *\n * ```ts\n * form = new QdFormGroup({\n *   multiInput: new QdFormArray()\n * });\n * ```\n * ```html\n * <form [formGroup]=\"form\">\n *   <qd-multi-input [formArrayName]=\"multiInput\" [config]=\"config\"></qd-multi-input>\n * </form>\n * ```\n *\n * ####**Usage with Model Binding**\n * ```ts\n * values;\n * ```\n * ```html\n * <qd-multi-input [(values)]=\"values\" [config]=\"config\"></qd-multi-input>\n * ```\n */\n@Component({\n  selector: 'qd-multi-input',\n  templateUrl: './multi-input.component.html',\n  styleUrls: ['./multi-input.component.scss'],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: QdMultiInputComponent,\n      multi: true\n    },\n    QdMultiInputService,\n    QdFormsActionEmitterService\n  ],\n  host: { class: 'qd-multi-input' },\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class QdMultiInputComponent implements ControlValueAccessor, OnInit, OnChanges, OnDestroy, OnDestroy {\n  /**\n   * Here an id can be assigned, with which a value can be linked to a corresponding label.\n   */\n  @Input() id;\n\n  /**\n   * The current form item values, if you are working with Model Binding.\n   *\n   * @example\n   * <qd-multi-input [(values)]=\"values\" [config]=\"config\"></qd-multi-input>\n   */\n  @Input() set values(values: string[]) {\n    this._values = values;\n  }\n\n  get values(): string[] {\n    return this._values;\n  }\n\n  /**\n   * * @deprecated\n   * TODO remove logic for support of [formControlName] directive and FormControl with angular 14 update\n   */\n  @Input() set formControlName(formControlName: string) {\n    console.warn(\n      'QD-UI | QdMultiInputComponent - Please use the MultiInput with the QdFormArray form control and the [formArrayName] directive!'\n    );\n    this._formControlName = formControlName;\n  }\n\n  get formControlName(): string {\n    return this._formControlName;\n  }\n\n  @Input() set formArrayName(formArrayName: string) {\n    this._formArrayName = formArrayName;\n  }\n\n  get formArrayName(): string {\n    return this._formArrayName || this.formControlName;\n  }\n\n  /**\n   * The configuration for this form item\n   *\n   * @example\n   * {\n   *   label: { i18n: 'my-label' },\n   *   hint: { i18n: 'my-hint' },\n   *   options: [\n   *     { i18n: 'i18n.qd.exampleFormField.goodsDeclaration.import', value: 'import' },\n   *     { i18n: 'i18n.qd.exampleFormField.goodsDeclaration.export', value: 'export' },\n   *     { i18n: 'i18n.qd.exampleFormField.goodsDeclaration.transit', value: 'transit' }\n   *   ]\n   * };\n   */\n  @Input() config: QdFormMultiInputConfiguration;\n\n  /**\n   * A static test ID for integration tests can be set. <br />\n   * The value for the HTML attribute [data-test-id].\n   */\n  @Input('data-test-id') testId = 'multi-input';\n\n  /**\n   * Emits event when the values change. Return values match the current values.\n   */\n  @Output() readonly valuesChange = new EventEmitter<string[]>();\n\n  /**\n   * Emits event when the hint is clicked/tapped. `hintAction` must be set to `true` for this.\n   */\n  @Output() readonly clickHint = new EventEmitter();\n\n  /**\n   * Emits event when a readonly value is clicked/tapped. `clickReadonly ` must be set to `true` for this.\n   */\n  @Output() readonly clickReadonly = new EventEmitter();\n\n  /**\n   * Emits event when a viewonly value is clicked/tapped. `clickViewonly ` must be set to `true` for this.\n   */\n  @Output() readonly clickViewonly = new EventEmitter();\n\n  @ViewChild('input') inputField: ElementRef;\n  @ViewChild(forwardRef(() => QdMultiInputMenuComponent)) multiInputMenu: QdMultiInputMenuComponent;\n  @ViewChild(QdPopoverOnClickDirective) popoverOnClickDirective: QdPopoverOnClickDirective;\n  @ViewChildren('errorTooltips') errorTooltips: QueryList<ElementRef>;\n  @ViewChildren('dropdownOption') dropdownOptions: QueryList<ElementRef>;\n\n  @HostBinding('class.qd-multi-input-readonly')\n  @HostBinding('class.qd-multi-input-chip-readonly')\n  readonly = false;\n\n  @HostBinding('class.qd-multi-input--readonly-action')\n  readonlyAction = false;\n\n  @HostBinding('class.qd-multi-input-viewonly')\n  @HostBinding('class.qd-multi-input-chip-viewonly')\n  viewonly = false;\n\n  @HostBinding('class.qd-multi-input--viewonly-action')\n  viewonlyAction = false;\n\n  @HostBinding('class.qd-form-hint-action')\n  @HostBinding('class.qd-multi-input--hint-action')\n  hintAction = false;\n\n  @HostBinding('class.qd-form-disabled')\n  @HostBinding('class.qd-multi-input-disabled')\n  @HostBinding('class.qd-multi-input-chip-disabled')\n  disabled = false;\n\n  @HostBinding('class.qd-multi-input-focus')\n  hasFocus = false;\n\n  @HostBinding('class.qd-form-error')\n  @HostBinding('class.qd-multi-input-error')\n  get hasError(): boolean {\n    return this.formArray ? this.formArray.touched && this.formArray.invalid : false;\n  }\n\n  @HostListener('document:click', ['$event']) clickOutside($event): void {\n    if (\n      typeof $event.target.className === 'string' &&\n      !$event.target.className.includes('qd-multi-input') &&\n      this.open\n    ) {\n      this._onTouch();\n      if ($event?.pointerId !== -1) this.closePopover();\n    }\n  }\n\n  label: string;\n  options: QdMultiInputOption[];\n  open = false;\n  optionsListForView: QdMultiInputOption[];\n  filterOptions: string;\n  formArray: QdFormArray<string>;\n\n  private _values: string[];\n  private _formControlName: string;\n  private _formArrayName: string;\n  private _onDisabledChange;\n  private _subs = new Subscription();\n  private _resizeObserver: ResizeObserver;\n  private _onChange: any = () => {};\n  private _onTouch: any = () => {};\n\n  get hasHint(): boolean {\n    return this.config.hint && this.config.hint.i18n && !this.config.hint.disabled;\n  }\n\n  constructor(\n    private readonly hostRef: ElementRef<HTMLElement>,\n    private readonly multiInputService: QdMultiInputService,\n    private readonly changeDetectorRef: ChangeDetectorRef,\n    private readonly actionEmitterService: QdFormsActionEmitterService,\n    private readonly qdFormArrayFactoryService: QdFormArrayFactoryService,\n    @Optional() @Host() @SkipSelf() private readonly controlContainer: ControlContainer,\n    @Optional() private readonly eventBrokerService: QdEventBrokerService\n  ) {\n    if (!this.id) this.id = uuid();\n\n    this.multiInputService.optionsListForView$.pipe(takeUntilDestroyed()).subscribe(list => {\n      this.optionsListForView = list;\n    });\n  }\n\n  ngOnInit(): void {\n    this.updateConfiguration();\n\n    this.multiInputService.setOptionsList(this.options);\n    this.multiInputService.setSelectedItems(this.values);\n\n    this._subs.add(this.actionEmitterService.hintEventEmitter$.subscribe(() => this.clickHint.emit()));\n    this._subs.add(this.actionEmitterService.readonlyEventEmitter$.subscribe(() => this.clickReadonly.emit()));\n    this._subs.add(this.actionEmitterService.viewonlyEventEmitter$.subscribe(() => this.clickViewonly.emit()));\n    this._subs.add(this.initOpModeSubscription());\n\n    if (!this.controlContainer) return;\n\n    if (this.formArrayName) {\n      const formArray = this.controlContainer.control.get(this.formArrayName);\n\n      // Updating form array programmatically from outside\n      this._subs.add(\n        formArray.valueChanges.subscribe(() => {\n          this.multiInputService.setSelectedItems(this.formArray.value);\n          this.valuesChange.emit(this.formArray.value);\n        })\n      );\n\n      if (formArray instanceof QdFormArray) {\n        this.formArray = formArray;\n        this.multiInputService.setSelectedItems(this.formArray.value);\n      } else {\n        // TODO remove logic for support of Angular FormControl with angular 19 update\n        this.formArray = this.qdFormArrayFactoryService.createQdFormArrayFromFormControl(\n          formArray as UntypedFormControl\n        );\n        console.warn('QD-UI | QdMultiInputComponent - Please use the MultiInput with the QdFormArray form control!');\n      }\n      this.disabled = formArray.disabled;\n      this._onDisabledChange = (disabled): void => {\n        this.disabled = disabled;\n      };\n      this.formArray.registerOnDisabledChange(this._onDisabledChange);\n    } else {\n      console.warn(\n        'QD-UI | QdMultiInputComponent - Missing [formArrayName] directive from host element of the component'\n      );\n    }\n  }\n\n  ngOnChanges(changes): void {\n    if (changes.config) {\n      this.updateConfiguration();\n      if (this.haveOptionsChanged(changes)) {\n        this.multiInputService.setOptionsList(this.options);\n      }\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.clickOutside = (): void => {};\n    this._subs?.unsubscribe();\n    this._resizeObserver?.disconnect();\n\n    if (this.formArray && this._onDisabledChange) this.formArray._unregisterOnDisabledChange(this._onDisabledChange);\n  }\n\n  registerOnChange(fn: (_: any) => void): void {\n    this._onChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this._onTouch = fn;\n  }\n\n  writeValue(values: string[]): void {\n    if (!this.controlContainer) this.getItems();\n\n    this.values = values;\n    this.valuesChange.emit(this.values);\n  }\n\n  getItems(): QdMultiInputOption[] {\n    return this.multiInputService.getItems();\n  }\n\n  hasItems(): boolean {\n    return this.multiInputService.getItems().length > 0;\n  }\n\n  getTranslation(option: QdMultiInputOption): string {\n    return this.multiInputService.getTranslation(option);\n  }\n\n  openPopover(): void {\n    if (this.readonly || this.viewonly || this.disabled || this.options.length === 0) return;\n\n    this.popoverOnClickDirective?.open();\n  }\n\n  closePopover(): void {\n    if (this.readonly || this.viewonly || this.disabled) return;\n\n    this.popoverOnClickDirective?.close();\n  }\n\n  handleClick(option: QdMultiInputOption): void {\n    if (!option.disabled) {\n      this.addItem(option);\n      this.closePopover();\n    }\n\n    this.focus();\n  }\n\n  handleBlur(): void {\n    this.hasFocus = false;\n  }\n\n  onKeyDown(event: KeyboardEvent): void {\n    switch (event.key) {\n      case 'Enter': {\n        const newOption = this.multiInputMenu?.keyManager?.activeItem?.option;\n        if (newOption?.disabled) return;\n        const option = this.optionsListForView.find(s => s.value === newOption?.value) || undefined;\n        this.addChip(option);\n        this.openPopover();\n        break;\n      }\n      case 'Escape':\n        this.closePopover();\n        this.blur();\n        break;\n\n      case 'ArrowUp':\n        this.openPopover();\n        this.multiInputMenu?.handleArrowKey('up', event);\n        break;\n\n      case 'ArrowDown':\n        this.openPopover();\n        this.multiInputMenu?.handleArrowKey('down', event);\n        break;\n\n      default:\n        this.openPopover();\n    }\n  }\n\n  changeValue(): void {\n    this.multiInputService.setCurrentInput(this.filterOptions);\n    this.openPopover();\n    this.multiInputMenu?.resetCheckedOption();\n    this.changeDetectorRef.detectChanges();\n  }\n\n  close(index): void {\n    if (this.formArray) {\n      this.formArray.removeAt(index);\n      this.formArray.markAsTouched();\n      return;\n    }\n\n    this.multiInputService.removeItemAtIndex(index);\n    this.writeValue(this.multiInputService.getItemValues());\n    this.focus();\n  }\n\n  getIterableElements(): NgIterable<any> {\n    return this.getItemsArray();\n  }\n\n  getValues(): QdMultiInputOption[] {\n    const values = this.getItemsArray().map(i => this.multiInputService.findOption(i.value));\n    return values;\n  }\n\n  handleChipClick($event): void {\n    $event.stopPropagation();\n    this.focus();\n    if (this.readonlyAction) this.handleReadOnlyAction($event);\n    if (this.viewonlyAction) this.handleViewOnlyAction($event);\n  }\n\n  handleReadOnlyAction($event): void {\n    this.clickReadonly.emit($event.target.dataset.value);\n  }\n\n  handleViewOnlyAction($event): void {\n    this.clickViewonly.emit($event.target.dataset.value);\n  }\n\n  focus(): void {\n    this.inputField?.nativeElement.focus();\n  }\n\n  private updateConfiguration(): void {\n    this.label = getLabel(this.config);\n    this.readonly = getReadonly(this.config, this.readonly);\n    this.viewonly = getViewonly(this.config, this.viewonly);\n    this.hintAction = getHintAction(this.config);\n    this.readonlyAction = getReadonlyAction(this.config);\n    this.viewonlyAction = getViewonlyAction(this.config);\n    this.disabled = getDisabled(this.config) || !!this.formArray?.disabled;\n    this.options = getMultiInputOptions(this.config);\n  }\n\n  private addChip(option?: QdMultiInputOption): void {\n    if (!option || !this.optionsListForView.map(options => options.value).includes(option.value)) {\n      if (this.inputField.nativeElement.value === '') return;\n\n      this.handleUserInput();\n    } else {\n      this.addItem(option);\n    }\n  }\n\n  private handleUserInput(): void {\n    const items: QdMultiInputOption[] = [];\n    if (this.filterOptions !== '' && !this.config.disableFreetext) {\n      const optionIndex = this.findOptionIndex(this.filterOptions);\n      if (optionIndex === -1) {\n        items.push(...this.getSplitOptions());\n      } else {\n        items.push(this.optionsListForView[optionIndex]);\n      }\n      this.addItemsToChipSet(items);\n    }\n  }\n\n  private addItemsToChipSet(items: QdMultiInputOption[]): void {\n    if (this.formArray) {\n      items.forEach(item => {\n        this.formArray.push(item.value);\n        this.multiInputService.addSelectedItem(item);\n      });\n      this.filterOptions = '';\n      this.changeValue();\n      this.formArray.markAsTouched();\n    } else {\n      items.forEach(item => this.addItem(item));\n    }\n  }\n\n  private getSplitOptions(): QdMultiInputOption[] {\n    return this.multiInputService.splitFilterOptions(this.filterOptions, this.config.inputSplitters);\n  }\n\n  private findOptionIndex(optionName: string): number {\n    return this.optionsListForView.findIndex(option => this.getTranslation(option) === optionName);\n  }\n\n  private addItem(option: QdMultiInputOption): void {\n    if (this.formArray) {\n      this.formArray.push(option.value);\n      this.formArray.markAsTouched();\n      return;\n    }\n\n    this.multiInputService.addSelectedItem(option);\n    this.filterOptions = '';\n    this.changeValue();\n    this.writeValue(this.multiInputService.getItemValues());\n  }\n\n  private haveOptionsChanged(changes): boolean {\n    return !isEqual(changes.config.previousValue?.options, changes.config.currentValue?.options);\n  }\n\n  private blur(): void {\n    this.inputField?.nativeElement.blur();\n  }\n\n  private getItemsArray(): (FormControl | QdMultiInputOption)[] {\n    return this.formArray ? (this.formArray.controls as FormControl[]) : this.getItems();\n  }\n\n  private initOpModeSubscription(): Subscription | void {\n    if (!this.eventBrokerService) return;\n\n    return this.eventBrokerService.consume<{ isViewonly: boolean }>('operation_mode_changed').subscribe(topic => {\n      if (typeof this.config.viewonly === 'boolean') return;\n\n      this.viewonly = getViewonly(this.config, topic.payload.isViewonly);\n    });\n  }\n}\n","<qd-form-label\n  [label]=\"label\"\n  [readonly]=\"readonly\"\n  [viewonly]=\"viewonly\"\n  [control]=\"formArray\"\n  [tooltip]=\"config?.tooltip\"\n  [data-test-id]=\"testId\"\n></qd-form-label>\n\n<div\n  *ngIf=\"!readonly && !viewonly\"\n  class=\"qd-multi-input__input-chip-box\"\n  (click)=\"focus()\"\n  (opened)=\"open = true\"\n  (closed)=\"open = false\"\n  [qdPopoverOnClick]=\"menu\"\n  [qdPopoverCloseStrategy]=\"'onOutsideClick'\"\n  [qdPopoverDisabled]=\"options.length === 0\"\n  [qdPopoverAutoSize]=\"{ width: true }\"\n  [qdPopoverBackgroundColor]=\"'transparent'\"\n  [positionStrategy]=\"[\n    {\n      originX: 'start',\n      originY: 'bottom',\n      overlayX: 'start',\n      overlayY: 'top',\n      offsetX: -2\n    },\n    {\n      originX: 'start',\n      originY: 'top',\n      overlayX: 'start',\n      overlayY: 'bottom',\n      weight: 0.8,\n      offsetX: -2\n    }\n  ]\"\n>\n  <div [ngClass]=\"hasItems() ? 'qd-multi-input__chip-margin' : ''\">\n    <qd-multi-input-chip\n      *ngFor=\"let element of getIterableElements(); let index = index\"\n      [close]=\"!disabled && !readonly && !viewonly\"\n      [itemControl]=\"formArray ? element : undefined\"\n      [value]=\"formArray ? undefined : getTranslation(element)\"\n      (closeClickEmitter)=\"close(index)\"\n      (click)=\"handleChipClick($event)\"\n    >\n    </qd-multi-input-chip>\n  </div>\n\n  <div class=\"qd-multi-input__wrapper\">\n    <input\n      #input\n      type=\"text\"\n      class=\"qd-multi-input__box\"\n      *ngIf=\"!readonly && !viewonly\"\n      [disabled]=\"disabled\"\n      [(ngModel)]=\"filterOptions\"\n      (ngModelChange)=\"changeValue()\"\n      (keydown)=\"onKeyDown($event)\"\n      (focus)=\"hasFocus = true\"\n      (blur)=\"handleBlur()\"\n      [ngClass]=\"open ? 'qd-multi-input__box--open' : ''\"\n      [attr.data-test-id]=\"testId + '-input'\"\n    />\n\n    <div class=\"qd-multi-input__box qd-multi-input__box--readonly\" *ngIf=\"readonly && !hasItems()\">&nbsp;</div>\n\n    <div class=\"qd-multi-input__box qd-multi-input__box--viewonly\" *ngIf=\"viewonly && !hasItems()\">&nbsp;</div>\n\n    <ng-template #menu>\n      <qd-multi-input-menu\n        [optionsListForView]=\"optionsListForView\"\n        [id]=\"id\"\n        [data-test-id]=\"testId\"\n        (itemClick)=\"handleClick($event)\"\n      ></qd-multi-input-menu>\n    </ng-template>\n  </div>\n</div>\n\n<ng-container *ngIf=\"config && !readonly && !viewonly\">\n  <qd-form-hint\n    [hint]=\"hasHint ? config.hint.i18n : ''\"\n    [control]=\"formArray\"\n    [hasError]=\"hasError\"\n    [hintAction]=\"hintAction\"\n    [data-test-id]=\"testId\"\n  ></qd-form-hint>\n</ng-container>\n\n<qd-form-readonly\n  *ngIf=\"readonly\"\n  [values]=\"getValues()\"\n  [readonlyAction]=\"readonlyAction\"\n  [data-test-id]=\"testId\"\n></qd-form-readonly>\n\n<qd-form-viewonly\n  *ngIf=\"viewonly\"\n  [values]=\"getValues()\"\n  [viewonlyAction]=\"viewonlyAction\"\n  [data-test-id]=\"testId\"\n></qd-form-viewonly>\n"]}
540
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"multi-input.component.js","sourceRoot":"","sources":["../../../../../../libs/qd-ui/src/lib/forms/multi-input/multi-input.component.ts","../../../../../../libs/qd-ui/src/lib/forms/multi-input/multi-input.component.html"],"names":[],"mappings":"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","sourcesContent":["// @ts-strict-ignore\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  forwardRef,\n  Host,\n  HostBinding,\n  HostListener,\n  Input,\n  NgIterable,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  QueryList,\n  SkipSelf,\n  ViewChild,\n  ViewChildren\n} from '@angular/core';\nimport {\n  ControlContainer,\n  ControlValueAccessor,\n  FormControl,\n  NG_VALUE_ACCESSOR,\n  UntypedFormControl\n} from '@angular/forms';\nimport isEqual from 'lodash/isEqual';\nimport { Subscription } from 'rxjs';\nimport { v4 as uuid } from 'uuid';\n\nimport { QdFormMultiInputConfiguration, QdMultiInputOption } from '../model/forms.interface';\nimport { QdFormArray } from '../reactive-forms/controls/form-array';\nimport { QdFormArrayFactoryService } from '../reactive-forms/controls/form-array-factory.service';\nimport {\n  getDisabled,\n  getHintAction,\n  getLabel,\n  getMultiInputOptions,\n  getReadonly,\n  getReadonlyAction,\n  getViewonly,\n  getViewonlyAction\n} from '../shared/helpers/forms.helpers';\nimport { QdFormsActionEmitterService } from '../shared/services/action-emitter.service';\nimport { QdMultiInputService } from './multi-input-service/multi-input.service';\nimport { QdPopoverOnClickDirective } from '../../core/popover/popover-on-click/popover-on-click.directive';\nimport { QdMultiInputMenuComponent } from './multi-input-menu/multi-input-menu.component';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { QdEventBrokerService } from '../../core/services/event-broker.service';\n\n/**\n * The **QdMultiInput** is a component that provides a user interface for entering multiple inputs.<br />\n * It is designed to enhance the user experience when dealing with multiple inputs and can be used with Quadrel Reactive Forms or with model binding.\n *\n * ####**Usage with Reactive Forms**\n *\n * ```ts\n * form = new QdFormGroup({\n *   multiInput: new QdFormArray()\n * });\n * ```\n * ```html\n * <form [formGroup]=\"form\">\n *   <qd-multi-input [formArrayName]=\"multiInput\" [config]=\"config\"></qd-multi-input>\n * </form>\n * ```\n *\n * ####**Usage with Model Binding**\n * ```ts\n * values;\n * ```\n * ```html\n * <qd-multi-input [(values)]=\"values\" [config]=\"config\"></qd-multi-input>\n * ```\n */\n@Component({\n  selector: 'qd-multi-input',\n  templateUrl: './multi-input.component.html',\n  styleUrls: ['./multi-input.component.scss'],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: QdMultiInputComponent,\n      multi: true\n    },\n    QdMultiInputService,\n    QdFormsActionEmitterService\n  ],\n  host: { class: 'qd-multi-input' },\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class QdMultiInputComponent implements ControlValueAccessor, OnInit, OnChanges, OnDestroy, OnDestroy {\n  /**\n   * Here an id can be assigned, with which a value can be linked to a corresponding label.\n   */\n  @Input() id;\n\n  /**\n   * The current form item values, if you are working with Model Binding.\n   *\n   * @example\n   * <qd-multi-input [(values)]=\"values\" [config]=\"config\"></qd-multi-input>\n   */\n  @Input() set values(values: string[]) {\n    this._values = values;\n  }\n\n  get values(): string[] {\n    return this._values;\n  }\n\n  /**\n   * * @deprecated\n   * TODO remove logic for support of [formControlName] directive and FormControl with angular 14 update\n   */\n  @Input() set formControlName(formControlName: string) {\n    console.warn(\n      'QD-UI | QdMultiInputComponent - Please use the MultiInput with the QdFormArray form control and the [formArrayName] directive!'\n    );\n    this._formControlName = formControlName;\n  }\n\n  get formControlName(): string {\n    return this._formControlName;\n  }\n\n  @Input() set formArrayName(formArrayName: string) {\n    this._formArrayName = formArrayName;\n  }\n\n  get formArrayName(): string {\n    return this._formArrayName || this.formControlName;\n  }\n\n  /**\n   * The configuration for this form item\n   *\n   * @example\n   * {\n   *   label: { i18n: 'my-label' },\n   *   hint: { i18n: 'my-hint' },\n   *   options: [\n   *     { i18n: 'i18n.qd.exampleFormField.goodsDeclaration.import', value: 'import' },\n   *     { i18n: 'i18n.qd.exampleFormField.goodsDeclaration.export', value: 'export' },\n   *     { i18n: 'i18n.qd.exampleFormField.goodsDeclaration.transit', value: 'transit' }\n   *   ]\n   * };\n   */\n  @Input() config: QdFormMultiInputConfiguration;\n\n  /**\n   * A static test ID for integration tests can be set. <br />\n   * The value for the HTML attribute [data-test-id].\n   */\n  @Input('data-test-id') testId = 'multi-input';\n\n  /**\n   * Emits event when the values change. Return values match the current values.\n   */\n  @Output() readonly valuesChange = new EventEmitter<string[]>();\n\n  /**\n   * Emits event when the hint is clicked/tapped. `hintAction` must be set to `true` for this.\n   */\n  @Output() readonly clickHint = new EventEmitter();\n\n  /**\n   * Emits event when a readonly value is clicked/tapped. `clickReadonly ` must be set to `true` for this.\n   */\n  @Output() readonly clickReadonly = new EventEmitter();\n\n  /**\n   * Emits event when a viewonly value is clicked/tapped. `clickViewonly ` must be set to `true` for this.\n   */\n  @Output() readonly clickViewonly = new EventEmitter();\n\n  @ViewChild('input') inputField: ElementRef;\n  @ViewChild(forwardRef(() => QdMultiInputMenuComponent)) multiInputMenu: QdMultiInputMenuComponent;\n  @ViewChild(QdPopoverOnClickDirective) popoverOnClickDirective: QdPopoverOnClickDirective;\n  @ViewChildren('errorTooltips') errorTooltips: QueryList<ElementRef>;\n  @ViewChildren('dropdownOption') dropdownOptions: QueryList<ElementRef>;\n\n  @HostBinding('class.qd-multi-input-readonly')\n  @HostBinding('class.qd-multi-input-chip-readonly')\n  readonly = false;\n\n  @HostBinding('class.qd-multi-input--readonly-action')\n  readonlyAction = false;\n\n  @HostBinding('class.qd-multi-input-viewonly')\n  @HostBinding('class.qd-multi-input-chip-viewonly')\n  viewonly = false;\n\n  @HostBinding('class.qd-multi-input--viewonly-action')\n  viewonlyAction = false;\n\n  @HostBinding('class.qd-form-hint-action')\n  @HostBinding('class.qd-multi-input--hint-action')\n  hintAction = false;\n\n  @HostBinding('class.qd-form-disabled')\n  @HostBinding('class.qd-multi-input-disabled')\n  @HostBinding('class.qd-multi-input-chip-disabled')\n  disabled = false;\n\n  @HostBinding('class.qd-multi-input-focus')\n  hasFocus = false;\n\n  @HostBinding('class.qd-form-error')\n  @HostBinding('class.qd-multi-input-error')\n  get hasError(): boolean {\n    return this.formArray ? this.formArray.touched && this.formArray.invalid : false;\n  }\n\n  @HostListener('document:click', ['$event']) clickOutside($event): void {\n    if (\n      typeof $event.target.className === 'string' &&\n      !$event.target.className.includes('qd-multi-input') &&\n      this.open\n    ) {\n      this._onTouch();\n      if ($event?.pointerId !== -1) this.closePopover();\n    }\n  }\n\n  label: string;\n  options: QdMultiInputOption[];\n  open = false;\n  optionsListForView: QdMultiInputOption[];\n  filterOptions: string;\n  formArray: QdFormArray<string>;\n\n  private _values: string[];\n  private _formControlName: string;\n  private _formArrayName: string;\n  private _onDisabledChange;\n  private _subs = new Subscription();\n  private _resizeObserver: ResizeObserver;\n  private _onChange: any = () => {};\n  private _onTouch: any = () => {};\n\n  get hasHint(): boolean {\n    return this.config.hint && this.config.hint.i18n && !this.config.hint.disabled;\n  }\n\n  constructor(\n    private readonly hostRef: ElementRef<HTMLElement>,\n    private readonly multiInputService: QdMultiInputService,\n    private readonly changeDetectorRef: ChangeDetectorRef,\n    private readonly actionEmitterService: QdFormsActionEmitterService,\n    private readonly qdFormArrayFactoryService: QdFormArrayFactoryService,\n    @Optional() @Host() @SkipSelf() private readonly controlContainer: ControlContainer,\n    @Optional() private readonly eventBrokerService: QdEventBrokerService\n  ) {\n    if (!this.id) this.id = uuid();\n\n    this.multiInputService.optionsListForView$.pipe(takeUntilDestroyed()).subscribe(list => {\n      this.optionsListForView = list;\n    });\n  }\n\n  ngOnInit(): void {\n    this.updateConfiguration();\n\n    this.multiInputService.setOptionsList(this.options);\n    this.multiInputService.setSelectedItems(this.values);\n\n    this._subs.add(this.actionEmitterService.hintEventEmitter$.subscribe(() => this.clickHint.emit()));\n    this._subs.add(this.actionEmitterService.readonlyEventEmitter$.subscribe(() => this.clickReadonly.emit()));\n    this._subs.add(this.actionEmitterService.viewonlyEventEmitter$.subscribe(() => this.clickViewonly.emit()));\n    this._subs.add(this.initOpModeSubscription());\n\n    if (!this.controlContainer) return;\n\n    if (this.formArrayName) {\n      const formArray = this.controlContainer.control.get(this.formArrayName);\n\n      // Updating form array programmatically from outside\n      this._subs.add(\n        formArray.valueChanges.subscribe(() => {\n          this.multiInputService.setSelectedItems(this.formArray.value);\n          this.valuesChange.emit(this.formArray.value);\n        })\n      );\n\n      if (formArray instanceof QdFormArray) {\n        this.formArray = formArray;\n        this.multiInputService.setSelectedItems(this.formArray.value);\n      } else {\n        // TODO remove logic for support of Angular FormControl with angular 19 update\n        this.formArray = this.qdFormArrayFactoryService.createQdFormArrayFromFormControl(\n          formArray as UntypedFormControl\n        );\n        console.warn('QD-UI | QdMultiInputComponent - Please use the MultiInput with the QdFormArray form control!');\n      }\n      this.disabled = formArray.disabled;\n      this._onDisabledChange = (disabled): void => {\n        this.disabled = disabled;\n      };\n      this.formArray.registerOnDisabledChange(this._onDisabledChange);\n    } else {\n      console.warn(\n        'QD-UI | QdMultiInputComponent - Missing [formArrayName] directive from host element of the component'\n      );\n    }\n  }\n\n  ngOnChanges(changes): void {\n    if (changes.config) {\n      this.updateConfiguration();\n      if (this.haveOptionsChanged(changes)) {\n        this.multiInputService.setOptionsList(this.options);\n      }\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.clickOutside = (): void => {};\n    this._subs?.unsubscribe();\n    this._resizeObserver?.disconnect();\n\n    if (this.formArray && this._onDisabledChange) this.formArray._unregisterOnDisabledChange(this._onDisabledChange);\n  }\n\n  registerOnChange(fn: (_: any) => void): void {\n    this._onChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this._onTouch = fn;\n  }\n\n  writeValue(values: string[]): void {\n    if (!this.controlContainer) this.getItems();\n\n    this.values = values;\n    this.valuesChange.emit(this.values);\n  }\n\n  getItems(): QdMultiInputOption[] {\n    return this.multiInputService.getItems();\n  }\n\n  hasItems(): boolean {\n    return this.multiInputService.getItems().length > 0;\n  }\n\n  getTranslation(option: QdMultiInputOption): string {\n    return this.multiInputService.getTranslation(option);\n  }\n\n  openPopover(): void {\n    if (this.readonly || this.viewonly || this.disabled || this.options.length === 0) return;\n\n    this.popoverOnClickDirective?.open();\n  }\n\n  closePopover(): void {\n    if (this.readonly || this.viewonly || this.disabled) return;\n\n    this.popoverOnClickDirective?.close();\n  }\n\n  handleClick(option: QdMultiInputOption): void {\n    if (!option.disabled) {\n      this.addItem(option);\n      this.closePopover();\n    }\n\n    this.focus();\n  }\n\n  handleBlur(): void {\n    this.hasFocus = false;\n  }\n\n  onKeyDown(event: KeyboardEvent): void {\n    switch (event.key) {\n      case 'Enter': {\n        const newOption = this.multiInputMenu?.keyManager?.activeItem?.option;\n        if (newOption?.disabled) return;\n        const option = this.optionsListForView.find(s => s.value === newOption?.value) || undefined;\n        this.addChip(option);\n        this.openPopover();\n        break;\n      }\n      case 'Escape':\n        this.closePopover();\n        this.blur();\n        break;\n\n      case 'ArrowUp':\n        this.openPopover();\n        this.multiInputMenu?.handleArrowKey('up', event);\n        break;\n\n      case 'ArrowDown':\n        this.openPopover();\n        this.multiInputMenu?.handleArrowKey('down', event);\n        break;\n\n      default:\n        this.openPopover();\n    }\n  }\n\n  changeValue(): void {\n    this.multiInputService.setCurrentInput(this.filterOptions);\n    this.openPopover();\n    this.multiInputMenu?.resetCheckedOption();\n    this.changeDetectorRef.detectChanges();\n  }\n\n  close(index): void {\n    if (this.formArray) {\n      this.formArray.removeAt(index);\n      this.formArray.markAsTouched();\n      return;\n    }\n\n    this.multiInputService.removeItemAtIndex(index);\n    this.writeValue(this.multiInputService.getItemValues());\n    this.focus();\n  }\n\n  getIterableElements(): NgIterable<any> {\n    return this.getItemsArray();\n  }\n\n  getValues(): QdMultiInputOption[] {\n    const values = this.getItemsArray().map(i => this.multiInputService.findOption(i.value));\n    return values;\n  }\n\n  handleChipClick($event): void {\n    $event.stopPropagation();\n    this.focus();\n    if (this.readonlyAction) this.handleReadOnlyAction($event);\n    if (this.viewonlyAction) this.handleViewOnlyAction($event);\n  }\n\n  handleReadOnlyAction($event): void {\n    this.clickReadonly.emit($event.target.dataset.value);\n  }\n\n  handleViewOnlyAction($event): void {\n    this.clickViewonly.emit($event.target.dataset.value);\n  }\n\n  focus(): void {\n    this.inputField?.nativeElement.focus();\n  }\n\n  private updateConfiguration(): void {\n    this.label = getLabel(this.config);\n    this.readonly = getReadonly(this.config, this.readonly);\n    this.viewonly = getViewonly(this.config, this.viewonly);\n    this.hintAction = getHintAction(this.config);\n    this.readonlyAction = getReadonlyAction(this.config);\n    this.viewonlyAction = getViewonlyAction(this.config);\n    this.disabled = getDisabled(this.config) || !!this.formArray?.disabled;\n    this.options = getMultiInputOptions(this.config);\n  }\n\n  private addChip(option?: QdMultiInputOption): void {\n    if (!option || !this.optionsListForView.map(options => options.value).includes(option.value)) {\n      if (this.inputField.nativeElement.value === '') return;\n\n      this.handleUserInput();\n    } else {\n      this.addItem(option);\n    }\n  }\n\n  private handleUserInput(): void {\n    const items: QdMultiInputOption[] = [];\n    if (this.filterOptions !== '' && !this.config.disableFreetext) {\n      const optionIndex = this.findOptionIndex(this.filterOptions);\n      if (optionIndex === -1) {\n        items.push(...this.getSplitOptions());\n      } else {\n        items.push(this.optionsListForView[optionIndex]);\n      }\n      this.addItemsToChipSet(items);\n    }\n  }\n\n  private addItemsToChipSet(items: QdMultiInputOption[]): void {\n    if (this.formArray) {\n      items.forEach(item => {\n        this.formArray.push(item.value);\n        this.multiInputService.addSelectedItem(item);\n      });\n      this.filterOptions = '';\n      this.changeValue();\n      this.formArray.markAsTouched();\n    } else {\n      items.forEach(item => this.addItem(item));\n    }\n  }\n\n  private getSplitOptions(): QdMultiInputOption[] {\n    return this.multiInputService.splitFilterOptions(this.filterOptions, this.config.inputSplitters);\n  }\n\n  private findOptionIndex(optionName: string): number {\n    return this.optionsListForView.findIndex(option => this.getTranslation(option) === optionName);\n  }\n\n  private addItem(option: QdMultiInputOption): void {\n    this.filterOptions = '';\n\n    if (this.formArray) {\n      this.formArray.push(option.value);\n      this.formArray.markAsTouched();\n      return;\n    }\n\n    this.multiInputService.addSelectedItem(option);\n    this.changeValue();\n    this.writeValue(this.multiInputService.getItemValues());\n  }\n\n  private haveOptionsChanged(changes): boolean {\n    return !isEqual(changes.config.previousValue?.options, changes.config.currentValue?.options);\n  }\n\n  private blur(): void {\n    this.inputField?.nativeElement.blur();\n  }\n\n  private getItemsArray(): (FormControl | QdMultiInputOption)[] {\n    return this.formArray ? (this.formArray.controls as FormControl[]) : this.getItems();\n  }\n\n  private initOpModeSubscription(): Subscription | void {\n    if (!this.eventBrokerService) return;\n\n    return this.eventBrokerService.consume<{ isViewonly: boolean }>('operation_mode_changed').subscribe(topic => {\n      if (typeof this.config.viewonly === 'boolean') return;\n\n      this.viewonly = getViewonly(this.config, topic.payload.isViewonly);\n    });\n  }\n}\n","<qd-form-label\n  [label]=\"label\"\n  [readonly]=\"readonly\"\n  [viewonly]=\"viewonly\"\n  [control]=\"formArray\"\n  [tooltip]=\"config?.tooltip\"\n  [data-test-id]=\"testId\"\n></qd-form-label>\n\n<div\n  *ngIf=\"!readonly && !viewonly\"\n  class=\"qd-multi-input__input-chip-box\"\n  (click)=\"focus()\"\n  (opened)=\"open = true\"\n  (closed)=\"open = false\"\n  [qdPopoverOnClick]=\"menu\"\n  [qdPopoverCloseStrategy]=\"'onOutsideClick'\"\n  [qdPopoverDisabled]=\"options.length === 0\"\n  [qdPopoverAutoSize]=\"{ width: true }\"\n  [qdPopoverBackgroundColor]=\"'transparent'\"\n  [positionStrategy]=\"[\n    {\n      originX: 'start',\n      originY: 'bottom',\n      overlayX: 'start',\n      overlayY: 'top',\n      offsetX: -2\n    },\n    {\n      originX: 'start',\n      originY: 'top',\n      overlayX: 'start',\n      overlayY: 'bottom',\n      weight: 0.8,\n      offsetX: -2\n    }\n  ]\"\n>\n  <div [ngClass]=\"hasItems() ? 'qd-multi-input__chip-margin' : ''\">\n    <qd-multi-input-chip\n      *ngFor=\"let element of getIterableElements(); let index = index\"\n      [close]=\"!disabled && !readonly && !viewonly\"\n      [itemControl]=\"formArray ? element : undefined\"\n      [value]=\"formArray ? undefined : getTranslation(element)\"\n      (closeClickEmitter)=\"close(index)\"\n      (click)=\"handleChipClick($event)\"\n    >\n    </qd-multi-input-chip>\n  </div>\n\n  <div class=\"qd-multi-input__wrapper\">\n    <input\n      #input\n      type=\"text\"\n      class=\"qd-multi-input__box\"\n      *ngIf=\"!readonly && !viewonly\"\n      [disabled]=\"disabled\"\n      [(ngModel)]=\"filterOptions\"\n      (ngModelChange)=\"changeValue()\"\n      (keydown)=\"onKeyDown($event)\"\n      (focus)=\"hasFocus = true\"\n      (blur)=\"handleBlur()\"\n      [ngClass]=\"open ? 'qd-multi-input__box--open' : ''\"\n      [attr.data-test-id]=\"testId + '-input'\"\n    />\n\n    <div class=\"qd-multi-input__box qd-multi-input__box--readonly\" *ngIf=\"readonly && !hasItems()\">&nbsp;</div>\n\n    <div class=\"qd-multi-input__box qd-multi-input__box--viewonly\" *ngIf=\"viewonly && !hasItems()\">&nbsp;</div>\n\n    <ng-template #menu>\n      <qd-multi-input-menu\n        [optionsListForView]=\"optionsListForView\"\n        [id]=\"id\"\n        [data-test-id]=\"testId\"\n        (itemClick)=\"handleClick($event)\"\n      ></qd-multi-input-menu>\n    </ng-template>\n  </div>\n</div>\n\n<ng-container *ngIf=\"config && !readonly && !viewonly\">\n  <qd-form-hint\n    [hint]=\"hasHint ? config.hint.i18n : ''\"\n    [control]=\"formArray\"\n    [hasError]=\"hasError\"\n    [hintAction]=\"hintAction\"\n    [data-test-id]=\"testId\"\n  ></qd-form-hint>\n</ng-container>\n\n<qd-form-readonly\n  *ngIf=\"readonly\"\n  [values]=\"getValues()\"\n  [readonlyAction]=\"readonlyAction\"\n  [data-test-id]=\"testId\"\n></qd-form-readonly>\n\n<qd-form-viewonly\n  *ngIf=\"viewonly\"\n  [values]=\"getValues()\"\n  [viewonlyAction]=\"viewonlyAction\"\n  [data-test-id]=\"testId\"\n></qd-form-viewonly>\n"]}
@@ -10639,11 +10639,8 @@ class QdCalendarComponent {
10639
10639
  this.weeks = Array.from({ length: Math.ceil(dates.length / 7) }, () => dates.splice(0, 7));
10640
10640
  }
10641
10641
  fillDates(momentObj) {
10642
- const firstOfMonth = moment(momentObj).startOf('month').day();
10643
10642
  const lastOfMonth = moment(momentObj).endOf('month').day();
10644
- const firstDayOfGrid = moment(momentObj)
10645
- .startOf('month')
10646
- .subtract(firstOfMonth === 0 ? 6 : firstOfMonth - 1, 'days');
10643
+ const firstDayOfGrid = moment(momentObj).locale(this.language).startOf('month').startOf('week');
10647
10644
  const lastDayOfGrid = moment(momentObj).endOf('month').subtract(lastOfMonth, 'days').add(7, 'days');
10648
10645
  const startCalendar = firstDayOfGrid.date();
10649
10646
  return range(startCalendar, startCalendar + lastDayOfGrid.diff(firstDayOfGrid, 'days')).map(date => {
@@ -14747,13 +14744,13 @@ class QdMultiInputComponent {
14747
14744
  return this.optionsListForView.findIndex(option => this.getTranslation(option) === optionName);
14748
14745
  }
14749
14746
  addItem(option) {
14747
+ this.filterOptions = '';
14750
14748
  if (this.formArray) {
14751
14749
  this.formArray.push(option.value);
14752
14750
  this.formArray.markAsTouched();
14753
14751
  return;
14754
14752
  }
14755
14753
  this.multiInputService.addSelectedItem(option);
14756
- this.filterOptions = '';
14757
14754
  this.changeValue();
14758
14755
  this.writeValue(this.multiInputService.getItemValues());
14759
14756
  }