@quadrel-enterprise-ui/framework 18.24.1 → 18.25.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -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"]}
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"page-config.interface.js","sourceRoot":"","sources":["../../../../../../libs/qd-ui/src/lib/page/model/page-config.interface.ts"],"names":[],"mappings":"","sourcesContent":["import { QdMenuButtonActionConfig } from '../../button/model/button-config';\nimport { QdPageHeaderFacetConfig } from './page-header-facet.interface';\n\n/**\n * @description Configuration of QdPage.\n *\n * @template T - The type of the page object data\n */\nexport type QdPageConfig<T extends object = object> =\n  | QdPageConfigOverview\n  | QdPageConfigCreate<T>\n  | QdPageConfigInspect<T>\n  | QdPageConfigCustom<T>;\n\nexport interface QdPageSelectedContext {\n  value: string;\n  label: {\n    i18n: string;\n  };\n}\n\ninterface QdPageContextConfigBase {\n  /**\n   * @description Description for the specific header facet\n   */\n  label: {\n    /**\n     * @description i18n string for the description, used for translation.\n     */\n    i18n: string;\n  };\n\n  /**\n   * @description Allows to identify the context\n   */\n  id: string;\n\n  /**\n   * @description Register some handler that is executed when the selection changes.\n   */\n  changed?: (selection: QdPageSelectedContext | QdPageSelectedContext[] | null) => void;\n}\n\n/**\n * @description Configuration for a context with single selection\n */\nexport interface QdPageContextConfigSingle extends QdPageContextConfigBase {\n  /**\n   * @description Configures the type on how the context selection happens.\n   */\n  type: 'single';\n\n  /**\n   * @description Available options for selection.\n   */\n  options: QdPageSelectedContext[];\n\n  /**\n   * @description Configures whether the context options are searchable for the user.\n   * @default false\n   */\n  hasSearch?: boolean;\n\n  /**\n   * @description Placeholder for search\n   */\n  searchPlaceholder?: {\n    /**\n     * @description i18n string\n     */\n    i18n: string;\n  };\n\n  /**\n   * @description Title for the dialog that will be opened\n   */\n  title?: {\n    /**\n     * @description i18n string\n     */\n    i18n: string;\n  };\n}\n\n/**\n * @description Configuration for a context with multi selection\n */\nexport interface QdPageContextConfigMulti extends QdPageContextConfigBase {\n  /**\n   * @description Configures the type on how the context selection happens.\n   */\n  type: 'multi';\n\n  /**\n   * @description Available options for selection.\n   */\n  options: QdPageSelectedContext[];\n\n  /**\n   * @description Configures whether the context options are searchable for the user.\n   * @default false\n   */\n  hasSearch?: boolean;\n\n  /**\n   * @description Placeholder for search\n\n   */\n  searchPlaceholder?: {\n    /**\n     * @description i18n string\n     */\n    i18n: string;\n  };\n\n  /**\n   * @description Title for the dialog that will be opened\n   */\n  title?: {\n    /**\n     * @description i18n string\n     */\n    i18n: string;\n  };\n}\n\n/**\n * @description Configuration for a context with custom selection (e. g. your own dialog)\n */\nexport interface QdPageContextConfigCustom extends QdPageContextConfigBase {\n  /**\n   * @description Configures the type on how the context selection happens.\n   */\n  type: 'custom';\n\n  /**\n   * @description Handler to open a custom dialog for selection\n   */\n  open: () => void;\n}\n\n/**\n * @description Configures the context with one of the available types\n */\nexport type QdPageContextConfig = QdPageContextConfigSingle | QdPageContextConfigMulti | QdPageContextConfigCustom;\n\n/**\n * @description Base configuration for QdPage.\n */\ninterface QdPageConfigBase {\n  /**\n   * @description Title of the page.\n   */\n  title: QdPageTitle;\n\n  /**\n   * @description Hides contexts from being shown. The ContextService will still work in the background.\n   *\n   * @default false\n   */\n  hideContexts?: boolean;\n\n  /**\n   * @description Label for the menu button of custom actions.\n   */\n  customActionsLabel?: QdPageCustomActionsLabel;\n}\n\n/**\n * @description Configuration for the overview page type.\n *\n * @template T - The type of the page object data\n */\nexport interface QdPageConfigOverview extends QdPageConfigBase {\n  /**\n   * @description Page Type\n   *\n   * @default 'overview'\n   */\n  pageType?: 'overview'; // Optional to make it default\n\n  /**\n   * @description Configuration specific to the overview page type.\n   */\n  pageTypeConfig?: QdPageTypeOverviewConfig;\n}\n\n/**\n * @description Configuration for the create page type.\n *\n * @template T - The type of the page object data\n */\nexport interface QdPageConfigCreate<T extends object = object> extends QdPageConfigBase {\n  /**\n   * @description Page Type\n   *\n   * @default 'create'\n   */\n  pageType: 'create';\n\n  /**\n   * @description Configuration specific to the create page type.\n   */\n  pageTypeConfig?: QdPageTypeCreateConfig;\n\n  /**\n   * @description Information placed in the header of the page. Concerns current shown object.\n   */\n  headerFacets?: QdPageHeaderFacetConfig<T>[];\n}\n\nexport interface QdPageConfigInspect<T extends object = object> extends QdPageConfigBase {\n  /**\n   * @description Page Type\n   *\n   * @default 'inspect'\n   */\n  pageType: 'inspect';\n\n  /**\n   * @description Configuration specific to the inspect page type.\n   */\n  pageTypeConfig?: QdPageTypeInspectConfig;\n\n  /**\n   * @description Information placed in the header of the page. Concerns current shown object.\n   */\n  headerFacets?: QdPageHeaderFacetConfig<T>[];\n\n  /**\n   * @description Determines whether the facets in header should be collapsed and custom actions are in a menu. This mode is designed for touch devices and mobile phones only.\n   *\n   * @default false\n   */\n  adaptiveMode?: boolean;\n}\n\nexport interface QdPageConfigCustom<T extends object = object> extends QdPageConfigBase {\n  /**\n   * @description Page Type\n   *\n   * @default 'custom'\n   */\n  pageType: 'custom';\n\n  /**\n   * @description Configuration specific to the custom page type.\n   */\n  pageTypeConfig?: QdPageTypeCustomConfig;\n\n  /**\n   * @description Information placed in the header of the page. Concerns current shown object.\n   */\n  headerFacets?: QdPageHeaderFacetConfig<T>[];\n\n  /**\n   * @description Determines whether the facets in header should be collapsed and custom actions are in a menu. This mode is designed for touch devices and mobile phones only.\n   *\n   * @default false\n   */\n  adaptiveMode?: boolean;\n}\n\n/**\n * Configures the overview page\n */\nexport interface QdPageTypeOverviewConfig {\n  /**\n   * @description Custom actions for the header.\n   * You can define a label, a handler, and you can disable or hide the action.\n   *\n   * * If there exists more than 1 Custom Action, a QdMenuButton will be displayed.\n   *\n   * * These actions are not intended to influence the core process flow or manipulate the object directly. Instead, they should be used for side effects, such as triggering notifications, updating external services, or executing supplementary tasks that do not alter the main state of the object.\n   */\n  customActions?: QdMenuButtonActionConfig[];\n}\n\n/**\n * @description Configures the create page.\n */\nexport interface QdPageTypeCreateConfig {\n  /**\n   * @description Configuration for the save draft action.\n   */\n  saveDraft?: QdPageSaveDraftAction;\n\n  /**\n   * @description Configuration for the cancel button.\n   */\n  cancel: QdPageCancelAction;\n\n  /**\n   * @description Configuration for the submit button.\n   */\n  submit: QdPageCreateSubmitAction;\n\n  /**\n   * @description Custom actions for the header.\n   * You can define a label, a handler, and you can disable or hide the action.\n   *\n   * * If there exists more than 1 Custom Action, a QdMenuButton will be displayed.\n   *\n   * * These actions are not intended to influence the core process flow or manipulate the object directly. Instead, they should be used for side effects, such as triggering notifications, updating external services, or executing supplementary tasks that do not alter the main state of the object.\n   */\n  customActions?: QdMenuButtonActionConfig[];\n}\n\n/**\n * @description Configures the inspect page.\n */\nexport interface QdPageTypeInspectConfig {\n  /**\n   * @description Operation mode for the page.\n   *\n   * * This property determines the mode in which the page operates. It can be either 'view' or 'edit'.\n   *\n   * * **view**: The page is in read-only mode.\n   * * **edit**: The page allows modifications.\n   */\n  operationMode?: QdInspectOperationMode;\n\n  /**\n   * @description Specifies whether the user can edit the object or not.\n   */\n  hideEdit?: boolean;\n\n  /**\n   * @description Configuration for the edit action.\n   */\n  edit?: QdPageEditAction;\n\n  /**\n   * @description Configuration for the save action.\n   */\n  save?: QdPageSaveAction;\n\n  /**\n   * @description Configuration for the cancel action.\n   */\n  cancel: QdPageCancelAction;\n\n  /**\n   * @description Configuration for the delete action.\n   */\n  delete?: QdPageDeleteAction;\n\n  /**\n   * @description Configuration for the archive action.\n   */\n  archive?: QdPageArchiveAction;\n\n  /**\n   * @description Configuration for the submit action.\n   */\n  submit?: QdPageSubmitAction;\n\n  /**\n   * @description Custom actions for the header.\n   * You can define a label, a handler, and you can disable or hide the action.\n   *\n   * * If there exists more than 1 Custom Action, a QdMenuButton will be displayed.\n   *\n   * * In the \"Inspect\" page type, you can assign custom actions to the operation modes \"view\" or \"edit.\" By default, the action is active in both modes.\n   *\n   * * These actions are not intended to influence the core process flow or manipulate the object directly. Instead, they should be used for side effects, such as triggering notifications, updating external services, or executing supplementary tasks that do not alter the main state of the object.\n   */\n  customActions?: (QdMenuButtonActionConfig & { operationMode?: QdInspectOperationMode })[];\n}\n\nexport interface QdPageTypeCustomConfig {\n  /**\n   * @description Custom actions for the header.\n   * You can define a label, a handler, and you can disable or hide the action.\n   *\n   * * If there exists more than 1 Custom Action, a QdMenuButton will be displayed.\n   *\n   * * These actions are not intended to influence the core process flow or manipulate the object directly. Instead, they should be used for side effects, such as triggering notifications, updating external services, or executing supplementary tasks that do not alter the main state of the object.\n   */\n  customActions?: QdMenuButtonActionConfig[];\n}\n\nexport interface QdPageTitle {\n  /**\n   * @description Defines the translation key\n   *\n   * * @example { i18n: \"i18n.overview.title\"}\n   */\n  i18n: string;\n}\n\n/**\n * @description Configuration for the custom actions label, used when multiple custom actions exist.\n */\nexport interface QdPageCustomActionsLabel {\n  /**\n   * @description Label for the menu button of custom actions, used for translation.\n   *\n   * * If no custom translation key is provided, a standard label will be used by default.\n   *\n   * * This label becomes visible if more than one custom action is defined, as the actions will be grouped under a QdMenuButton that displays this label.\n   */\n  i18n: string;\n}\n\n/**\n * @description Operation modes for the inspect page.\n *\n * @default 'view'\n */\nexport type QdInspectOperationMode = 'view' | 'edit';\n\n/**\n * @description Interface for the save action, including optional validation configuration.\n */\nexport interface QdPageSaveAction {\n  /**\n   * @description Label for the save action, used for translation.\n   *\n   * * If no custom translation key is provided, a standard label will be used by default.\n   */\n  label?: { i18n: string };\n\n  /**\n   * @description Handler function that is triggered when the save action is executed.\n   */\n  handler: (formValues?: any) => void;\n\n  /**\n   * @description Optional validation flag, defaults to true.\n   * Determines whether form validation is required before saving and ensures that changes must be present in the form before saving.\n   *\n   * * By default, this flag is set to true, meaning that validation is enforced, and the form will only save if there are changes.\n   *\n   * * If set to `false`, the form will be saved without validation checks, but changes must still be present to proceed with the save operation.\n   *\n   * * This flag is useful in scenarios where form validation is not needed or should be bypassed, but it ensures that only modified forms can be saved.\n   */\n  hasValidation?: boolean;\n}\n\n/**\n * @description Interface for the safe draft action.\n */\nexport interface QdPageSaveDraftAction {\n  /**\n   * @description Label for the save draft action, used for translation.\n   *\n   * * If no custom translation key is provided, a standard label will be used by default.\n   */\n  label?: { i18n: string };\n\n  /**\n   * @description Handler function that is triggered when the save draft action is executed.\n   */\n  handler: () => void;\n}\n\n/**\n * @description Interface for the cancel action, including an optional confirmation message.\n */\nexport interface QdPageCancelAction {\n  /**\n   * @description Label for the cancel action, used for translation.\n   *\n   * * If no custom translation key is provided, a standard label will be used by default.\n   */\n  label?: { i18n: string };\n\n  /**\n   * @description Handler function that is triggered when the cancel action is executed.\n   */\n  handler: (formValues?: any) => void;\n\n  /**\n   * @description An optional confirmation message displayed in a dialog when the user attempts to cancel the operation, warning that all changes will be discarded.\n   * If no custom message is provided, a standard message will be shown by default.\n   *\n   * * The cancellation process checks whether there are unsaved changes in the form. If there are changes, the dialog will appear.\n   *\n   * * If no changes are detected, the cancellation proceeds without showing the confirmation dialog.\n   */\n  confirmationMessage?: { i18n: string };\n}\n\n/**\n * @description Interface for the submit action on create pages.\n */\nexport interface QdPageCreateSubmitAction {\n  /**\n   * @description Label for the submit action, used for translation.\n   *\n   * * If no custom translation key is provided, a standard label will be used by default.\n   */\n  label?: { i18n: string };\n\n  /**\n   * @description Handler function that is triggered when the submit action is executed.\n   */\n  handler: (formValues?: any) => void;\n}\n\n/**\n * @description Interface for the submit action.\n */\nexport interface QdPageSubmitAction {\n  /**\n   * @description Label for the submit action, used for translation.\n   *\n   * * If no custom translation key is provided, a standard label will be used by default.\n   */\n  label?: { i18n: string };\n\n  /**\n   * @description Handler function that is triggered when the submit action is executed.\n   */\n  handler: (formValues?: any) => void;\n\n  /**\n   * @description By default, the visibility of the submit button depends on the page type and the operation mode.\n   * To completely hide the submit button, you can set this isHidden flag.\n   *\n   * @default false\n   */\n  isHidden?: boolean;\n}\n\n/**\n * @description Interface for the edit action.\n */\nexport interface QdPageEditAction {\n  /**\n   * @description Label for the edit action, used for translation.\n   *\n   * * If no custom translation key is provided, a standard label will be used by default.\n   */\n  label?: { i18n: string };\n\n  /**\n   * @description Handler function that is triggered when the edit action is executed.\n   */\n  handler: (formValues?: any) => void;\n}\n\n/**\n * @description Interface for the delete action.\n *\n * * This action is represented as an icon, so it does not require a label.\n */\nexport interface QdPageDeleteAction {\n  /**\n   * @description Handler function that is triggered when the delete action is executed.\n   */\n  handler: (formValues?: any) => void;\n}\n\n/**\n * @description Interface for the archive action.\n *\n * * This action is represented as an icon, so it does not require a label.\n */\nexport interface QdPageArchiveAction {\n  /**\n   * @description Handler function that is triggered when the archive action is executed.\n   */\n  handler: (formValues?: any) => void;\n}\n"]}
2
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"page-config.interface.js","sourceRoot":"","sources":["../../../../../../libs/qd-ui/src/lib/page/model/page-config.interface.ts"],"names":[],"mappings":"","sourcesContent":["import { Observable } from 'rxjs';\n\nimport { QdMenuButtonActionConfig } from '../../button/model/button-config';\nimport { QdPageHeaderFacetConfig } from './page-header-facet.interface';\n\n/**\n * @description Configuration of QdPage.\n *\n * @template T - The type of the page object data\n */\nexport type QdPageConfig<T extends object = object> =\n  | QdPageConfigOverview\n  | QdPageConfigCreate<T>\n  | QdPageConfigInspect<T>\n  | QdPageConfigCustom<T>;\n\nexport interface QdPageSelectedContext {\n  value: string;\n  label: {\n    i18n: string;\n  };\n}\n\ninterface QdPageContextConfigBase {\n  /**\n   * @description Description for the specific header facet\n   */\n  label: {\n    /**\n     * @description i18n string for the description, used for translation.\n     */\n    i18n: string;\n  };\n\n  /**\n   * @description Allows to identify the context\n   */\n  id: string;\n\n  /**\n   * @description Register some handler that is executed when the selection changes.\n   */\n  changed?: (selection: QdPageSelectedContext | QdPageSelectedContext[] | null) => void;\n}\n\n/**\n * @description Configuration for a context with single selection\n */\nexport interface QdPageContextConfigSingle extends QdPageContextConfigBase {\n  /**\n   * @description Configures the type on how the context selection happens.\n   */\n  type: 'single';\n\n  /**\n   * @description Available options for selection.\n   */\n  options: QdPageSelectedContext[];\n\n  /**\n   * @description Configures whether the context options are searchable for the user.\n   * @default false\n   */\n  hasSearch?: boolean;\n\n  /**\n   * @description Placeholder for search\n   */\n  searchPlaceholder?: {\n    /**\n     * @description i18n string\n     */\n    i18n: string;\n  };\n\n  /**\n   * @description Title for the dialog that will be opened\n   */\n  title?: {\n    /**\n     * @description i18n string\n     */\n    i18n: string;\n  };\n}\n\n/**\n * @description Configuration for a context with multi selection\n */\nexport interface QdPageContextConfigMulti extends QdPageContextConfigBase {\n  /**\n   * @description Configures the type on how the context selection happens.\n   */\n  type: 'multi';\n\n  /**\n   * @description Available options for selection.\n   */\n  options: QdPageSelectedContext[];\n\n  /**\n   * @description Configures whether the context options are searchable for the user.\n   * @default false\n   */\n  hasSearch?: boolean;\n\n  /**\n   * @description Placeholder for search\n\n   */\n  searchPlaceholder?: {\n    /**\n     * @description i18n string\n     */\n    i18n: string;\n  };\n\n  /**\n   * @description Title for the dialog that will be opened\n   */\n  title?: {\n    /**\n     * @description i18n string\n     */\n    i18n: string;\n  };\n}\n\n/**\n * @description Configuration for a context with custom selection (e. g. your own dialog)\n */\nexport interface QdPageContextConfigCustom extends QdPageContextConfigBase {\n  /**\n   * @description Configures the type on how the context selection happens.\n   */\n  type: 'custom';\n\n  /**\n   * @description Handler to open a custom dialog for selection\n   */\n  open: () => void;\n}\n\n/**\n * @description Configures the context with one of the available types\n */\nexport type QdPageContextConfig = QdPageContextConfigSingle | QdPageContextConfigMulti | QdPageContextConfigCustom;\n\n/**\n * @description Base configuration for QdPage.\n */\ninterface QdPageConfigBase {\n  /**\n   * @description Title of the page.\n   */\n  title: QdPageTitle;\n\n  /**\n   * @description Hides contexts from being shown. The ContextService will still work in the background.\n   *\n   * @default false\n   */\n  hideContexts?: boolean;\n\n  /**\n   * @description Label for the menu button of custom actions.\n   */\n  customActionsLabel?: QdPageCustomActionsLabel;\n}\n\n/**\n * @description Configuration for the overview page type.\n *\n * @template T - The type of the page object data\n */\nexport interface QdPageConfigOverview extends QdPageConfigBase {\n  /**\n   * @description Page Type\n   *\n   * @default 'overview'\n   */\n  pageType?: 'overview'; // Optional to make it default\n\n  /**\n   * @description Configuration specific to the overview page type.\n   */\n  pageTypeConfig?: QdPageTypeOverviewConfig;\n}\n\n/**\n * @description Configuration for the create page type.\n *\n * @template T - The type of the page object data\n */\nexport interface QdPageConfigCreate<T extends object = object> extends QdPageConfigBase {\n  /**\n   * @description Page Type\n   *\n   * @default 'create'\n   */\n  pageType: 'create';\n\n  /**\n   * @description Configuration specific to the create page type.\n   */\n  pageTypeConfig?: QdPageTypeCreateConfig;\n\n  /**\n   * @description Information placed in the header of the page. Concerns current shown object.\n   */\n  headerFacets?: QdPageHeaderFacetConfig<T>[];\n}\n\nexport interface QdPageConfigInspect<T extends object = object> extends QdPageConfigBase {\n  /**\n   * @description Page Type\n   *\n   * @default 'inspect'\n   */\n  pageType: 'inspect';\n\n  /**\n   * @description Configuration specific to the inspect page type.\n   */\n  pageTypeConfig?: QdPageTypeInspectConfig;\n\n  /**\n   * @description Information placed in the header of the page. Concerns current shown object.\n   */\n  headerFacets?: QdPageHeaderFacetConfig<T>[];\n\n  /**\n   * @description Determines whether the facets in header should be collapsed and custom actions are in a menu. This mode is designed for touch devices and mobile phones only.\n   *\n   * @default false\n   */\n  adaptiveMode?: boolean;\n}\n\nexport interface QdPageConfigCustom<T extends object = object> extends QdPageConfigBase {\n  /**\n   * @description Page Type\n   *\n   * @default 'custom'\n   */\n  pageType: 'custom';\n\n  /**\n   * @description Configuration specific to the custom page type.\n   */\n  pageTypeConfig?: QdPageTypeCustomConfig;\n\n  /**\n   * @description Information placed in the header of the page. Concerns current shown object.\n   */\n  headerFacets?: QdPageHeaderFacetConfig<T>[];\n\n  /**\n   * @description Determines whether the facets in header should be collapsed and custom actions are in a menu. This mode is designed for touch devices and mobile phones only.\n   *\n   * @default false\n   */\n  adaptiveMode?: boolean;\n}\n\n/**\n * Configures the overview page\n */\nexport interface QdPageTypeOverviewConfig {\n  /**\n   * @description Custom actions for the header.\n   * You can define a label, a handler, and you can disable or hide the action.\n   *\n   * * If there exists more than 1 Custom Action, a QdMenuButton will be displayed.\n   *\n   * * These actions are not intended to influence the core process flow or manipulate the object directly. Instead, they should be used for side effects, such as triggering notifications, updating external services, or executing supplementary tasks that do not alter the main state of the object.\n   */\n  customActions?: QdMenuButtonActionConfig[];\n}\n\n/**\n * @description Configures the create page.\n */\nexport interface QdPageTypeCreateConfig {\n  /**\n   * @description Configuration for the save draft action.\n   */\n  saveDraft?: QdPageSaveDraftAction;\n\n  /**\n   * @description Configuration for the cancel button.\n   */\n  cancel: QdPageCancelAction;\n\n  /**\n   * @description Configuration for the submit button.\n   */\n  submit: QdPageCreateSubmitAction;\n\n  /**\n   * @description Custom actions for the header.\n   * You can define a label, a handler, and you can disable or hide the action.\n   *\n   * * If there exists more than 1 Custom Action, a QdMenuButton will be displayed.\n   *\n   * * These actions are not intended to influence the core process flow or manipulate the object directly. Instead, they should be used for side effects, such as triggering notifications, updating external services, or executing supplementary tasks that do not alter the main state of the object.\n   */\n  customActions?: QdMenuButtonActionConfig[];\n}\n\n/**\n * @description Configures the inspect page.\n */\nexport interface QdPageTypeInspectConfig {\n  /**\n   * @description Operation mode for the page.\n   *\n   * * This property determines the mode in which the page operates. It can be either 'view' or 'edit'.\n   *\n   * * **view**: The page is in read-only mode.\n   * * **edit**: The page allows modifications.\n   */\n  operationMode?: QdInspectOperationMode;\n\n  /**\n   * @description Specifies whether the user can edit the object or not.\n   */\n  hideEdit?: boolean;\n\n  /**\n   * @description Configuration for the edit action.\n   */\n  edit?: QdPageEditAction;\n\n  /**\n   * @description Configuration for the save action.\n   */\n  save?: QdPageSaveAction;\n\n  /**\n   * @description Configuration for the cancel action.\n   */\n  cancel: QdPageCancelAction;\n\n  /**\n   * @description Configuration for the delete action.\n   */\n  delete?: QdPageDeleteAction;\n\n  /**\n   * @description Configuration for the archive action.\n   */\n  archive?: QdPageArchiveAction;\n\n  /**\n   * @description Configuration for the submit action.\n   */\n  submit?: QdPageSubmitAction;\n\n  /**\n   * @description Custom actions for the header.\n   * You can define a label, a handler, and you can disable or hide the action.\n   *\n   * * If there exists more than 1 Custom Action, a QdMenuButton will be displayed.\n   *\n   * * In the \"Inspect\" page type, you can assign custom actions to the operation modes \"view\" or \"edit.\" By default, the action is active in both modes.\n   *\n   * * These actions are not intended to influence the core process flow or manipulate the object directly. Instead, they should be used for side effects, such as triggering notifications, updating external services, or executing supplementary tasks that do not alter the main state of the object.\n   */\n  customActions?: (QdMenuButtonActionConfig & { operationMode?: QdInspectOperationMode })[];\n}\n\nexport interface QdPageTypeCustomConfig {\n  /**\n   * @description Custom actions for the header.\n   * You can define a label, a handler, and you can disable or hide the action.\n   *\n   * * If there exists more than 1 Custom Action, a QdMenuButton will be displayed.\n   *\n   * * These actions are not intended to influence the core process flow or manipulate the object directly. Instead, they should be used for side effects, such as triggering notifications, updating external services, or executing supplementary tasks that do not alter the main state of the object.\n   */\n  customActions?: QdMenuButtonActionConfig[];\n}\n\nexport interface QdPageTitle {\n  /**\n   * @description Defines the translation key\n   *\n   * * @example { i18n: \"i18n.overview.title\"}\n   */\n  i18n: string;\n}\n\n/**\n * @description Configuration for the custom actions label, used when multiple custom actions exist.\n */\nexport interface QdPageCustomActionsLabel {\n  /**\n   * @description Label for the menu button of custom actions, used for translation.\n   *\n   * * If no custom translation key is provided, a standard label will be used by default.\n   *\n   * * This label becomes visible if more than one custom action is defined, as the actions will be grouped under a QdMenuButton that displays this label.\n   */\n  i18n: string;\n}\n\n/**\n * @description Operation modes for the inspect page.\n *\n * @default 'view'\n */\nexport type QdInspectOperationMode = 'view' | 'edit';\n\n/**\n * @description Interface for the save action, including optional validation configuration.\n */\nexport interface QdPageSaveAction {\n  /**\n   * @description Label for the save action, used for translation.\n   *\n   * * If no custom translation key is provided, a standard label will be used by default.\n   */\n  label?: { i18n: string };\n\n  /**\n   * @description Triggered when the save action is executed.\n   *\n   * Success criteria:\n   * - If the handler returns an Observable<boolean>, only the first emission after the save click counts:\n   *   - **true:** success - toggle to view and apply the saved values\n   *   - **false:** failure/cancel - stay in edit mode\n   * - If the handler returns no Observable (void), the save is treated as instant success (toggle + apply values).\n   *\n   * On a successful save, the framework applies the values and resets its internal validation and change-tracking state.\n   */\n  handler: (formValues?: any) => void | Observable<boolean>;\n\n  /**\n   * @description Optional validation flag, defaults to true.\n   * Determines whether form validation is required before saving and ensures that changes must be present in the form before saving.\n   *\n   * * By default, this flag is set to true, meaning that validation is enforced, and the form will only save if there are changes.\n   *\n   * * If set to `false`, the form will be saved without validation checks, but changes must still be present to proceed with the save operation.\n   *\n   * * This flag is useful in scenarios where form validation is not needed or should be bypassed, but it ensures that only modified forms can be saved.\n   */\n  hasValidation?: boolean;\n}\n\n/**\n * @description Interface for the safe draft action.\n */\nexport interface QdPageSaveDraftAction {\n  /**\n   * @description Label for the save draft action, used for translation.\n   *\n   * * If no custom translation key is provided, a standard label will be used by default.\n   */\n  label?: { i18n: string };\n\n  /**\n   * @description Handler function that is triggered when the save draft action is executed.\n   */\n  handler: () => void;\n}\n\n/**\n * @description Interface for the cancel action, including an optional confirmation message.\n */\nexport interface QdPageCancelAction {\n  /**\n   * @description Label for the cancel action, used for translation.\n   *\n   * * If no custom translation key is provided, a standard label will be used by default.\n   */\n  label?: { i18n: string };\n\n  /**\n   * @description Handler function that is triggered when the cancel action is executed.\n   */\n  handler: (formValues?: any) => void;\n\n  /**\n   * @description An optional confirmation message displayed in a dialog when the user attempts to cancel the operation, warning that all changes will be discarded.\n   * If no custom message is provided, a standard message will be shown by default.\n   *\n   * * The cancellation process checks whether there are unsaved changes in the form. If there are changes, the dialog will appear.\n   *\n   * * If no changes are detected, the cancellation proceeds without showing the confirmation dialog.\n   */\n  confirmationMessage?: { i18n: string };\n}\n\n/**\n * @description Interface for the submit action on create pages.\n */\nexport interface QdPageCreateSubmitAction {\n  /**\n   * @description Label for the submit action, used for translation.\n   *\n   * * If no custom translation key is provided, a standard label will be used by default.\n   */\n  label?: { i18n: string };\n\n  /**\n   * @description Handler function that is triggered when the submit action is executed.\n   */\n  handler: (formValues?: any) => void;\n}\n\n/**\n * @description Interface for the submit action.\n */\nexport interface QdPageSubmitAction {\n  /**\n   * @description Label for the submit action, used for translation.\n   *\n   * * If no custom translation key is provided, a standard label will be used by default.\n   */\n  label?: { i18n: string };\n\n  /**\n   * @description Handler function that is triggered when the submit action is executed.\n   */\n  handler: (formValues?: any) => void;\n\n  /**\n   * @description By default, the visibility of the submit button depends on the page type and the operation mode.\n   * To completely hide the submit button, you can set this isHidden flag.\n   *\n   * @default false\n   */\n  isHidden?: boolean;\n}\n\n/**\n * @description Interface for the edit action.\n */\nexport interface QdPageEditAction {\n  /**\n   * @description Label for the edit action, used for translation.\n   *\n   * * If no custom translation key is provided, a standard label will be used by default.\n   */\n  label?: { i18n: string };\n\n  /**\n   * @description Handler function that is triggered when the edit action is executed.\n   */\n  handler: (formValues?: any) => void;\n}\n\n/**\n * @description Interface for the delete action.\n *\n * * This action is represented as an icon, so it does not require a label.\n */\nexport interface QdPageDeleteAction {\n  /**\n   * @description Handler function that is triggered when the delete action is executed.\n   */\n  handler: (formValues?: any) => void;\n}\n\n/**\n * @description Interface for the archive action.\n *\n * * This action is represented as an icon, so it does not require a label.\n */\nexport interface QdPageArchiveAction {\n  /**\n   * @description Handler function that is triggered when the archive action is executed.\n   */\n  handler: (formValues?: any) => void;\n}\n"]}
@@ -1,5 +1,5 @@
1
1
  import { ChangeDetectionStrategy, Component, HostBinding, HostListener, Inject, Input, Optional } from '@angular/core';
2
- import { BehaviorSubject, combineLatest, Subject, switchMap } from 'rxjs';
2
+ import { BehaviorSubject, combineLatest, isObservable, Subject, switchMap } from 'rxjs';
3
3
  import { debounceTime, filter, map, take, takeUntil, tap } from 'rxjs/operators';
4
4
  import { QdDialogComponent, QdDialogService, QdDialogSize } from '../../dialog/dialog.module';
5
5
  import { QdPageCancelConfirmationDialogComponent } from '../cancel-confirmation-dialog/page-cancel-confirmation-dialog.component';
@@ -193,10 +193,12 @@ export class QdPageObjectHeaderComponent {
193
193
  });
194
194
  }
195
195
  save() {
196
- this.pageStoreService.toggleViewonly(true);
197
- if (this.saveButton?.handler)
198
- this.saveButton.handler(this.formGroupManagerService.getAllValues());
199
- this.formGroupManagerService.takeFormGroupsSnapshot();
196
+ const handleSuccess = () => {
197
+ this.pageStoreService.toggleViewonly(true);
198
+ this.formGroupManagerService.takeFormGroupsSnapshot();
199
+ };
200
+ const result = this.saveButton?.handler?.(this.formGroupManagerService.getAllValues());
201
+ isObservable(result) ? result.pipe(take(1)).subscribe((ok) => ok && handleSuccess()) : handleSuccess();
200
202
  }
201
203
  changeContext(context, selection, event) {
202
204
  event.stopPropagation();
@@ -304,4 +306,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImpor
304
306
  type: HostListener,
305
307
  args: ['click']
306
308
  }] } });
307
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"page-object-header.component.js","sourceRoot":"","sources":["../../../../../../libs/qd-ui/src/lib/page/object-header/page-object-header.component.ts","../../../../../../libs/qd-ui/src/lib/page/object-header/page-object-header.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  HostBinding,\n  HostListener,\n  Inject,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Optional,\n  SimpleChanges\n} from '@angular/core';\nimport { BehaviorSubject, combineLatest, Observable, Subject, switchMap } from 'rxjs';\nimport { debounceTime, filter, map, take, takeUntil, tap } from 'rxjs/operators';\nimport { QdMenuButtonActionConfig, QdMenuButtonConfig } from '../../button/model/button-config';\nimport { QdDialogComponent, QdDialogService, QdDialogSize } from '../../dialog/dialog.module';\nimport { QdPageCancelConfirmationDialogComponent } from '../cancel-confirmation-dialog/page-cancel-confirmation-dialog.component';\nimport {\n  QdInspectOperationMode,\n  QdPageConfig,\n  QdPageConfigCreate,\n  QdPageConfigCustom,\n  QdPageConfigInspect,\n  QdPageContextConfig,\n  QdPageSelectedContext,\n  QdPageTypeInspectConfig\n} from '../model/page-config.interface';\nimport {\n  QdFacetOptionMultiSelect,\n  QdFacetOptionSingleSelect,\n  QdPageHeaderFacetConfig\n} from '../model/page-header-facet.interface';\nimport { QD_PAGE_OBJECT_RESOLVER_TOKEN, QdPageObjectResolver } from '../model/page-object-resolver';\nimport { QdContextService } from '../shared/services/context.service';\nimport { QdFormGroupManagerService } from '../shared/services/form-group-manager.service';\nimport { QdPageStoreService } from '../shared/services/page-store.service';\nimport { QdResolverTriggerService } from '../shared/services/resolver-trigger.service';\nimport { QdContextSelectDialogComponent } from './context-select-dialog/context-select-dialog.component';\n\n@Component({\n  selector: 'qd-page-object-header',\n  templateUrl: './page-object-header.component.html',\n  styleUrls: ['./page-object-header.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  host: { '[style.borderBottom]': 'borderBottomStyle' }\n})\nexport class QdPageObjectHeaderComponent<T extends object> implements OnInit, OnChanges, OnDestroy {\n  @Input({ required: true })\n  config!: QdPageConfig<T>;\n\n  @Input({ required: true })\n  hasNavigation = false;\n\n  @Input('data-test-id') testId = 'page-object-header';\n\n  @HostBinding('class.in-dialog')\n  get isInDialog(): boolean {\n    return !!this.dialogComponent;\n  }\n\n  @HostListener('click')\n  toggleFacets(): void {\n    if (!this.adaptiveMode || (this.headerFacets?.length ?? 0) >= 2) return;\n\n    this.facetsCollapsed = !this.facetsCollapsed;\n  }\n\n  get adaptiveMode(): boolean {\n    return (this.config as QdPageConfigInspect | QdPageConfigCustom).adaptiveMode;\n  }\n\n  private _pageObjectDataSubject = new BehaviorSubject<T>({} as T);\n  private _isLoadingSubject = new BehaviorSubject<boolean>(false);\n  private _customActionsSubject = new BehaviorSubject<QdMenuButtonConfig>({ actions: [] });\n  private _destroyed$ = new Subject<void>();\n\n  pageObjectData$: Observable<T> = this._pageObjectDataSubject.asObservable();\n  isLoading$: Observable<boolean> = this._isLoadingSubject.asObservable().pipe(debounceTime(400));\n  customActions$: Observable<QdMenuButtonConfig> = this._customActionsSubject.asObservable();\n\n  facetsCollapsed = true;\n\n  contexts$!: Observable<\n    {\n      label: string;\n      value: QdPageSelectedContext[];\n      context: QdPageContextConfig;\n      selection: QdPageSelectedContext | QdPageSelectedContext[];\n    }[]\n  >;\n\n  get borderBottomStyle(): string {\n    const pageType = this.config.pageType;\n\n    return pageType === 'create' ||\n      (pageType === 'inspect' && this.hasNavigation) ||\n      (pageType === 'custom' && this.hasNavigation) ||\n      (pageType === 'overview' && this.hasNavigation)\n      ? 'none !important'\n      : '';\n  }\n\n  get showEdit$(): Observable<boolean> {\n    return this.isInspectAndViewMode$.pipe(map(v => v && !this.hideEdit));\n  }\n\n  get showDelete$(): Observable<boolean> {\n    return this.isInspectAndViewMode$.pipe(map(v => v && !!this.deleteButton));\n  }\n\n  get showArchive$(): Observable<boolean> {\n    return this.isInspectAndViewMode$.pipe(map(v => v && !!this.archiveButton));\n  }\n\n  get showCancel$(): Observable<boolean> {\n    return this.isInspectAndViewMode$.pipe(map(v => !v && !!this.cancelButton && !this.isCreate));\n  }\n\n  get showSave$(): Observable<boolean> {\n    return this.isInspectAndViewMode$.pipe(map(v => !v && !!this.saveButton));\n  }\n\n  get headerFacets(): QdPageHeaderFacetConfig<T>[] | undefined {\n    if (this.hasHeaderFacets(this.config)) return this.config.headerFacets;\n  }\n\n  get isInspectAndViewMode$(): Observable<boolean> {\n    return this.pageStoreService.isViewonly$.pipe(\n      takeUntil(this._destroyed$),\n      map(isView => this.config.pageType === 'inspect' && isView)\n    );\n  }\n\n  get isCreate(): boolean {\n    return this.config.pageType === 'create';\n  }\n\n  get isOverview(): boolean {\n    return this.config.pageType === 'overview';\n  }\n\n  get isContextSelectable(): boolean {\n    return this.config.pageType === 'overview' || this.config.pageType === 'custom';\n  }\n\n  get editButton(): QdPageTypeInspectConfig['edit'] {\n    return (this.config.pageTypeConfig as QdPageTypeInspectConfig)?.edit;\n  }\n\n  get deleteButton(): QdPageTypeInspectConfig['delete'] {\n    return (this.config.pageTypeConfig as QdPageTypeInspectConfig)?.delete;\n  }\n\n  get archiveButton(): QdPageTypeInspectConfig['archive'] {\n    return (this.config.pageTypeConfig as QdPageTypeInspectConfig)?.archive;\n  }\n\n  get cancelButton(): QdPageTypeInspectConfig['cancel'] {\n    return (this.config.pageTypeConfig as QdPageTypeInspectConfig)?.cancel;\n  }\n\n  get saveButton(): QdPageTypeInspectConfig['save'] {\n    return (this.config.pageTypeConfig as QdPageTypeInspectConfig)?.save;\n  }\n\n  get hideEdit(): boolean {\n    const config = this.config.pageTypeConfig as QdPageTypeInspectConfig | undefined;\n\n    if (!config) return false;\n    if (config.operationMode !== 'edit') return config.hideEdit === true;\n\n    return false;\n  }\n\n  get hasValuesChanged$(): Observable<boolean> {\n    return this.formGroupManagerService.$hasValuesChanged();\n  }\n\n  get $canSave(): Observable<boolean> {\n    if ((this.config.pageTypeConfig as QdPageTypeInspectConfig)?.save?.hasValidation === false)\n      return this.formGroupManagerService.$hasValuesChanged();\n\n    return combineLatest([\n      this.formGroupManagerService.$areFormGroupsValid(),\n      this.formGroupManagerService.$hasValuesChanged()\n    ]).pipe(map(([isValid, hasChanges]) => isValid && hasChanges));\n  }\n\n  constructor(\n    @Optional() @Inject(QD_PAGE_OBJECT_RESOLVER_TOKEN) private pageObjectResolver: QdPageObjectResolver<T>,\n    @Optional() private formGroupManagerService: QdFormGroupManagerService,\n    @Optional() private dialogComponent: QdDialogComponent,\n    private dialog: QdDialogService,\n    private contextService: QdContextService,\n    private resolverTriggerService: QdResolverTriggerService,\n    private pageStoreService: QdPageStoreService<T>\n  ) {\n    if (pageObjectResolver) {\n      const originalUpdateMetadata = this.pageObjectResolver.updateMetadata?.bind(this.pageObjectResolver);\n      this.pageObjectResolver.updateMetadata = (props: Partial<T>): void => {\n        this.updateMetadata(props);\n        if (originalUpdateMetadata) originalUpdateMetadata(props);\n      };\n\n      this.setupResolverTrigger();\n    }\n\n    this.initContexts();\n  }\n\n  ngOnInit(): void {\n    if (this.pageObjectResolver) this.setupResolverTrigger();\n\n    this.updateCustomActions();\n    this.formGroupManagerService.takeFormGroupsSnapshot();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['config'] && !changes['config'].firstChange) this.updateCustomActions();\n  }\n\n  ngOnDestroy(): void {\n    this.pageStoreService.toggleViewonly(false);\n\n    this._destroyed$.next();\n    this._destroyed$.complete();\n  }\n\n  updateMetadata(metadata: Partial<T>): void {\n    const updatedMetadata = { ...this._pageObjectDataSubject.value, ...metadata };\n    this._pageObjectDataSubject.next(updatedMetadata);\n  }\n\n  handleAction(facet: QdFacetOptionSingleSelect | QdFacetOptionMultiSelect): void {\n    facet?.action?.handler();\n  }\n\n  hasHeaderFacets(\n    config: QdPageConfig<T>\n  ): config is QdPageConfigCreate<T> | QdPageConfigInspect<T> | QdPageConfigCustom<T> {\n    return (this.config as { headerFacets: QdPageHeaderFacetConfig<T>[] }).headerFacets != null;\n  }\n\n  edit(): void {\n    this.formGroupManagerService.takeFormGroupsSnapshot();\n    this.pageStoreService.toggleViewonly(false);\n    if (this.editButton?.handler) this.editButton.handler();\n  }\n\n  cancel(): void {\n    this.formGroupManagerService\n      .$hasValuesChanged()\n      .pipe(take(1))\n      .subscribe(hasChanged => {\n        if (hasChanged) this.openCancelDialog();\n        else this.pageStoreService.toggleViewonly(true);\n      });\n  }\n\n  save(): void {\n    this.pageStoreService.toggleViewonly(true);\n\n    if (this.saveButton?.handler) this.saveButton.handler(this.formGroupManagerService.getAllValues());\n\n    this.formGroupManagerService.takeFormGroupsSnapshot();\n  }\n\n  changeContext(\n    context: QdPageContextConfig,\n    selection: QdPageSelectedContext | QdPageSelectedContext[],\n    event: MouseEvent\n  ): void {\n    event.stopPropagation();\n\n    if (context.type === 'custom') {\n      context.open();\n\n      return;\n    }\n\n    const dialogRef = this.dialog.open(QdContextSelectDialogComponent, {\n      data: { config: context, selection },\n      dialogSize: QdDialogSize.Small,\n      title: context.title\n    });\n\n    dialogRef.closed.subscribe((data: { selected: QdPageSelectedContext[] }) => {\n      if (data) this.contextService.setValue(context.id, data.selected);\n    });\n  }\n\n  clearContext(context: QdPageContextConfig): void {\n    this.contextService.clear(context.id);\n  }\n\n  private setupResolverTrigger(): void {\n    this.resolverTriggerService\n      .shouldTriggerResolver(this.pageObjectResolver.config?.triggerOn ?? 'pathParamsChange')\n      .pipe(\n        takeUntil(this._destroyed$),\n        filter(shouldTrigger => shouldTrigger),\n        tap(() => this._isLoadingSubject.next(true)),\n        switchMap(() => this.pageObjectResolver.resolve()),\n        tap(objectData => this._pageObjectDataSubject.next(objectData)),\n        tap(() => this._isLoadingSubject.next(false))\n      )\n      .subscribe();\n  }\n\n  private initContexts(): void {\n    this.contexts$ = this.contextService.contexts$.pipe(\n      map(contexts => contexts.filter(context => context.selection || this.config.pageType === 'overview')),\n      map(contexts =>\n        contexts?.map(({ selection, context }) => ({\n          label: context.label.i18n,\n          value: Array.isArray(selection?.value)\n            ? selection?.value.filter(item => item !== null && item !== undefined)\n            : selection?.value !== null && selection?.value !== undefined\n            ? [selection?.value]\n            : ([] as QdPageSelectedContext[]),\n          context,\n          selection: selection?.value ?? []\n        }))\n      )\n    );\n  }\n\n  private updateCustomActions(): void {\n    if (this.config.pageType === 'inspect') {\n      const operationMode = this.config.pageTypeConfig?.operationMode;\n\n      if (operationMode) this.pageStoreService.toggleViewonly(operationMode === 'view');\n\n      this.pageStoreService.isViewonly$.pipe(takeUntil(this._destroyed$)).subscribe(isViewonly => {\n        const customActions = this.config.pageTypeConfig?.customActions ?? [];\n\n        this._customActionsSubject.next(this.getCustomActionsByMode(customActions, isViewonly ? 'view' : 'edit'));\n      });\n    }\n\n    if (this.config.pageType !== 'inspect')\n      this._customActionsSubject.next({ actions: this.config.pageTypeConfig?.customActions ?? [] });\n  }\n\n  private getCustomActionsByMode(\n    customActions: (QdMenuButtonActionConfig & { operationMode?: QdInspectOperationMode })[],\n    mode: QdInspectOperationMode\n  ): QdMenuButtonConfig {\n    const actions = customActions\n      .filter(action => !action.operationMode || action.operationMode === mode)\n      .map(action => {\n        const menuButtonAction = { ...action };\n        delete menuButtonAction.operationMode;\n        return menuButtonAction;\n      });\n\n    return { actions };\n  }\n\n  private openCancelDialog(): void {\n    this.dialog\n      .open(QdPageCancelConfirmationDialogComponent, {\n        title: { i18n: 'i18n.qd.page.cancel.confirmation.dialog.title' },\n        dialogSize: QdDialogSize.Small,\n        data: this.config.pageTypeConfig\n      })\n      .closed.pipe(takeUntil(this._destroyed$))\n      .subscribe(confirm => {\n        if (confirm) {\n          this.formGroupManagerService.restoreFormGroupsFromSnapshot();\n          this.pageStoreService.toggleViewonly(true);\n        }\n      });\n  }\n}\n","<div class=\"loading-overlay\" *ngIf=\"isLoading$ | async\"><qd-spinner></qd-spinner></div>\n\n<div class=\"object-header-top\">\n  <header class=\"object-header-title\">{{ config.title.i18n | translate }}</header>\n  <div class=\"object-header-toolbar\">\n    <button class=\"button-icon\" data-test-id=\"archive-button\">\n      <qd-icon\n        *ngIf=\"showArchive$ | async\"\n        (click)=\"archiveButton?.handler()\"\n        class=\"header-action-icon\"\n        [icon]=\"'resultNew'\"\n      ></qd-icon>\n    </button>\n\n    <button class=\"button-icon\" data-test-id=\"delete-button\">\n      <qd-icon\n        class=\"header-action-icon\"\n        *ngIf=\"showDelete$ | async\"\n        (click)=\"deleteButton?.handler()\"\n        [icon]=\"'trash'\"\n      ></qd-icon>\n    </button>\n\n    <button *ngIf=\"showEdit$ | async\" qdButton (click)=\"edit()\" data-test-id=\"edit-button\">\n      {{ editButton?.label?.i18n || \"i18n.qd.page.header.edit\" | translate }}\n    </button>\n\n    <button *ngIf=\"showCancel$ | async\" qdButton qdButtonGhost (click)=\"cancel()\" data-test-id=\"cancel-button\">\n      {{ cancelButton.label?.i18n || \"i18n.qd.page.header.cancel\" | translate }}\n    </button>\n\n    <button\n      *ngIf=\"showSave$ | async\"\n      qdButton\n      (click)=\"save()\"\n      data-test-id=\"save-button\"\n      [disabled]=\"($canSave | async) === false\"\n    >\n      {{ saveButton.label?.i18n || \"i18n.qd.page.header.save\" | translate }}\n    </button>\n\n    <ng-container *ngIf=\"customActions$ | async as customActions\">\n      <ng-container *ngIf=\"!adaptiveMode; else adaptive\">\n        <button\n          [qdMenuButton]=\"customActions\"\n          [autoSize]=\"false\"\n          [data-test-id]=\"'page-'\"\n          *ngIf=\"customActions.actions.length > 1; else singleButton\"\n          data-test-id=\"custom-button\"\n        >\n          {{ config?.customActionsLabel?.i18n || \"i18n.qd.page.header.actions\" | translate }}\n        </button>\n\n        <ng-template #singleButton>\n          <ng-container *ngIf=\"(customActions$ | async).actions[0] as singleAction\">\n            <button\n              qdButton\n              *ngIf=\"singleAction.handler && !singleAction.isHidden\"\n              [disabled]=\"singleAction.isDisabled\"\n              (click)=\"singleAction.handler()\"\n              data-test-id=\"custom-button\"\n            >\n              {{ singleAction.label?.i18n | translate }}\n            </button>\n          </ng-container>\n        </ng-template>\n      </ng-container>\n\n      <ng-template #adaptive>\n        <button\n          *ngIf=\"(customActions$ | async)?.actions.length >= 1\"\n          type=\"button\"\n          class=\"adaptive-menu-button\"\n          [qdPopoverOnClick]=\"menu\"\n          [qdPopoverCloseStrategy]=\"'onEveryClick'\"\n          [qdPopoverStopPropagation]=\"true\"\n          [qdPopoverMinWidth]=\"160\"\n        >\n          <qd-icon icon=\"overflowMenuVertical\"></qd-icon>\n        </button>\n\n        <ng-template #menu>\n          <button\n            *ngFor=\"let action of customActions.actions; let i = index\"\n            class=\"adaptive-menu-entry\"\n            type=\"button\"\n            [disabled]=\"action.isDisabled\"\n            (click)=\"action.handler()\"\n          >\n            {{ action.label.i18n | translate }}\n          </button>\n        </ng-template>\n      </ng-template>\n    </ng-container>\n  </div>\n</div>\n\n<div class=\"object-header-facets\" [ngClass]=\"{ amongThemselves: adaptiveMode && !facetsCollapsed }\">\n  <ng-container *ngIf=\"pageObjectData$ | async as data\">\n    <div\n      class=\"object-header-facet\"\n      *ngFor=\"let facet of headerFacets | slice : 0 : (adaptiveMode && facetsCollapsed ? 2 : headerFacets?.length ?? 0)\"\n      [attr.data-test-id]=\"testId + '-facet-' + facet.name\"\n    >\n      <div class=\"facet-label\">{{ facet.label.i18n | translate }}</div>\n      <qd-dynamic-facet class=\"dynamic-facet\" [facet]=\"facet\" [data]=\"data\"></qd-dynamic-facet>\n    </div>\n  </ng-container>\n\n  <ng-container *ngIf=\"!config.hideContexts && contexts$ | async as contexts\">\n    <div\n      class=\"object-header-facet\"\n      *ngFor=\"\n        let context of contexts\n          | slice : 0 : (adaptiveMode && facetsCollapsed ? 2 - (headerFacets?.length ?? 0) : contexts.length);\n        let index = index;\n        let first = first\n      \"\n      [ngClass]=\"{ hasDivider: headerFacets && first }\"\n    >\n      <div class=\"facet-label\">{{ context.label | translate }}</div>\n\n      <span *ngIf=\"context.value.length === 0\" class=\"no-selected-context\">{{\n        \"i18n.qd.page.context.noSelectionPlaceholder\" | translate\n      }}</span>\n\n      <span *ngIf=\"context.value.length !== 0\">\n        <qd-chip state=\"none\" [close]=\"isContextSelectable\" (closeClickEmitter)=\"clearContext(context.context)\">\n          <ng-container *ngFor=\"let val of context.value; let last = last\">\n            {{ val.label.i18n | translate }}<span *ngIf=\"!last\">, </span>\n          </ng-container>\n        </qd-chip>\n      </span>\n\n      <span *ngIf=\"isContextSelectable && (!facetsCollapsed || !adaptiveMode)\" class=\"select-button\">\n        <button\n          qdButton\n          qdButtonLink\n          type=\"button\"\n          (click)=\"changeContext(context.context, context.selection, $event)\"\n          [data-test-id]=\"'object-header-select-context-' + context.context.id\"\n        >\n          {{\n            context.value.length !== 0\n              ? (\"i18n.qd.page.context.button.change\" | translate)\n              : (\"i18n.qd.page.context.button.select\" | translate)\n          }}\n        </button>\n      </span>\n    </div>\n  </ng-container>\n\n  <span class=\"facets-toggler\" *ngIf=\"adaptiveMode && headerFacets.length + (contexts$ | async).length > 2\">\n    <span *ngIf=\"facetsCollapsed\">+{{ headerFacets.length + (contexts$ | async).length - 2 }}</span>\n    <button qdIconButton>\n      <qd-icon [icon]=\"facetsCollapsed ? 'ctrlDown' : 'ctrlTop'\"></qd-icon>\n    </button>\n  </span>\n</div>\n"]}
309
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"page-object-header.component.js","sourceRoot":"","sources":["../../../../../../libs/qd-ui/src/lib/page/object-header/page-object-header.component.ts","../../../../../../libs/qd-ui/src/lib/page/object-header/page-object-header.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  HostBinding,\n  HostListener,\n  Inject,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Optional,\n  SimpleChanges\n} from '@angular/core';\nimport { BehaviorSubject, combineLatest, isObservable, Observable, Subject, switchMap } from 'rxjs';\nimport { debounceTime, filter, map, take, takeUntil, tap } from 'rxjs/operators';\nimport { QdMenuButtonActionConfig, QdMenuButtonConfig } from '../../button/model/button-config';\nimport { QdDialogComponent, QdDialogService, QdDialogSize } from '../../dialog/dialog.module';\nimport { QdPageCancelConfirmationDialogComponent } from '../cancel-confirmation-dialog/page-cancel-confirmation-dialog.component';\nimport {\n  QdInspectOperationMode,\n  QdPageConfig,\n  QdPageConfigCreate,\n  QdPageConfigCustom,\n  QdPageConfigInspect,\n  QdPageContextConfig,\n  QdPageSelectedContext,\n  QdPageTypeInspectConfig\n} from '../model/page-config.interface';\nimport {\n  QdFacetOptionMultiSelect,\n  QdFacetOptionSingleSelect,\n  QdPageHeaderFacetConfig\n} from '../model/page-header-facet.interface';\nimport { QD_PAGE_OBJECT_RESOLVER_TOKEN, QdPageObjectResolver } from '../model/page-object-resolver';\nimport { QdContextService } from '../shared/services/context.service';\nimport { QdFormGroupManagerService } from '../shared/services/form-group-manager.service';\nimport { QdPageStoreService } from '../shared/services/page-store.service';\nimport { QdResolverTriggerService } from '../shared/services/resolver-trigger.service';\nimport { QdContextSelectDialogComponent } from './context-select-dialog/context-select-dialog.component';\n\n@Component({\n  selector: 'qd-page-object-header',\n  templateUrl: './page-object-header.component.html',\n  styleUrls: ['./page-object-header.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  host: { '[style.borderBottom]': 'borderBottomStyle' }\n})\nexport class QdPageObjectHeaderComponent<T extends object> implements OnInit, OnChanges, OnDestroy {\n  @Input({ required: true })\n  config!: QdPageConfig<T>;\n\n  @Input({ required: true })\n  hasNavigation = false;\n\n  @Input('data-test-id') testId = 'page-object-header';\n\n  @HostBinding('class.in-dialog')\n  get isInDialog(): boolean {\n    return !!this.dialogComponent;\n  }\n\n  @HostListener('click')\n  toggleFacets(): void {\n    if (!this.adaptiveMode || (this.headerFacets?.length ?? 0) >= 2) return;\n\n    this.facetsCollapsed = !this.facetsCollapsed;\n  }\n\n  get adaptiveMode(): boolean {\n    return (this.config as QdPageConfigInspect | QdPageConfigCustom).adaptiveMode;\n  }\n\n  private _pageObjectDataSubject = new BehaviorSubject<T>({} as T);\n  private _isLoadingSubject = new BehaviorSubject<boolean>(false);\n  private _customActionsSubject = new BehaviorSubject<QdMenuButtonConfig>({ actions: [] });\n  private _destroyed$ = new Subject<void>();\n\n  pageObjectData$: Observable<T> = this._pageObjectDataSubject.asObservable();\n  isLoading$: Observable<boolean> = this._isLoadingSubject.asObservable().pipe(debounceTime(400));\n  customActions$: Observable<QdMenuButtonConfig> = this._customActionsSubject.asObservable();\n\n  facetsCollapsed = true;\n\n  contexts$!: Observable<\n    {\n      label: string;\n      value: QdPageSelectedContext[];\n      context: QdPageContextConfig;\n      selection: QdPageSelectedContext | QdPageSelectedContext[];\n    }[]\n  >;\n\n  get borderBottomStyle(): string {\n    const pageType = this.config.pageType;\n\n    return pageType === 'create' ||\n      (pageType === 'inspect' && this.hasNavigation) ||\n      (pageType === 'custom' && this.hasNavigation) ||\n      (pageType === 'overview' && this.hasNavigation)\n      ? 'none !important'\n      : '';\n  }\n\n  get showEdit$(): Observable<boolean> {\n    return this.isInspectAndViewMode$.pipe(map(v => v && !this.hideEdit));\n  }\n\n  get showDelete$(): Observable<boolean> {\n    return this.isInspectAndViewMode$.pipe(map(v => v && !!this.deleteButton));\n  }\n\n  get showArchive$(): Observable<boolean> {\n    return this.isInspectAndViewMode$.pipe(map(v => v && !!this.archiveButton));\n  }\n\n  get showCancel$(): Observable<boolean> {\n    return this.isInspectAndViewMode$.pipe(map(v => !v && !!this.cancelButton && !this.isCreate));\n  }\n\n  get showSave$(): Observable<boolean> {\n    return this.isInspectAndViewMode$.pipe(map(v => !v && !!this.saveButton));\n  }\n\n  get headerFacets(): QdPageHeaderFacetConfig<T>[] | undefined {\n    if (this.hasHeaderFacets(this.config)) return this.config.headerFacets;\n  }\n\n  get isInspectAndViewMode$(): Observable<boolean> {\n    return this.pageStoreService.isViewonly$.pipe(\n      takeUntil(this._destroyed$),\n      map(isView => this.config.pageType === 'inspect' && isView)\n    );\n  }\n\n  get isCreate(): boolean {\n    return this.config.pageType === 'create';\n  }\n\n  get isOverview(): boolean {\n    return this.config.pageType === 'overview';\n  }\n\n  get isContextSelectable(): boolean {\n    return this.config.pageType === 'overview' || this.config.pageType === 'custom';\n  }\n\n  get editButton(): QdPageTypeInspectConfig['edit'] {\n    return (this.config.pageTypeConfig as QdPageTypeInspectConfig)?.edit;\n  }\n\n  get deleteButton(): QdPageTypeInspectConfig['delete'] {\n    return (this.config.pageTypeConfig as QdPageTypeInspectConfig)?.delete;\n  }\n\n  get archiveButton(): QdPageTypeInspectConfig['archive'] {\n    return (this.config.pageTypeConfig as QdPageTypeInspectConfig)?.archive;\n  }\n\n  get cancelButton(): QdPageTypeInspectConfig['cancel'] {\n    return (this.config.pageTypeConfig as QdPageTypeInspectConfig)?.cancel;\n  }\n\n  get saveButton(): QdPageTypeInspectConfig['save'] {\n    return (this.config.pageTypeConfig as QdPageTypeInspectConfig)?.save;\n  }\n\n  get hideEdit(): boolean {\n    const config = this.config.pageTypeConfig as QdPageTypeInspectConfig | undefined;\n\n    if (!config) return false;\n    if (config.operationMode !== 'edit') return config.hideEdit === true;\n\n    return false;\n  }\n\n  get hasValuesChanged$(): Observable<boolean> {\n    return this.formGroupManagerService.$hasValuesChanged();\n  }\n\n  get $canSave(): Observable<boolean> {\n    if ((this.config.pageTypeConfig as QdPageTypeInspectConfig)?.save?.hasValidation === false)\n      return this.formGroupManagerService.$hasValuesChanged();\n\n    return combineLatest([\n      this.formGroupManagerService.$areFormGroupsValid(),\n      this.formGroupManagerService.$hasValuesChanged()\n    ]).pipe(map(([isValid, hasChanges]) => isValid && hasChanges));\n  }\n\n  constructor(\n    @Optional() @Inject(QD_PAGE_OBJECT_RESOLVER_TOKEN) private pageObjectResolver: QdPageObjectResolver<T>,\n    @Optional() private formGroupManagerService: QdFormGroupManagerService,\n    @Optional() private dialogComponent: QdDialogComponent,\n    private dialog: QdDialogService,\n    private contextService: QdContextService,\n    private resolverTriggerService: QdResolverTriggerService,\n    private pageStoreService: QdPageStoreService<T>\n  ) {\n    if (pageObjectResolver) {\n      const originalUpdateMetadata = this.pageObjectResolver.updateMetadata?.bind(this.pageObjectResolver);\n      this.pageObjectResolver.updateMetadata = (props: Partial<T>): void => {\n        this.updateMetadata(props);\n        if (originalUpdateMetadata) originalUpdateMetadata(props);\n      };\n\n      this.setupResolverTrigger();\n    }\n\n    this.initContexts();\n  }\n\n  ngOnInit(): void {\n    if (this.pageObjectResolver) this.setupResolverTrigger();\n\n    this.updateCustomActions();\n    this.formGroupManagerService.takeFormGroupsSnapshot();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['config'] && !changes['config'].firstChange) this.updateCustomActions();\n  }\n\n  ngOnDestroy(): void {\n    this.pageStoreService.toggleViewonly(false);\n\n    this._destroyed$.next();\n    this._destroyed$.complete();\n  }\n\n  updateMetadata(metadata: Partial<T>): void {\n    const updatedMetadata = { ...this._pageObjectDataSubject.value, ...metadata };\n    this._pageObjectDataSubject.next(updatedMetadata);\n  }\n\n  handleAction(facet: QdFacetOptionSingleSelect | QdFacetOptionMultiSelect): void {\n    facet?.action?.handler();\n  }\n\n  hasHeaderFacets(\n    config: QdPageConfig<T>\n  ): config is QdPageConfigCreate<T> | QdPageConfigInspect<T> | QdPageConfigCustom<T> {\n    return (this.config as { headerFacets: QdPageHeaderFacetConfig<T>[] }).headerFacets != null;\n  }\n\n  edit(): void {\n    this.formGroupManagerService.takeFormGroupsSnapshot();\n    this.pageStoreService.toggleViewonly(false);\n    if (this.editButton?.handler) this.editButton.handler();\n  }\n\n  cancel(): void {\n    this.formGroupManagerService\n      .$hasValuesChanged()\n      .pipe(take(1))\n      .subscribe(hasChanged => {\n        if (hasChanged) this.openCancelDialog();\n        else this.pageStoreService.toggleViewonly(true);\n      });\n  }\n\n  save(): void {\n    const handleSuccess = (): void => {\n      this.pageStoreService.toggleViewonly(true);\n      this.formGroupManagerService.takeFormGroupsSnapshot();\n    };\n\n    const result = this.saveButton?.handler?.(this.formGroupManagerService.getAllValues());\n\n    isObservable(result) ? result.pipe(take(1)).subscribe((ok: boolean) => ok && handleSuccess()) : handleSuccess();\n  }\n\n  changeContext(\n    context: QdPageContextConfig,\n    selection: QdPageSelectedContext | QdPageSelectedContext[],\n    event: MouseEvent\n  ): void {\n    event.stopPropagation();\n\n    if (context.type === 'custom') {\n      context.open();\n\n      return;\n    }\n\n    const dialogRef = this.dialog.open(QdContextSelectDialogComponent, {\n      data: { config: context, selection },\n      dialogSize: QdDialogSize.Small,\n      title: context.title\n    });\n\n    dialogRef.closed.subscribe((data: { selected: QdPageSelectedContext[] }) => {\n      if (data) this.contextService.setValue(context.id, data.selected);\n    });\n  }\n\n  clearContext(context: QdPageContextConfig): void {\n    this.contextService.clear(context.id);\n  }\n\n  private setupResolverTrigger(): void {\n    this.resolverTriggerService\n      .shouldTriggerResolver(this.pageObjectResolver.config?.triggerOn ?? 'pathParamsChange')\n      .pipe(\n        takeUntil(this._destroyed$),\n        filter(shouldTrigger => shouldTrigger),\n        tap(() => this._isLoadingSubject.next(true)),\n        switchMap(() => this.pageObjectResolver.resolve()),\n        tap(objectData => this._pageObjectDataSubject.next(objectData)),\n        tap(() => this._isLoadingSubject.next(false))\n      )\n      .subscribe();\n  }\n\n  private initContexts(): void {\n    this.contexts$ = this.contextService.contexts$.pipe(\n      map(contexts => contexts.filter(context => context.selection || this.config.pageType === 'overview')),\n      map(contexts =>\n        contexts?.map(({ selection, context }) => ({\n          label: context.label.i18n,\n          value: Array.isArray(selection?.value)\n            ? selection?.value.filter(item => item !== null && item !== undefined)\n            : selection?.value !== null && selection?.value !== undefined\n            ? [selection?.value]\n            : ([] as QdPageSelectedContext[]),\n          context,\n          selection: selection?.value ?? []\n        }))\n      )\n    );\n  }\n\n  private updateCustomActions(): void {\n    if (this.config.pageType === 'inspect') {\n      const operationMode = this.config.pageTypeConfig?.operationMode;\n\n      if (operationMode) this.pageStoreService.toggleViewonly(operationMode === 'view');\n\n      this.pageStoreService.isViewonly$.pipe(takeUntil(this._destroyed$)).subscribe(isViewonly => {\n        const customActions = this.config.pageTypeConfig?.customActions ?? [];\n\n        this._customActionsSubject.next(this.getCustomActionsByMode(customActions, isViewonly ? 'view' : 'edit'));\n      });\n    }\n\n    if (this.config.pageType !== 'inspect')\n      this._customActionsSubject.next({ actions: this.config.pageTypeConfig?.customActions ?? [] });\n  }\n\n  private getCustomActionsByMode(\n    customActions: (QdMenuButtonActionConfig & { operationMode?: QdInspectOperationMode })[],\n    mode: QdInspectOperationMode\n  ): QdMenuButtonConfig {\n    const actions = customActions\n      .filter(action => !action.operationMode || action.operationMode === mode)\n      .map(action => {\n        const menuButtonAction = { ...action };\n        delete menuButtonAction.operationMode;\n        return menuButtonAction;\n      });\n\n    return { actions };\n  }\n\n  private openCancelDialog(): void {\n    this.dialog\n      .open(QdPageCancelConfirmationDialogComponent, {\n        title: { i18n: 'i18n.qd.page.cancel.confirmation.dialog.title' },\n        dialogSize: QdDialogSize.Small,\n        data: this.config.pageTypeConfig\n      })\n      .closed.pipe(takeUntil(this._destroyed$))\n      .subscribe(confirm => {\n        if (confirm) {\n          this.formGroupManagerService.restoreFormGroupsFromSnapshot();\n          this.pageStoreService.toggleViewonly(true);\n        }\n      });\n  }\n}\n","<div class=\"loading-overlay\" *ngIf=\"isLoading$ | async\"><qd-spinner></qd-spinner></div>\n\n<div class=\"object-header-top\">\n  <header class=\"object-header-title\">{{ config.title.i18n | translate }}</header>\n  <div class=\"object-header-toolbar\">\n    <button class=\"button-icon\" data-test-id=\"archive-button\">\n      <qd-icon\n        *ngIf=\"showArchive$ | async\"\n        (click)=\"archiveButton?.handler()\"\n        class=\"header-action-icon\"\n        [icon]=\"'resultNew'\"\n      ></qd-icon>\n    </button>\n\n    <button class=\"button-icon\" data-test-id=\"delete-button\">\n      <qd-icon\n        class=\"header-action-icon\"\n        *ngIf=\"showDelete$ | async\"\n        (click)=\"deleteButton?.handler()\"\n        [icon]=\"'trash'\"\n      ></qd-icon>\n    </button>\n\n    <button *ngIf=\"showEdit$ | async\" qdButton (click)=\"edit()\" data-test-id=\"edit-button\">\n      {{ editButton?.label?.i18n || \"i18n.qd.page.header.edit\" | translate }}\n    </button>\n\n    <button *ngIf=\"showCancel$ | async\" qdButton qdButtonGhost (click)=\"cancel()\" data-test-id=\"cancel-button\">\n      {{ cancelButton.label?.i18n || \"i18n.qd.page.header.cancel\" | translate }}\n    </button>\n\n    <button\n      *ngIf=\"showSave$ | async\"\n      qdButton\n      (click)=\"save()\"\n      data-test-id=\"save-button\"\n      [disabled]=\"($canSave | async) === false\"\n    >\n      {{ saveButton.label?.i18n || \"i18n.qd.page.header.save\" | translate }}\n    </button>\n\n    <ng-container *ngIf=\"customActions$ | async as customActions\">\n      <ng-container *ngIf=\"!adaptiveMode; else adaptive\">\n        <button\n          [qdMenuButton]=\"customActions\"\n          [autoSize]=\"false\"\n          [data-test-id]=\"'page-'\"\n          *ngIf=\"customActions.actions.length > 1; else singleButton\"\n          data-test-id=\"custom-button\"\n        >\n          {{ config?.customActionsLabel?.i18n || \"i18n.qd.page.header.actions\" | translate }}\n        </button>\n\n        <ng-template #singleButton>\n          <ng-container *ngIf=\"(customActions$ | async).actions[0] as singleAction\">\n            <button\n              qdButton\n              *ngIf=\"singleAction.handler && !singleAction.isHidden\"\n              [disabled]=\"singleAction.isDisabled\"\n              (click)=\"singleAction.handler()\"\n              data-test-id=\"custom-button\"\n            >\n              {{ singleAction.label?.i18n | translate }}\n            </button>\n          </ng-container>\n        </ng-template>\n      </ng-container>\n\n      <ng-template #adaptive>\n        <button\n          *ngIf=\"(customActions$ | async)?.actions.length >= 1\"\n          type=\"button\"\n          class=\"adaptive-menu-button\"\n          [qdPopoverOnClick]=\"menu\"\n          [qdPopoverCloseStrategy]=\"'onEveryClick'\"\n          [qdPopoverStopPropagation]=\"true\"\n          [qdPopoverMinWidth]=\"160\"\n        >\n          <qd-icon icon=\"overflowMenuVertical\"></qd-icon>\n        </button>\n\n        <ng-template #menu>\n          <button\n            *ngFor=\"let action of customActions.actions; let i = index\"\n            class=\"adaptive-menu-entry\"\n            type=\"button\"\n            [disabled]=\"action.isDisabled\"\n            (click)=\"action.handler()\"\n          >\n            {{ action.label.i18n | translate }}\n          </button>\n        </ng-template>\n      </ng-template>\n    </ng-container>\n  </div>\n</div>\n\n<div class=\"object-header-facets\" [ngClass]=\"{ amongThemselves: adaptiveMode && !facetsCollapsed }\">\n  <ng-container *ngIf=\"pageObjectData$ | async as data\">\n    <div\n      class=\"object-header-facet\"\n      *ngFor=\"let facet of headerFacets | slice : 0 : (adaptiveMode && facetsCollapsed ? 2 : headerFacets?.length ?? 0)\"\n      [attr.data-test-id]=\"testId + '-facet-' + facet.name\"\n    >\n      <div class=\"facet-label\">{{ facet.label.i18n | translate }}</div>\n      <qd-dynamic-facet class=\"dynamic-facet\" [facet]=\"facet\" [data]=\"data\"></qd-dynamic-facet>\n    </div>\n  </ng-container>\n\n  <ng-container *ngIf=\"!config.hideContexts && contexts$ | async as contexts\">\n    <div\n      class=\"object-header-facet\"\n      *ngFor=\"\n        let context of contexts\n          | slice : 0 : (adaptiveMode && facetsCollapsed ? 2 - (headerFacets?.length ?? 0) : contexts.length);\n        let index = index;\n        let first = first\n      \"\n      [ngClass]=\"{ hasDivider: headerFacets && first }\"\n    >\n      <div class=\"facet-label\">{{ context.label | translate }}</div>\n\n      <span *ngIf=\"context.value.length === 0\" class=\"no-selected-context\">{{\n        \"i18n.qd.page.context.noSelectionPlaceholder\" | translate\n      }}</span>\n\n      <span *ngIf=\"context.value.length !== 0\">\n        <qd-chip state=\"none\" [close]=\"isContextSelectable\" (closeClickEmitter)=\"clearContext(context.context)\">\n          <ng-container *ngFor=\"let val of context.value; let last = last\">\n            {{ val.label.i18n | translate }}<span *ngIf=\"!last\">, </span>\n          </ng-container>\n        </qd-chip>\n      </span>\n\n      <span *ngIf=\"isContextSelectable && (!facetsCollapsed || !adaptiveMode)\" class=\"select-button\">\n        <button\n          qdButton\n          qdButtonLink\n          type=\"button\"\n          (click)=\"changeContext(context.context, context.selection, $event)\"\n          [data-test-id]=\"'object-header-select-context-' + context.context.id\"\n        >\n          {{\n            context.value.length !== 0\n              ? (\"i18n.qd.page.context.button.change\" | translate)\n              : (\"i18n.qd.page.context.button.select\" | translate)\n          }}\n        </button>\n      </span>\n    </div>\n  </ng-container>\n\n  <span class=\"facets-toggler\" *ngIf=\"adaptiveMode && headerFacets.length + (contexts$ | async).length > 2\">\n    <span *ngIf=\"facetsCollapsed\">+{{ headerFacets.length + (contexts$ | async).length - 2 }}</span>\n    <button qdIconButton>\n      <qd-icon [icon]=\"facetsCollapsed ? 'ctrlDown' : 'ctrlTop'\"></qd-icon>\n    </button>\n  </span>\n</div>\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 => {
@@ -33190,10 +33187,12 @@ class QdPageObjectHeaderComponent {
33190
33187
  });
33191
33188
  }
33192
33189
  save() {
33193
- this.pageStoreService.toggleViewonly(true);
33194
- if (this.saveButton?.handler)
33195
- this.saveButton.handler(this.formGroupManagerService.getAllValues());
33196
- this.formGroupManagerService.takeFormGroupsSnapshot();
33190
+ const handleSuccess = () => {
33191
+ this.pageStoreService.toggleViewonly(true);
33192
+ this.formGroupManagerService.takeFormGroupsSnapshot();
33193
+ };
33194
+ const result = this.saveButton?.handler?.(this.formGroupManagerService.getAllValues());
33195
+ isObservable(result) ? result.pipe(take(1)).subscribe((ok) => ok && handleSuccess()) : handleSuccess();
33197
33196
  }
33198
33197
  changeContext(context, selection, event) {
33199
33198
  event.stopPropagation();