@quadrel-enterprise-ui/framework 18.25.0 → 18.25.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.
- package/esm2022/lib/forms/datepicker/calendar/calendar.component.mjs +11 -6
- package/esm2022/lib/forms/input/input.component.mjs +18 -9
- package/fesm2022/quadrel-enterprise-ui-framework.mjs +27 -13
- package/fesm2022/quadrel-enterprise-ui-framework.mjs.map +1 -1
- package/lib/forms/datepicker/calendar/calendar.component.d.ts +1 -0
- package/lib/forms/input/input.component.d.ts +1 -0
- package/package.json +1 -1
|
@@ -43,7 +43,7 @@ export class QdCalendarComponent {
|
|
|
43
43
|
QdCalendarMode = QdCalendarMode;
|
|
44
44
|
ngOnInit() {
|
|
45
45
|
moment.locale(this.language);
|
|
46
|
-
this.
|
|
46
|
+
this.setWeekdays();
|
|
47
47
|
this.todayDate = moment();
|
|
48
48
|
this.months = moment.months();
|
|
49
49
|
this.years = this.getYears((QdDateAdapter.parseToMoment(this.selectedDate)?.isValid()
|
|
@@ -53,8 +53,10 @@ export class QdCalendarComponent {
|
|
|
53
53
|
this.generateCalendar(this.currentDate);
|
|
54
54
|
}
|
|
55
55
|
ngOnChanges(changes) {
|
|
56
|
-
if (changes['language'])
|
|
56
|
+
if (changes['language']) {
|
|
57
57
|
moment.locale(this.language);
|
|
58
|
+
this.setWeekdays();
|
|
59
|
+
}
|
|
58
60
|
if (changes['disabledDates'] && !changes['disabledDates'].isFirstChange())
|
|
59
61
|
this.generateCalendar(this.currentDate);
|
|
60
62
|
}
|
|
@@ -118,9 +120,8 @@ export class QdCalendarComponent {
|
|
|
118
120
|
this.weeks = Array.from({ length: Math.ceil(dates.length / 7) }, () => dates.splice(0, 7));
|
|
119
121
|
}
|
|
120
122
|
fillDates(momentObj) {
|
|
121
|
-
const
|
|
122
|
-
const
|
|
123
|
-
const lastDayOfGrid = moment(momentObj).endOf('month').subtract(lastOfMonth, 'days').add(7, 'days');
|
|
123
|
+
const firstDayOfGrid = moment(momentObj).locale(this.language).startOf('month').startOf('isoWeek');
|
|
124
|
+
const lastDayOfGrid = moment(momentObj).endOf('month').endOf('isoWeek').add(1, 'day');
|
|
124
125
|
const startCalendar = firstDayOfGrid.date();
|
|
125
126
|
return range(startCalendar, startCalendar + lastDayOfGrid.diff(firstDayOfGrid, 'days')).map(date => {
|
|
126
127
|
const newDate = moment(firstDayOfGrid).date(date);
|
|
@@ -165,6 +166,10 @@ export class QdCalendarComponent {
|
|
|
165
166
|
return date.isAfter(fromDate, 'day') && date.isBefore(toDate, 'day');
|
|
166
167
|
});
|
|
167
168
|
}
|
|
169
|
+
setWeekdays() {
|
|
170
|
+
const w = moment.localeData(this.language).weekdaysMin();
|
|
171
|
+
this.weekdays = w.slice(1).concat(w[0]);
|
|
172
|
+
}
|
|
168
173
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: QdCalendarComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
169
174
|
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", type: QdCalendarComponent, selector: "qd-calendar", inputs: { selectedDate: "selectedDate", language: "language", disabledDates: "disabledDates" }, outputs: { selectedChange: "selectedChange" }, usesOnChanges: true, ngImport: i0, template: "<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", styles: [".nav{color:#171717;font-size:1rem;font-weight:700;line-height:1.5rem;display:grid;margin:.75rem;grid-template-columns:[next] 2rem [monthyear] auto [prev] 2rem [end];text-transform:capitalize}.nav span{line-height:2.5rem;text-align:center}.nav .current-month-year,.nav .current-years-list,.nav .current-year{cursor:pointer}tbody{display:inherit;margin:.75rem}td{color:#171717;font-size:.875rem;font-weight:400;line-height:1.3125rem;min-width:2.5625rem;padding:.4375rem;text-align:center;text-transform:capitalize}td.disabled{color:#d5d5d5;pointer-events:none}td.hidden{opacity:0;pointer-events:none}td.today{box-shadow:0 0 0 .125rem #d5d5d5 inset}td.selected,td.day:hover{background:#d5d5d5;cursor:pointer}.picker{display:flex;width:100%;flex-wrap:wrap;padding:.75rem}.picker .col{flex:0 0 33.33%;padding:.5rem .25rem}.picker .entry{padding:.4375rem;background:#d5d5d5;cursor:pointer;text-align:center}.picker .entry.selected,.picker .entry:hover{background:gray}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.QdIconComponent, selector: "qd-icon", inputs: ["icon"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
170
175
|
}
|
|
@@ -180,4 +185,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImpor
|
|
|
180
185
|
}], selectedChange: [{
|
|
181
186
|
type: Output
|
|
182
187
|
}] } });
|
|
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"]}
|
|
188
|
+
//# 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.setWeekdays();\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']) {\n      moment.locale(this.language);\n      this.setWeekdays();\n    }\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 firstDayOfGrid = moment(momentObj).locale(this.language).startOf('month').startOf('isoWeek');\n    const lastDayOfGrid = moment(momentObj).endOf('month').endOf('isoWeek').add(1, 'day');\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  private setWeekdays(): void {\n    const w = moment.localeData(this.language).weekdaysMin();\n\n    this.weekdays = w.slice(1).concat(w[0]);\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"]}
|
|
@@ -359,21 +359,23 @@ export class QdInputComponent {
|
|
|
359
359
|
if (this.controlContainer) {
|
|
360
360
|
if (this.formControlName) {
|
|
361
361
|
this.control = this.controlContainer.control.get(this.formControlName);
|
|
362
|
-
// TODO remove logic for support of angular FormControl with angular
|
|
363
|
-
if (!(this.control instanceof QdFormControl))
|
|
362
|
+
// TODO remove logic for support of angular FormControl with angular 20 update
|
|
363
|
+
if (!(this.control instanceof QdFormControl))
|
|
364
364
|
console.warn('QD-UI | QdInputComponent - Please use the QdFormControl instead of the Angular FormControl');
|
|
365
|
-
}
|
|
366
365
|
}
|
|
367
366
|
}
|
|
368
367
|
this.writeValue(this.value || getValue(this.config));
|
|
368
|
+
this.normalizeInitialControlValueIfNeeded();
|
|
369
369
|
this._subs.add(this.actionEmitterService.hintEventEmitter$.subscribe(() => this.clickHint.emit()));
|
|
370
370
|
this._subs.add(this.actionEmitterService.readonlyEventEmitter$.subscribe(() => this.clickReadonly.emit()));
|
|
371
371
|
this._subs.add(this.actionEmitterService.viewonlyEventEmitter$.subscribe(() => this.clickViewonly.emit()));
|
|
372
372
|
this._subs.add(this.initOpModeSubscription());
|
|
373
373
|
}
|
|
374
374
|
ngOnChanges(changes) {
|
|
375
|
-
if (changes['config'])
|
|
375
|
+
if (changes['config']) {
|
|
376
376
|
this.updateConfig();
|
|
377
|
+
this.normalizeInitialControlValueIfNeeded();
|
|
378
|
+
}
|
|
377
379
|
if (changes['value'])
|
|
378
380
|
this.writeValue(this.value);
|
|
379
381
|
}
|
|
@@ -382,18 +384,15 @@ export class QdInputComponent {
|
|
|
382
384
|
}
|
|
383
385
|
registerOnChange(fn) {
|
|
384
386
|
const fnString = fn.toString();
|
|
385
|
-
if (fnString.includes('_noControlError') || fnString.includes('validateControlPresenceOnChange'))
|
|
387
|
+
if (fnString.includes('_noControlError') || fnString.includes('validateControlPresenceOnChange'))
|
|
386
388
|
return;
|
|
387
|
-
}
|
|
388
389
|
this._onChange = fn;
|
|
389
|
-
fn(this.hasUnits ? this._value : this._value.value);
|
|
390
390
|
}
|
|
391
391
|
registerOnTouched(fn) {
|
|
392
392
|
this._onTouch = fn;
|
|
393
393
|
}
|
|
394
394
|
writeValue(value) {
|
|
395
395
|
this._value = getValueWithUnit(value, this.config);
|
|
396
|
-
this._onChange(this.hasUnits ? this._value : this._value.value);
|
|
397
396
|
}
|
|
398
397
|
setDisabledState(disabled) {
|
|
399
398
|
this.disabled = disabled;
|
|
@@ -493,6 +492,16 @@ export class QdInputComponent {
|
|
|
493
492
|
this.viewonly = getViewonly(this.config, topic.payload.isViewonly);
|
|
494
493
|
});
|
|
495
494
|
}
|
|
495
|
+
normalizeInitialControlValueIfNeeded() {
|
|
496
|
+
if (!this.control)
|
|
497
|
+
return;
|
|
498
|
+
const modelValue = this.control.value;
|
|
499
|
+
const normalized = getValueWithUnit(modelValue, this.config);
|
|
500
|
+
const target = this.hasUnits ? normalized : normalized.value;
|
|
501
|
+
if (!isEqual(modelValue, target))
|
|
502
|
+
this.control.setValue(target, { emitEvent: false });
|
|
503
|
+
this._value = normalized;
|
|
504
|
+
}
|
|
496
505
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: QdInputComponent, deps: [{ token: i1.QdFormsActionEmitterService }, { token: i2.QdFormOptionsResolverRegistry }, { token: i3.ControlContainer, host: true, optional: true, skipSelf: true }, { token: i4.QdEventBrokerService, optional: true }], target: i0.ɵɵFactoryTarget.Component });
|
|
497
506
|
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", type: QdInputComponent, selector: "qd-input", inputs: { formControlName: "formControlName", value: "value", config: "config", isError: "isError", testId: ["data-test-id", "testId"] }, outputs: { valueChange: "valueChange", enterClick: "enterClick", clickClear: "clickClear", clickHint: "clickHint", clickReadonly: "clickReadonly", clickViewonly: "clickViewonly" }, host: { properties: { "class.qd-input-readonly": "this.readonly", "class.qd-input--readonly-action": "this.readonlyAction", "class.qd-input-viewonly": "this.viewonly", "class.qd-input--viewonly-action": "this.viewonlyAction", "class.qd-form-hint-action": "this.hintAction", "class.qd-input-hint-action": "this.hintAction", "class.qd-form-disabled": "this.disabled", "class.qd-input-disabled": "this.disabled", "class.qd-input-focus": "this.isInputFocused", "class.qd-form-error": "this.hasError", "class.qd-input-error": "this.hasError", "class.qd-input-error-from-outside": "this.isErrorFromOutside" } }, providers: [
|
|
498
507
|
{
|
|
@@ -598,4 +607,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImpor
|
|
|
598
607
|
type: ViewChild,
|
|
599
608
|
args: ['input']
|
|
600
609
|
}] } });
|
|
601
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input.component.js","sourceRoot":"","sources":["../../../../../../libs/qd-ui/src/lib/forms/input/input.component.ts","../../../../../../libs/qd-ui/src/lib/forms/input/input.component.html"],"names":[],"mappings":"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","sourcesContent":["// @ts-strict-ignore\nimport {\n  Component,\n  ElementRef,\n  EventEmitter,\n  Host,\n  HostBinding,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  SimpleChanges,\n  SkipSelf,\n  ViewChild\n} from '@angular/core';\nimport { AbstractControl, ControlContainer, ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { isEqual } from 'lodash';\nimport { Subscription } from 'rxjs';\n\nimport { QdFocusable } from '../../core/focusable/focusable';\nimport { QD_FOCUSABLE_TOKEN } from '../../core/focusable/focusable.token';\nimport { QdEventBrokerService } from '../../core/services/event-broker.service';\nimport { getValueWithUnit } from './helpers/get-value-with-unit';\n\nimport { QdPopoverSizingService } from '../../core/popover/popover-sizing.service';\nimport { QdFormOptionsResolver } from '../model/form-options-resolver';\nimport {\n  QdFormInputConfiguration,\n  QdInputMode,\n  QdInputType,\n  QdInputValue,\n  QdInputValueWithUnit\n} from '../model/forms.interface';\nimport { QdFormInputOption } from '../model/options.interface';\nimport { QdFormControl } from '../reactive-forms/controls/form-control';\nimport {\n  getClearable,\n  getDisabled,\n  getHasAutofocus,\n  getHint,\n  getHintAction,\n  getInputMode,\n  getInputType,\n  getLabel,\n  getPlaceholder,\n  getReadonly,\n  getReadonlyAction,\n  getValue,\n  getViewonly,\n  getViewonlyAction\n} from '../shared/helpers/forms.helpers';\nimport { QdFormsActionEmitterService } from '../shared/services/action-emitter.service';\nimport { QdFormOptionsResolverRegistry } from '../shared/services/options-resolver.registry';\n\n/**\n * The **QdInput** component provides a FormElement for entering text into a UI.<br />\n * It 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 *   input: new QdFormControl()\n * });\n * ```\n * ```html\n * <form [formGroup]=\"form\">\n *   <qd-input [formControlName]=\"input\" [config]=\"config\"></qd-input>\n * </form>\n * ```\n *\n * ### **Usage with Model Binding**\n * ```ts\n * value;\n * ```\n * ```html\n * <qd-input [(value)]=\"value\" [config]=\"config\"></qd-input>\n * ```\n *\n * ## **Suggested Options**\n *\n * ### **Static options by config**\n *\n * Static options can be defined in the config `options` field:\n *\n * ```ts\n * config: QdFormInputConfiguration = {\n *   ...\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', disabled: true }\n *   ]\n * }\n * ```\n * ```html\n * <qd-input [config]=\"config\"></qd-input>\n * ```\n *\n * <Story id=\"components-grid-system-container--columns-6\" />\n *\n * ### **Dynamic options by resolver**\n *\n * If you want to define the options dynamically, you can inject a `QdFormOptionsResolver`\n * with the `QD_FORM_OPTIONS_RESOLVER` injection token. The resolver just has to implement the `resolver`\n * method.\n *\n * ```ts\n * @Injectable()\n * export class YourFormOptionsResolver implements QdFormOptionsResolver {\n *   constructor(private readonly httpClient: HttpClient) {}\n *\n *   resolve(value: string): Observable<QdFormInput[]> {\n *     return this.httpClient\n *       .get(yourBackendUrl)\n *       .pipe(\n *         catchError(error => {\n *           console.error('your error message');\n *\n *           return throwError(error);\n *         })\n *       );\n *   }\n * }\n * ```\n * The options resolver can be injected into a component that contains the `QdInput` or also into a parent\n * component. If you need dynamic options for the search in the section toolbar, you can inject\n * the resolver on a higher level, e.g. in the component that contains the section.\n *\n * ```ts\n * @Component({\n *   ...\n *   providers: [\n *     ...\n *     {\n *       provide: QD_FORM_OPTIONS_RESOLVER,\n *       useClass: YourFormOptionsResolver\n *     }\n *   ]\n * })\n * ```\n *\n * By default, the resolver is applied to every input that is inside the component that injects the resolver.\n * To disable the resolver for an input, you have to set the `optionsResolverName` property in the\n * input config to `null`. It's also possible to define a `name` for the resolver by setting the `name` property\n * in the resolver class. Thus, you can connect the input to a specific resolver. Below there is also a\n * description of how to use multiple inputs with different resolvers in one component.\n * <br><br>\n *\n * #### **Multiple inputs with suggested options**\n *\n * For multiple inputs with various resolvers in one component you can distinguish the resolvers by setting the\n * `name` as a property in the resolver class.\n *\n * ```ts\n * @Injectable()\n * export class FruitsFormOptionsResolver implements QdFormOptionsResolver {\n *   name = 'fruits';\n *   // ...\n * }\n * ```\n *\n * ```ts\n * @Injectable()\n * export class CountriesFormOptionsResolver implements QdFormOptionsResolver {\n *   name = 'countries';\n *   // ...\n * }\n * ```\n *\n * Then the input can be assigned to a resolver by setting the `optionsResolverName` property\n * in the input config.\n *\n * ```ts\n * config: QdFormInputConfiguration = {\n *   ...\n *   optionsResolverName: 'fruits'\n * }\n *\n * config2: QdFormInputConfiguration = {\n *   ...\n *   optionsResolverName: 'countries'\n * }\n * ```\n * ```html\n * <qd-input [config]=\"config\"></qd-input>\n * <qd-input [config]=\"config2\"></qd-input>\n * ```\n * To inject multiple resolvers in a component you can use the provider setting `multi: true`.\n *\n * ```ts\n * @Component({\n *   ...\n *   providers: [\n *     ...\n *     {\n *       provide: QD_FORM_OPTIONS_RESOLVER,\n *       useClass: FruitsFormOptionsResolver,\n *       multi: true\n *     },\n *     {\n *       provide: QD_FORM_OPTIONS_RESOLVER,\n *       useClass: CountriesFormOptionsResolver,\n *       multi: true\n *     }\n *   ]\n * })\n * ```\n *\n * #### **Custom loading and error hints**\n *\n * In the resolver you also can define custom loading and error hints with the properties `requestLoadingHint`\n * and `requestErrorHint`.\n *\n * ```ts\n * @Injectable()\n * export class YourFormOptionsResolver implements QdFormOptionsResolver {\n *   requestLoadingHint = { i18n: 'i18n.custom.options.loading' };\n *   requestErrorHint = { i18n: 'i18n.custom.options.error' };\n *\n *   // ...\n *\n *   resolve(value: string): Observable<QdFormInput[]> {\n *     // ...\n *   }\n * }\n * ```\n * You also can update the error hint directly in the resolve method to display a more specific error\n * message when an error occurs.\n *\n * ```ts\n * @Injectable()\n * export class YourFormOptionsResolver implements QdFormOptionsResolver {\n *   // ...\n *\n *   constructor(\n *     @Optional() @Inject(BACKEND_ERROR_CODES) private readonly backendErrorCodes\n *   ) {\n *     this.backendErrorCodes = this.backendErrorCodes || {};\n *   }\n *\n *   // ...\n *\n *   resolve(value: string): Observable<QdFormInput[]> {\n *     return this.httpClient\n *       .get(yourBackendUrl)\n *       .pipe(\n *         catchError((error: HttpErrorResponse) => {\n *           if (error.error?.errorCode && error.error.errorCode in this.backendErrorCodes)\n *             this.requestErrorHint = { i18n: 'ERROR.' + error.error.errorCode };\n *           return throwError(() => error);\n *         })\n *       );\n *   }\n * }\n * ```\n */\n@Component({\n  selector: 'qd-input',\n  templateUrl: './input.component.html',\n  styleUrls: ['./input.component.scss'],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: QdInputComponent,\n      multi: true\n    },\n    QdFormsActionEmitterService,\n    QdFormOptionsResolverRegistry,\n    // TODO: Remove when removing derived directive\n    QdPopoverSizingService,\n    {\n      provide: QD_FOCUSABLE_TOKEN,\n      useExisting: QdInputComponent\n    }\n  ]\n})\nexport class QdInputComponent implements OnInit, OnChanges, OnDestroy, ControlValueAccessor, QdFocusable {\n  /**\n   * The form control name can be assigned here if you want to use Reactive Forms.\n   */\n  @Input()\n  formControlName: string;\n\n  /**\n   * The current form item value, if you are working with Model Binding.\n   *\n   * @example\n   * <qd-input [(value)]=\"value\" [config]=\"config\"></qd-input>\n   */\n  @Input()\n  value;\n\n  /**\n   * The configuration for this form item\n   *\n   * @example\n   * {\n   *   label: { i18n: 'label' },\n   *   placeholder: { i18n: 'placeholder' },\n   *   hint: { i18n: 'hint' }\n   * };\n   */\n  @Input()\n  config: QdFormInputConfiguration;\n\n  /**\n   * Set component to \"error\" externally. No reactive forms required. Used for components within the Quadrel UI framework. This is done by a CSS class.\n   *\n   * @default false\n   */\n  @Input()\n  isError = false;\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')\n  testId = 'text-input';\n\n  /**\n   * Emits event when the value has changed.\n   * Optionally emits the current input value, including unit (if configured).\n   */\n  @Output()\n  readonly valueChange = new EventEmitter<QdInputValue | QdInputValueWithUnit | undefined>();\n\n  /**\n   * Emits event when the value has changed. Note: Emits on keyup (no longer on click, as before)!\n   * Optionally emits the current input value, including unit (if configured).\n   */\n  @Output()\n  readonly enterClick = new EventEmitter<QdInputValue | QdInputValueWithUnit | undefined>();\n\n  /**\n   * Emits event when the input field was lapped on click/tap on the x icon. <br />\n   * `QdFormInputConfiguration['clearable']` must be set to true for this.\n   */\n  @Output()\n  readonly clickClear = new EventEmitter();\n\n  /**\n   * Emits event when the hint is clicked/tapped. `hintAction` must be set to `true` for this.\n   */\n  @Output()\n  readonly clickHint = new EventEmitter();\n\n  /**\n   * Emits event when the readonly value is clicked/tapped. `clickReadonly ` must be set to `true` for this.\n   */\n  @Output()\n  readonly clickReadonly = new EventEmitter();\n\n  /**\n   * Emits event when the viewonly value is clicked/tapped. `clickViewonly ` must be set to `true` for this.\n   */\n  @Output()\n  readonly clickViewonly = new EventEmitter();\n\n  @HostBinding('class.qd-input-readonly')\n  readonly: boolean;\n\n  @HostBinding('class.qd-input--readonly-action')\n  readonlyAction = false;\n\n  @HostBinding('class.qd-input-viewonly')\n  viewonly: boolean;\n\n  @HostBinding('class.qd-input--viewonly-action')\n  viewonlyAction = false;\n\n  @HostBinding('class.qd-form-hint-action')\n  @HostBinding('class.qd-input-hint-action')\n  hintAction = false;\n\n  @HostBinding('class.qd-form-disabled')\n  @HostBinding('class.qd-input-disabled')\n  disabled: boolean;\n\n  @HostBinding('class.qd-input-focus')\n  isInputFocused = false;\n  areUnitsOpened = false;\n\n  @HostBinding('class.qd-form-error')\n  @HostBinding('class.qd-input-error')\n  get hasError(): boolean {\n    return this.control ? this.control.touched && this.control.invalid : false;\n  }\n\n  @HostBinding('class.qd-input-error-from-outside')\n  get isErrorFromOutside(): boolean {\n    return this.isError;\n  }\n\n  @ViewChild('input')\n  inputElement: ElementRef;\n\n  inputType: QdInputType;\n  inputMode: QdInputMode;\n  placeholder: string;\n  label: string;\n  hint: string;\n  clearable: boolean;\n  hasAutofocus: boolean;\n  hasOptions = false;\n  _value: QdInputValueWithUnit = { value: '' };\n  control: AbstractControl | QdFormControl<any>;\n\n  private _optionsResolver!: QdFormOptionsResolver | null;\n  private _subs = new Subscription();\n\n  private _onChange: any = () => {};\n  private _onTouch: any = () => {};\n\n  get hasOnlyUnitsError(): boolean {\n    return isEqual(Object.keys(this.control.errors), ['required']) && this._value.value !== '';\n  }\n\n  get hasUnits(): boolean {\n    return this.config?.units?.length > 0;\n  }\n\n  get numberOfCharacters(): number {\n    if (!this._value.value) return 0;\n\n    return String(this._value.value).length;\n  }\n\n  get hasMaxLength(): boolean {\n    if (!(this.control instanceof QdFormControl)) return false;\n\n    return this.control.hasMaxLength();\n  }\n\n  get maxLength(): number {\n    if (!(this.control instanceof QdFormControl)) return;\n\n    return this.control.getMaxLengthOrUndefined();\n  }\n\n  get valueAsList(): string[] {\n    return [`${this._value.value}${this._value.unit ? ' ' + this._value.unit : ''}`];\n  }\n\n  constructor(\n    private readonly actionEmitterService: QdFormsActionEmitterService,\n    private readonly resolverRegistry: QdFormOptionsResolverRegistry,\n    @Optional() @Host() @SkipSelf() private readonly controlContainer: ControlContainer,\n    @Optional() private readonly eventBrokerService: QdEventBrokerService\n  ) {}\n\n  ngOnInit(): void {\n    this.initializeOptionsResolver();\n    this.updateConfig();\n\n    if (this.controlContainer) {\n      if (this.formControlName) {\n        this.control = this.controlContainer.control.get(this.formControlName);\n\n        // TODO remove logic for support of angular FormControl with angular 18 update\n        if (!(this.control instanceof QdFormControl)) {\n          console.warn('QD-UI | QdInputComponent - Please use the QdFormControl instead of the Angular FormControl');\n        }\n      }\n    }\n\n    this.writeValue(this.value || getValue(this.config));\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\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['config']) this.updateConfig();\n    if (changes['value']) this.writeValue(this.value);\n  }\n\n  ngOnDestroy(): void {\n    this._subs.unsubscribe();\n  }\n\n  registerOnChange(fn: (_: any) => void): void {\n    const fnString = fn.toString();\n\n    if (fnString.includes('_noControlError') || fnString.includes('validateControlPresenceOnChange')) {\n      return;\n    }\n\n    this._onChange = fn;\n\n    fn(this.hasUnits ? this._value : this._value.value);\n  }\n\n  registerOnTouched(fn: any): void {\n    this._onTouch = fn;\n  }\n\n  writeValue(value: QdInputValueWithUnit | QdInputValue): void {\n    this._value = getValueWithUnit(value, this.config);\n\n    this._onChange(this.hasUnits ? this._value : this._value.value);\n  }\n\n  setDisabledState(disabled: boolean): void {\n    this.disabled = disabled;\n    this.clearable = getClearable(this.config) && !this.disabled;\n  }\n\n  handleInput(event): void {\n    const value = event.target.value;\n    this._value = { ...this._value, value };\n    this.emitValue();\n    this._onTouch();\n  }\n\n  handleOptionSelected(option: QdFormInputOption): void {\n    this._value = { ...this._value, value: option.i18n };\n    this.valueChange.emit(option.value);\n    this._onChange(option.value);\n    this._onTouch();\n  }\n\n  handleUnitChange(unit): void {\n    this._value = { ...this._value, unit };\n    this.emitValue();\n  }\n\n  handleInputFocus(): void {\n    this.isInputFocused = true;\n  }\n\n  handleInputBlur(): void {\n    this.isInputFocused = false;\n\n    setTimeout(() => {\n      if (!this.areUnitsOpened) this._onTouch();\n    }, 100);\n  }\n\n  handleUnitsOpened(): void {\n    this.areUnitsOpened = true;\n  }\n\n  handleUnitsClosed(): void {\n    this.areUnitsOpened = false;\n\n    if (this._value.unit && this._value.value === '') {\n      this.inputElement.nativeElement.focus();\n    } else {\n      this._onTouch();\n    }\n  }\n\n  clearInput(): void {\n    this._value = { ...this._value, value: '' };\n    this.inputElement.nativeElement.focus();\n\n    this.emitValue();\n    this.clickClear.emit();\n  }\n\n  focus(): void {\n    this.inputElement.nativeElement.focus();\n  }\n\n  emitEnterClick(): void {\n    if (this.hasUnits) {\n      this.enterClick.emit(this._value);\n    } else {\n      this.enterClick.emit(this._value.value);\n    }\n  }\n\n  private updateConfig(): void {\n    this.inputType = getInputType(this.config);\n    this.inputMode = getInputMode(this.config);\n    this.placeholder = getPlaceholder(this.config);\n    this.label = getLabel(this.config);\n    this.hint = getHint(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.control?.disabled;\n    this.clearable = !this.disabled && getClearable(this.config);\n    this.hasAutofocus = getHasAutofocus(this.config);\n    this.hasOptions = (this.config.options && this.config.options.length > 0) || !!this._optionsResolver;\n  }\n\n  private initializeOptionsResolver(): void {\n    this.resolverRegistry.initialize(this.config?.optionsResolverName);\n    this._optionsResolver = this.resolverRegistry.findResolver();\n  }\n\n  private emitValue(): void {\n    if (this.hasUnits) {\n      this.valueChange.emit(this._value);\n      this._onChange(this._value);\n    } else {\n      this.valueChange.emit(this._value.value);\n      this._onChange(this._value.value);\n    }\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]=\"control\"\n  [tooltip]=\"config?.tooltip\"\n  [data-test-id]=\"testId\"\n></qd-form-label>\n\n<ng-container *ngIf=\"!readonly && !viewonly && !hasOptions\">\n  <div class=\"qd-input-input\" (keydown.enter)=\"emitEnterClick()\">\n    <ng-container *ngTemplateOutlet=\"inputBox\"></ng-container>\n  </div>\n\n  <span class=\"qd-input-character-counter\" *ngIf=\"hasMaxLength\">{{ numberOfCharacters }} / {{ maxLength }}</span>\n\n  <qd-form-hint\n    [hint]=\"hint\"\n    [control]=\"control\"\n    [hasError]=\"hasError\"\n    [hintAction]=\"hintAction\"\n    [data-test-id]=\"testId\"\n  ></qd-form-hint>\n</ng-container>\n\n<div *ngIf=\"!readonly && !viewonly && hasOptions\">\n  <div\n    class=\"qd-input-input\"\n    qdInputOptions\n    [qdPopoverMinWidth]=\"200\"\n    [config]=\"config\"\n    [value]=\"_value.value\"\n    (optionSelected)=\"handleOptionSelected($event)\"\n    (enterClick)=\"emitEnterClick()\"\n  >\n    <!-- handle (enterClick) by options directive here because event has to be fired after selection -->\n    <ng-container *ngTemplateOutlet=\"inputBox\"></ng-container>\n  </div>\n\n  <span class=\"qd-input-character-counter\" *ngIf=\"hasMaxLength\">{{ numberOfCharacters }} / {{ maxLength }}</span>\n\n  <qd-form-hint\n    [hint]=\"hint\"\n    [control]=\"control\"\n    [hasError]=\"hasError\"\n    [hintAction]=\"hintAction\"\n    [data-test-id]=\"testId\"\n  ></qd-form-hint>\n</div>\n\n<qd-form-readonly\n  *ngIf=\"readonly\"\n  [values]=\"valueAsList\"\n  [readonlyAction]=\"readonlyAction\"\n  [data-test-id]=\"testId\"\n></qd-form-readonly>\n\n<qd-form-viewonly\n  *ngIf=\"viewonly\"\n  [values]=\"valueAsList\"\n  [viewonlyAction]=\"viewonlyAction\"\n  [data-test-id]=\"testId\"\n></qd-form-viewonly>\n\n<ng-template #inputBox>\n  <input\n    #input\n    [placeholder]=\"placeholder | translate\"\n    [value]=\"hasOptions ? (_value.value.toString() | translate) : _value.value\"\n    (input)=\"handleInput($event)\"\n    (focus)=\"handleInputFocus()\"\n    (blur)=\"handleInputBlur()\"\n    [disabled]=\"disabled || readonly\"\n    [type]=\"inputType\"\n    [attr.inputmode]=\"inputMode\"\n    [qdAutofocus]=\"hasAutofocus\"\n    [attr.data-test-id]=\"testId + '-input'\"\n    [step]=\"config?.step\"\n    required\n  />\n  <div class=\"qd-input-suffix\">\n    <qd-icon *ngIf=\"hasError && !hasOnlyUnitsError\" class=\"qd-input-error-icon\" icon=\"exclamationCircleSolid\"></qd-icon>\n    <qd-icon *ngIf=\"clearable\" class=\"qd-input-clearable-icon\" icon=\"timesLarge\" (click)=\"clearInput()\"></qd-icon>\n    <ng-content select=\"[qdIconButton]\"></ng-content>\n  </div>\n  <qd-input-units\n    *ngIf=\"hasUnits\"\n    [unit]=\"_value.unit\"\n    [config]=\"config\"\n    (unitChange)=\"handleUnitChange($event)\"\n    (opened)=\"handleUnitsOpened()\"\n    (closed)=\"handleUnitsClosed()\"\n  ></qd-input-units>\n  <div class=\"qd-input-suffix\" *ngIf=\"hasError && hasOnlyUnitsError\">\n    <qd-icon class=\"qd-input-error-icon\" icon=\"exclamationCircleSolid\"></qd-icon>\n  </div>\n</ng-template>\n"]}
|
|
610
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input.component.js","sourceRoot":"","sources":["../../../../../../libs/qd-ui/src/lib/forms/input/input.component.ts","../../../../../../libs/qd-ui/src/lib/forms/input/input.component.html"],"names":[],"mappings":"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","sourcesContent":["// @ts-strict-ignore\nimport {\n  Component,\n  ElementRef,\n  EventEmitter,\n  Host,\n  HostBinding,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  SimpleChanges,\n  SkipSelf,\n  ViewChild\n} from '@angular/core';\nimport { AbstractControl, ControlContainer, ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { isEqual } from 'lodash';\nimport { Subscription } from 'rxjs';\n\nimport { QdFocusable } from '../../core/focusable/focusable';\nimport { QD_FOCUSABLE_TOKEN } from '../../core/focusable/focusable.token';\nimport { QdEventBrokerService } from '../../core/services/event-broker.service';\nimport { getValueWithUnit } from './helpers/get-value-with-unit';\n\nimport { QdPopoverSizingService } from '../../core/popover/popover-sizing.service';\nimport { QdFormOptionsResolver } from '../model/form-options-resolver';\nimport {\n  QdFormInputConfiguration,\n  QdInputMode,\n  QdInputType,\n  QdInputValue,\n  QdInputValueWithUnit\n} from '../model/forms.interface';\nimport { QdFormInputOption } from '../model/options.interface';\nimport { QdFormControl } from '../reactive-forms/controls/form-control';\nimport {\n  getClearable,\n  getDisabled,\n  getHasAutofocus,\n  getHint,\n  getHintAction,\n  getInputMode,\n  getInputType,\n  getLabel,\n  getPlaceholder,\n  getReadonly,\n  getReadonlyAction,\n  getValue,\n  getViewonly,\n  getViewonlyAction\n} from '../shared/helpers/forms.helpers';\nimport { QdFormsActionEmitterService } from '../shared/services/action-emitter.service';\nimport { QdFormOptionsResolverRegistry } from '../shared/services/options-resolver.registry';\n\n/**\n * The **QdInput** component provides a FormElement for entering text into a UI.<br />\n * It 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 *   input: new QdFormControl()\n * });\n * ```\n * ```html\n * <form [formGroup]=\"form\">\n *   <qd-input [formControlName]=\"input\" [config]=\"config\"></qd-input>\n * </form>\n * ```\n *\n * ### **Usage with Model Binding**\n * ```ts\n * value;\n * ```\n * ```html\n * <qd-input [(value)]=\"value\" [config]=\"config\"></qd-input>\n * ```\n *\n * ## **Suggested Options**\n *\n * ### **Static options by config**\n *\n * Static options can be defined in the config `options` field:\n *\n * ```ts\n * config: QdFormInputConfiguration = {\n *   ...\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', disabled: true }\n *   ]\n * }\n * ```\n * ```html\n * <qd-input [config]=\"config\"></qd-input>\n * ```\n *\n * <Story id=\"components-grid-system-container--columns-6\" />\n *\n * ### **Dynamic options by resolver**\n *\n * If you want to define the options dynamically, you can inject a `QdFormOptionsResolver`\n * with the `QD_FORM_OPTIONS_RESOLVER` injection token. The resolver just has to implement the `resolver`\n * method.\n *\n * ```ts\n * @Injectable()\n * export class YourFormOptionsResolver implements QdFormOptionsResolver {\n *   constructor(private readonly httpClient: HttpClient) {}\n *\n *   resolve(value: string): Observable<QdFormInput[]> {\n *     return this.httpClient\n *       .get(yourBackendUrl)\n *       .pipe(\n *         catchError(error => {\n *           console.error('your error message');\n *\n *           return throwError(error);\n *         })\n *       );\n *   }\n * }\n * ```\n * The options resolver can be injected into a component that contains the `QdInput` or also into a parent\n * component. If you need dynamic options for the search in the section toolbar, you can inject\n * the resolver on a higher level, e.g. in the component that contains the section.\n *\n * ```ts\n * @Component({\n *   ...\n *   providers: [\n *     ...\n *     {\n *       provide: QD_FORM_OPTIONS_RESOLVER,\n *       useClass: YourFormOptionsResolver\n *     }\n *   ]\n * })\n * ```\n *\n * By default, the resolver is applied to every input that is inside the component that injects the resolver.\n * To disable the resolver for an input, you have to set the `optionsResolverName` property in the\n * input config to `null`. It's also possible to define a `name` for the resolver by setting the `name` property\n * in the resolver class. Thus, you can connect the input to a specific resolver. Below there is also a\n * description of how to use multiple inputs with different resolvers in one component.\n * <br><br>\n *\n * #### **Multiple inputs with suggested options**\n *\n * For multiple inputs with various resolvers in one component you can distinguish the resolvers by setting the\n * `name` as a property in the resolver class.\n *\n * ```ts\n * @Injectable()\n * export class FruitsFormOptionsResolver implements QdFormOptionsResolver {\n *   name = 'fruits';\n *   // ...\n * }\n * ```\n *\n * ```ts\n * @Injectable()\n * export class CountriesFormOptionsResolver implements QdFormOptionsResolver {\n *   name = 'countries';\n *   // ...\n * }\n * ```\n *\n * Then the input can be assigned to a resolver by setting the `optionsResolverName` property\n * in the input config.\n *\n * ```ts\n * config: QdFormInputConfiguration = {\n *   ...\n *   optionsResolverName: 'fruits'\n * }\n *\n * config2: QdFormInputConfiguration = {\n *   ...\n *   optionsResolverName: 'countries'\n * }\n * ```\n * ```html\n * <qd-input [config]=\"config\"></qd-input>\n * <qd-input [config]=\"config2\"></qd-input>\n * ```\n * To inject multiple resolvers in a component you can use the provider setting `multi: true`.\n *\n * ```ts\n * @Component({\n *   ...\n *   providers: [\n *     ...\n *     {\n *       provide: QD_FORM_OPTIONS_RESOLVER,\n *       useClass: FruitsFormOptionsResolver,\n *       multi: true\n *     },\n *     {\n *       provide: QD_FORM_OPTIONS_RESOLVER,\n *       useClass: CountriesFormOptionsResolver,\n *       multi: true\n *     }\n *   ]\n * })\n * ```\n *\n * #### **Custom loading and error hints**\n *\n * In the resolver you also can define custom loading and error hints with the properties `requestLoadingHint`\n * and `requestErrorHint`.\n *\n * ```ts\n * @Injectable()\n * export class YourFormOptionsResolver implements QdFormOptionsResolver {\n *   requestLoadingHint = { i18n: 'i18n.custom.options.loading' };\n *   requestErrorHint = { i18n: 'i18n.custom.options.error' };\n *\n *   // ...\n *\n *   resolve(value: string): Observable<QdFormInput[]> {\n *     // ...\n *   }\n * }\n * ```\n * You also can update the error hint directly in the resolve method to display a more specific error\n * message when an error occurs.\n *\n * ```ts\n * @Injectable()\n * export class YourFormOptionsResolver implements QdFormOptionsResolver {\n *   // ...\n *\n *   constructor(\n *     @Optional() @Inject(BACKEND_ERROR_CODES) private readonly backendErrorCodes\n *   ) {\n *     this.backendErrorCodes = this.backendErrorCodes || {};\n *   }\n *\n *   // ...\n *\n *   resolve(value: string): Observable<QdFormInput[]> {\n *     return this.httpClient\n *       .get(yourBackendUrl)\n *       .pipe(\n *         catchError((error: HttpErrorResponse) => {\n *           if (error.error?.errorCode && error.error.errorCode in this.backendErrorCodes)\n *             this.requestErrorHint = { i18n: 'ERROR.' + error.error.errorCode };\n *           return throwError(() => error);\n *         })\n *       );\n *   }\n * }\n * ```\n */\n@Component({\n  selector: 'qd-input',\n  templateUrl: './input.component.html',\n  styleUrls: ['./input.component.scss'],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: QdInputComponent,\n      multi: true\n    },\n    QdFormsActionEmitterService,\n    QdFormOptionsResolverRegistry,\n    // TODO: Remove when removing derived directive\n    QdPopoverSizingService,\n    {\n      provide: QD_FOCUSABLE_TOKEN,\n      useExisting: QdInputComponent\n    }\n  ]\n})\nexport class QdInputComponent implements OnInit, OnChanges, OnDestroy, ControlValueAccessor, QdFocusable {\n  /**\n   * The form control name can be assigned here if you want to use Reactive Forms.\n   */\n  @Input()\n  formControlName: string;\n\n  /**\n   * The current form item value, if you are working with Model Binding.\n   *\n   * @example\n   * <qd-input [(value)]=\"value\" [config]=\"config\"></qd-input>\n   */\n  @Input()\n  value;\n\n  /**\n   * The configuration for this form item\n   *\n   * @example\n   * {\n   *   label: { i18n: 'label' },\n   *   placeholder: { i18n: 'placeholder' },\n   *   hint: { i18n: 'hint' }\n   * };\n   */\n  @Input()\n  config: QdFormInputConfiguration;\n\n  /**\n   * Set component to \"error\" externally. No reactive forms required. Used for components within the Quadrel UI framework. This is done by a CSS class.\n   *\n   * @default false\n   */\n  @Input()\n  isError = false;\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')\n  testId = 'text-input';\n\n  /**\n   * Emits event when the value has changed.\n   * Optionally emits the current input value, including unit (if configured).\n   */\n  @Output()\n  readonly valueChange = new EventEmitter<QdInputValue | QdInputValueWithUnit | undefined>();\n\n  /**\n   * Emits event when the value has changed. Note: Emits on keyup (no longer on click, as before)!\n   * Optionally emits the current input value, including unit (if configured).\n   */\n  @Output()\n  readonly enterClick = new EventEmitter<QdInputValue | QdInputValueWithUnit | undefined>();\n\n  /**\n   * Emits event when the input field was lapped on click/tap on the x icon. <br />\n   * `QdFormInputConfiguration['clearable']` must be set to true for this.\n   */\n  @Output()\n  readonly clickClear = new EventEmitter();\n\n  /**\n   * Emits event when the hint is clicked/tapped. `hintAction` must be set to `true` for this.\n   */\n  @Output()\n  readonly clickHint = new EventEmitter();\n\n  /**\n   * Emits event when the readonly value is clicked/tapped. `clickReadonly ` must be set to `true` for this.\n   */\n  @Output()\n  readonly clickReadonly = new EventEmitter();\n\n  /**\n   * Emits event when the viewonly value is clicked/tapped. `clickViewonly ` must be set to `true` for this.\n   */\n  @Output()\n  readonly clickViewonly = new EventEmitter();\n\n  @HostBinding('class.qd-input-readonly')\n  readonly: boolean;\n\n  @HostBinding('class.qd-input--readonly-action')\n  readonlyAction = false;\n\n  @HostBinding('class.qd-input-viewonly')\n  viewonly: boolean;\n\n  @HostBinding('class.qd-input--viewonly-action')\n  viewonlyAction = false;\n\n  @HostBinding('class.qd-form-hint-action')\n  @HostBinding('class.qd-input-hint-action')\n  hintAction = false;\n\n  @HostBinding('class.qd-form-disabled')\n  @HostBinding('class.qd-input-disabled')\n  disabled: boolean;\n\n  @HostBinding('class.qd-input-focus')\n  isInputFocused = false;\n  areUnitsOpened = false;\n\n  @HostBinding('class.qd-form-error')\n  @HostBinding('class.qd-input-error')\n  get hasError(): boolean {\n    return this.control ? this.control.touched && this.control.invalid : false;\n  }\n\n  @HostBinding('class.qd-input-error-from-outside')\n  get isErrorFromOutside(): boolean {\n    return this.isError;\n  }\n\n  @ViewChild('input')\n  inputElement: ElementRef;\n\n  inputType: QdInputType;\n  inputMode: QdInputMode;\n  placeholder: string;\n  label: string;\n  hint: string;\n  clearable: boolean;\n  hasAutofocus: boolean;\n  hasOptions = false;\n  _value: QdInputValueWithUnit = { value: '' };\n  control: AbstractControl | QdFormControl<any>;\n\n  private _optionsResolver!: QdFormOptionsResolver | null;\n  private _subs = new Subscription();\n\n  private _onChange: any = () => {};\n  private _onTouch: any = () => {};\n\n  get hasOnlyUnitsError(): boolean {\n    return isEqual(Object.keys(this.control.errors), ['required']) && this._value.value !== '';\n  }\n\n  get hasUnits(): boolean {\n    return this.config?.units?.length > 0;\n  }\n\n  get numberOfCharacters(): number {\n    if (!this._value.value) return 0;\n\n    return String(this._value.value).length;\n  }\n\n  get hasMaxLength(): boolean {\n    if (!(this.control instanceof QdFormControl)) return false;\n\n    return this.control.hasMaxLength();\n  }\n\n  get maxLength(): number {\n    if (!(this.control instanceof QdFormControl)) return;\n\n    return this.control.getMaxLengthOrUndefined();\n  }\n\n  get valueAsList(): string[] {\n    return [`${this._value.value}${this._value.unit ? ' ' + this._value.unit : ''}`];\n  }\n\n  constructor(\n    private readonly actionEmitterService: QdFormsActionEmitterService,\n    private readonly resolverRegistry: QdFormOptionsResolverRegistry,\n    @Optional() @Host() @SkipSelf() private readonly controlContainer: ControlContainer,\n    @Optional() private readonly eventBrokerService: QdEventBrokerService\n  ) {}\n\n  ngOnInit(): void {\n    this.initializeOptionsResolver();\n    this.updateConfig();\n\n    if (this.controlContainer) {\n      if (this.formControlName) {\n        this.control = this.controlContainer.control.get(this.formControlName);\n\n        // TODO remove logic for support of angular FormControl with angular 20 update\n        if (!(this.control instanceof QdFormControl))\n          console.warn('QD-UI | QdInputComponent - Please use the QdFormControl instead of the Angular FormControl');\n      }\n    }\n\n    this.writeValue(this.value || getValue(this.config));\n\n    this.normalizeInitialControlValueIfNeeded();\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\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['config']) {\n      this.updateConfig();\n      this.normalizeInitialControlValueIfNeeded();\n    }\n\n    if (changes['value']) this.writeValue(this.value);\n  }\n\n  ngOnDestroy(): void {\n    this._subs.unsubscribe();\n  }\n\n  registerOnChange(fn: (_: any) => void): void {\n    const fnString = fn.toString();\n\n    if (fnString.includes('_noControlError') || fnString.includes('validateControlPresenceOnChange')) return;\n\n    this._onChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this._onTouch = fn;\n  }\n\n  writeValue(value: QdInputValueWithUnit | QdInputValue): void {\n    this._value = getValueWithUnit(value, this.config);\n  }\n\n  setDisabledState(disabled: boolean): void {\n    this.disabled = disabled;\n    this.clearable = getClearable(this.config) && !this.disabled;\n  }\n\n  handleInput(event): void {\n    const value = event.target.value;\n    this._value = { ...this._value, value };\n    this.emitValue();\n    this._onTouch();\n  }\n\n  handleOptionSelected(option: QdFormInputOption): void {\n    this._value = { ...this._value, value: option.i18n };\n    this.valueChange.emit(option.value);\n    this._onChange(option.value);\n    this._onTouch();\n  }\n\n  handleUnitChange(unit): void {\n    this._value = { ...this._value, unit };\n    this.emitValue();\n  }\n\n  handleInputFocus(): void {\n    this.isInputFocused = true;\n  }\n\n  handleInputBlur(): void {\n    this.isInputFocused = false;\n\n    setTimeout(() => {\n      if (!this.areUnitsOpened) this._onTouch();\n    }, 100);\n  }\n\n  handleUnitsOpened(): void {\n    this.areUnitsOpened = true;\n  }\n\n  handleUnitsClosed(): void {\n    this.areUnitsOpened = false;\n\n    if (this._value.unit && this._value.value === '') {\n      this.inputElement.nativeElement.focus();\n    } else {\n      this._onTouch();\n    }\n  }\n\n  clearInput(): void {\n    this._value = { ...this._value, value: '' };\n    this.inputElement.nativeElement.focus();\n\n    this.emitValue();\n    this.clickClear.emit();\n  }\n\n  focus(): void {\n    this.inputElement.nativeElement.focus();\n  }\n\n  emitEnterClick(): void {\n    if (this.hasUnits) {\n      this.enterClick.emit(this._value);\n    } else {\n      this.enterClick.emit(this._value.value);\n    }\n  }\n\n  private updateConfig(): void {\n    this.inputType = getInputType(this.config);\n    this.inputMode = getInputMode(this.config);\n    this.placeholder = getPlaceholder(this.config);\n    this.label = getLabel(this.config);\n    this.hint = getHint(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.control?.disabled;\n    this.clearable = !this.disabled && getClearable(this.config);\n    this.hasAutofocus = getHasAutofocus(this.config);\n    this.hasOptions = (this.config.options && this.config.options.length > 0) || !!this._optionsResolver;\n  }\n\n  private initializeOptionsResolver(): void {\n    this.resolverRegistry.initialize(this.config?.optionsResolverName);\n    this._optionsResolver = this.resolverRegistry.findResolver();\n  }\n\n  private emitValue(): void {\n    if (this.hasUnits) {\n      this.valueChange.emit(this._value);\n      this._onChange(this._value);\n    } else {\n      this.valueChange.emit(this._value.value);\n      this._onChange(this._value.value);\n    }\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  private normalizeInitialControlValueIfNeeded(): void {\n    if (!this.control) return;\n\n    const modelValue = (this.control as any).value;\n    const normalized = getValueWithUnit(modelValue, this.config);\n    const target = this.hasUnits ? normalized : normalized.value;\n\n    if (!isEqual(modelValue, target)) (this.control as any).setValue(target, { emitEvent: false });\n\n    this._value = normalized;\n  }\n}\n","<qd-form-label\n  [label]=\"label\"\n  [readonly]=\"readonly\"\n  [viewonly]=\"viewonly\"\n  [control]=\"control\"\n  [tooltip]=\"config?.tooltip\"\n  [data-test-id]=\"testId\"\n></qd-form-label>\n\n<ng-container *ngIf=\"!readonly && !viewonly && !hasOptions\">\n  <div class=\"qd-input-input\" (keydown.enter)=\"emitEnterClick()\">\n    <ng-container *ngTemplateOutlet=\"inputBox\"></ng-container>\n  </div>\n\n  <span class=\"qd-input-character-counter\" *ngIf=\"hasMaxLength\">{{ numberOfCharacters }} / {{ maxLength }}</span>\n\n  <qd-form-hint\n    [hint]=\"hint\"\n    [control]=\"control\"\n    [hasError]=\"hasError\"\n    [hintAction]=\"hintAction\"\n    [data-test-id]=\"testId\"\n  ></qd-form-hint>\n</ng-container>\n\n<div *ngIf=\"!readonly && !viewonly && hasOptions\">\n  <div\n    class=\"qd-input-input\"\n    qdInputOptions\n    [qdPopoverMinWidth]=\"200\"\n    [config]=\"config\"\n    [value]=\"_value.value\"\n    (optionSelected)=\"handleOptionSelected($event)\"\n    (enterClick)=\"emitEnterClick()\"\n  >\n    <!-- handle (enterClick) by options directive here because event has to be fired after selection -->\n    <ng-container *ngTemplateOutlet=\"inputBox\"></ng-container>\n  </div>\n\n  <span class=\"qd-input-character-counter\" *ngIf=\"hasMaxLength\">{{ numberOfCharacters }} / {{ maxLength }}</span>\n\n  <qd-form-hint\n    [hint]=\"hint\"\n    [control]=\"control\"\n    [hasError]=\"hasError\"\n    [hintAction]=\"hintAction\"\n    [data-test-id]=\"testId\"\n  ></qd-form-hint>\n</div>\n\n<qd-form-readonly\n  *ngIf=\"readonly\"\n  [values]=\"valueAsList\"\n  [readonlyAction]=\"readonlyAction\"\n  [data-test-id]=\"testId\"\n></qd-form-readonly>\n\n<qd-form-viewonly\n  *ngIf=\"viewonly\"\n  [values]=\"valueAsList\"\n  [viewonlyAction]=\"viewonlyAction\"\n  [data-test-id]=\"testId\"\n></qd-form-viewonly>\n\n<ng-template #inputBox>\n  <input\n    #input\n    [placeholder]=\"placeholder | translate\"\n    [value]=\"hasOptions ? (_value.value.toString() | translate) : _value.value\"\n    (input)=\"handleInput($event)\"\n    (focus)=\"handleInputFocus()\"\n    (blur)=\"handleInputBlur()\"\n    [disabled]=\"disabled || readonly\"\n    [type]=\"inputType\"\n    [attr.inputmode]=\"inputMode\"\n    [qdAutofocus]=\"hasAutofocus\"\n    [attr.data-test-id]=\"testId + '-input'\"\n    [step]=\"config?.step\"\n    required\n  />\n  <div class=\"qd-input-suffix\">\n    <qd-icon *ngIf=\"hasError && !hasOnlyUnitsError\" class=\"qd-input-error-icon\" icon=\"exclamationCircleSolid\"></qd-icon>\n    <qd-icon *ngIf=\"clearable\" class=\"qd-input-clearable-icon\" icon=\"timesLarge\" (click)=\"clearInput()\"></qd-icon>\n    <ng-content select=\"[qdIconButton]\"></ng-content>\n  </div>\n  <qd-input-units\n    *ngIf=\"hasUnits\"\n    [unit]=\"_value.unit\"\n    [config]=\"config\"\n    (unitChange)=\"handleUnitChange($event)\"\n    (opened)=\"handleUnitsOpened()\"\n    (closed)=\"handleUnitsClosed()\"\n  ></qd-input-units>\n  <div class=\"qd-input-suffix\" *ngIf=\"hasError && hasOnlyUnitsError\">\n    <qd-icon class=\"qd-input-error-icon\" icon=\"exclamationCircleSolid\"></qd-icon>\n  </div>\n</ng-template>\n"]}
|
|
@@ -10564,7 +10564,7 @@ class QdCalendarComponent {
|
|
|
10564
10564
|
QdCalendarMode = QdCalendarMode;
|
|
10565
10565
|
ngOnInit() {
|
|
10566
10566
|
moment.locale(this.language);
|
|
10567
|
-
this.
|
|
10567
|
+
this.setWeekdays();
|
|
10568
10568
|
this.todayDate = moment();
|
|
10569
10569
|
this.months = moment.months();
|
|
10570
10570
|
this.years = this.getYears((QdDateAdapter.parseToMoment(this.selectedDate)?.isValid()
|
|
@@ -10574,8 +10574,10 @@ class QdCalendarComponent {
|
|
|
10574
10574
|
this.generateCalendar(this.currentDate);
|
|
10575
10575
|
}
|
|
10576
10576
|
ngOnChanges(changes) {
|
|
10577
|
-
if (changes['language'])
|
|
10577
|
+
if (changes['language']) {
|
|
10578
10578
|
moment.locale(this.language);
|
|
10579
|
+
this.setWeekdays();
|
|
10580
|
+
}
|
|
10579
10581
|
if (changes['disabledDates'] && !changes['disabledDates'].isFirstChange())
|
|
10580
10582
|
this.generateCalendar(this.currentDate);
|
|
10581
10583
|
}
|
|
@@ -10639,9 +10641,8 @@ class QdCalendarComponent {
|
|
|
10639
10641
|
this.weeks = Array.from({ length: Math.ceil(dates.length / 7) }, () => dates.splice(0, 7));
|
|
10640
10642
|
}
|
|
10641
10643
|
fillDates(momentObj) {
|
|
10642
|
-
const
|
|
10643
|
-
const
|
|
10644
|
-
const lastDayOfGrid = moment(momentObj).endOf('month').subtract(lastOfMonth, 'days').add(7, 'days');
|
|
10644
|
+
const firstDayOfGrid = moment(momentObj).locale(this.language).startOf('month').startOf('isoWeek');
|
|
10645
|
+
const lastDayOfGrid = moment(momentObj).endOf('month').endOf('isoWeek').add(1, 'day');
|
|
10645
10646
|
const startCalendar = firstDayOfGrid.date();
|
|
10646
10647
|
return range(startCalendar, startCalendar + lastDayOfGrid.diff(firstDayOfGrid, 'days')).map(date => {
|
|
10647
10648
|
const newDate = moment(firstDayOfGrid).date(date);
|
|
@@ -10686,6 +10687,10 @@ class QdCalendarComponent {
|
|
|
10686
10687
|
return date.isAfter(fromDate, 'day') && date.isBefore(toDate, 'day');
|
|
10687
10688
|
});
|
|
10688
10689
|
}
|
|
10690
|
+
setWeekdays() {
|
|
10691
|
+
const w = moment.localeData(this.language).weekdaysMin();
|
|
10692
|
+
this.weekdays = w.slice(1).concat(w[0]);
|
|
10693
|
+
}
|
|
10689
10694
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: QdCalendarComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
10690
10695
|
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", type: QdCalendarComponent, selector: "qd-calendar", inputs: { selectedDate: "selectedDate", language: "language", disabledDates: "disabledDates" }, outputs: { selectedChange: "selectedChange" }, usesOnChanges: true, ngImport: i0, template: "<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", styles: [".nav{color:#171717;font-size:1rem;font-weight:700;line-height:1.5rem;display:grid;margin:.75rem;grid-template-columns:[next] 2rem [monthyear] auto [prev] 2rem [end];text-transform:capitalize}.nav span{line-height:2.5rem;text-align:center}.nav .current-month-year,.nav .current-years-list,.nav .current-year{cursor:pointer}tbody{display:inherit;margin:.75rem}td{color:#171717;font-size:.875rem;font-weight:400;line-height:1.3125rem;min-width:2.5625rem;padding:.4375rem;text-align:center;text-transform:capitalize}td.disabled{color:#d5d5d5;pointer-events:none}td.hidden{opacity:0;pointer-events:none}td.today{box-shadow:0 0 0 .125rem #d5d5d5 inset}td.selected,td.day:hover{background:#d5d5d5;cursor:pointer}.picker{display:flex;width:100%;flex-wrap:wrap;padding:.75rem}.picker .col{flex:0 0 33.33%;padding:.5rem .25rem}.picker .entry{padding:.4375rem;background:#d5d5d5;cursor:pointer;text-align:center}.picker .entry.selected,.picker .entry:hover{background:gray}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: QdIconComponent, selector: "qd-icon", inputs: ["icon"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
10691
10696
|
}
|
|
@@ -12314,21 +12319,23 @@ class QdInputComponent {
|
|
|
12314
12319
|
if (this.controlContainer) {
|
|
12315
12320
|
if (this.formControlName) {
|
|
12316
12321
|
this.control = this.controlContainer.control.get(this.formControlName);
|
|
12317
|
-
// TODO remove logic for support of angular FormControl with angular
|
|
12318
|
-
if (!(this.control instanceof QdFormControl))
|
|
12322
|
+
// TODO remove logic for support of angular FormControl with angular 20 update
|
|
12323
|
+
if (!(this.control instanceof QdFormControl))
|
|
12319
12324
|
console.warn('QD-UI | QdInputComponent - Please use the QdFormControl instead of the Angular FormControl');
|
|
12320
|
-
}
|
|
12321
12325
|
}
|
|
12322
12326
|
}
|
|
12323
12327
|
this.writeValue(this.value || getValue(this.config));
|
|
12328
|
+
this.normalizeInitialControlValueIfNeeded();
|
|
12324
12329
|
this._subs.add(this.actionEmitterService.hintEventEmitter$.subscribe(() => this.clickHint.emit()));
|
|
12325
12330
|
this._subs.add(this.actionEmitterService.readonlyEventEmitter$.subscribe(() => this.clickReadonly.emit()));
|
|
12326
12331
|
this._subs.add(this.actionEmitterService.viewonlyEventEmitter$.subscribe(() => this.clickViewonly.emit()));
|
|
12327
12332
|
this._subs.add(this.initOpModeSubscription());
|
|
12328
12333
|
}
|
|
12329
12334
|
ngOnChanges(changes) {
|
|
12330
|
-
if (changes['config'])
|
|
12335
|
+
if (changes['config']) {
|
|
12331
12336
|
this.updateConfig();
|
|
12337
|
+
this.normalizeInitialControlValueIfNeeded();
|
|
12338
|
+
}
|
|
12332
12339
|
if (changes['value'])
|
|
12333
12340
|
this.writeValue(this.value);
|
|
12334
12341
|
}
|
|
@@ -12337,18 +12344,15 @@ class QdInputComponent {
|
|
|
12337
12344
|
}
|
|
12338
12345
|
registerOnChange(fn) {
|
|
12339
12346
|
const fnString = fn.toString();
|
|
12340
|
-
if (fnString.includes('_noControlError') || fnString.includes('validateControlPresenceOnChange'))
|
|
12347
|
+
if (fnString.includes('_noControlError') || fnString.includes('validateControlPresenceOnChange'))
|
|
12341
12348
|
return;
|
|
12342
|
-
}
|
|
12343
12349
|
this._onChange = fn;
|
|
12344
|
-
fn(this.hasUnits ? this._value : this._value.value);
|
|
12345
12350
|
}
|
|
12346
12351
|
registerOnTouched(fn) {
|
|
12347
12352
|
this._onTouch = fn;
|
|
12348
12353
|
}
|
|
12349
12354
|
writeValue(value) {
|
|
12350
12355
|
this._value = getValueWithUnit(value, this.config);
|
|
12351
|
-
this._onChange(this.hasUnits ? this._value : this._value.value);
|
|
12352
12356
|
}
|
|
12353
12357
|
setDisabledState(disabled) {
|
|
12354
12358
|
this.disabled = disabled;
|
|
@@ -12448,6 +12452,16 @@ class QdInputComponent {
|
|
|
12448
12452
|
this.viewonly = getViewonly(this.config, topic.payload.isViewonly);
|
|
12449
12453
|
});
|
|
12450
12454
|
}
|
|
12455
|
+
normalizeInitialControlValueIfNeeded() {
|
|
12456
|
+
if (!this.control)
|
|
12457
|
+
return;
|
|
12458
|
+
const modelValue = this.control.value;
|
|
12459
|
+
const normalized = getValueWithUnit(modelValue, this.config);
|
|
12460
|
+
const target = this.hasUnits ? normalized : normalized.value;
|
|
12461
|
+
if (!isEqual(modelValue, target))
|
|
12462
|
+
this.control.setValue(target, { emitEvent: false });
|
|
12463
|
+
this._value = normalized;
|
|
12464
|
+
}
|
|
12451
12465
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: QdInputComponent, deps: [{ token: QdFormsActionEmitterService }, { token: QdFormOptionsResolverRegistry }, { token: i1$4.ControlContainer, host: true, optional: true, skipSelf: true }, { token: QdEventBrokerService, optional: true }], target: i0.ɵɵFactoryTarget.Component });
|
|
12452
12466
|
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", type: QdInputComponent, selector: "qd-input", inputs: { formControlName: "formControlName", value: "value", config: "config", isError: "isError", testId: ["data-test-id", "testId"] }, outputs: { valueChange: "valueChange", enterClick: "enterClick", clickClear: "clickClear", clickHint: "clickHint", clickReadonly: "clickReadonly", clickViewonly: "clickViewonly" }, host: { properties: { "class.qd-input-readonly": "this.readonly", "class.qd-input--readonly-action": "this.readonlyAction", "class.qd-input-viewonly": "this.viewonly", "class.qd-input--viewonly-action": "this.viewonlyAction", "class.qd-form-hint-action": "this.hintAction", "class.qd-input-hint-action": "this.hintAction", "class.qd-form-disabled": "this.disabled", "class.qd-input-disabled": "this.disabled", "class.qd-input-focus": "this.isInputFocused", "class.qd-form-error": "this.hasError", "class.qd-input-error": "this.hasError", "class.qd-input-error-from-outside": "this.isErrorFromOutside" } }, providers: [
|
|
12453
12467
|
{
|