@quadrel-enterprise-ui/framework 18.32.1 → 18.33.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.
- package/esm2022/lib/container/container.component.mjs +2 -2
- package/esm2022/lib/container/toolbar/action/container-toolbar-action.component.mjs +2 -2
- package/esm2022/lib/forms/shared/components/form-hint/form-hint.component.mjs +2 -2
- package/esm2022/lib/layout/action-bar/action-bar.component.mjs +2 -2
- package/esm2022/lib/layout/layout-renderer/layout-renderer.component.mjs +2 -2
- package/esm2022/lib/layout/modal-fullscreen-container/modal-fullscreen-container.component.mjs +2 -2
- package/esm2022/lib/navigation/stepper/step-action/step-action.component.mjs +2 -2
- package/esm2022/lib/navigation/stepper/step-item/step-item.component.mjs +2 -2
- package/esm2022/lib/navigation/tabs/tab-action/tab-action.component.mjs +2 -2
- package/esm2022/lib/quick-edit/quick-edit.component.mjs +10 -7
- package/esm2022/lib/search/search.component.mjs +2 -2
- package/esm2022/lib/shell/header/service-navigation/shell-service-navigation.component.mjs +4 -4
- package/fesm2022/quadrel-enterprise-ui-framework.mjs +32 -29
- package/fesm2022/quadrel-enterprise-ui-framework.mjs.map +1 -1
- package/lib/quick-edit/quick-edit.component.d.ts +2 -1
- package/lib/quick-edit/quick-edit.component.d.ts.map +1 -1
- package/package.json +2 -2
|
@@ -192,7 +192,7 @@ export class QdQuickEditComponent {
|
|
|
192
192
|
return (this.controlContainer?.control ?? this.quickEditFormGroup.get('rows'));
|
|
193
193
|
}
|
|
194
194
|
get showStandaloneCreate() {
|
|
195
|
-
return !this.containerActionService && !this.sectionActionService && this.config.canAdd;
|
|
195
|
+
return !this.containerActionService && !this.sectionActionService && !!this.config.canAdd;
|
|
196
196
|
}
|
|
197
197
|
get canAdd() {
|
|
198
198
|
return this.config.canAdd ?? this.sectionActionService != null;
|
|
@@ -240,6 +240,11 @@ export class QdQuickEditComponent {
|
|
|
240
240
|
this._destroyed$.next();
|
|
241
241
|
this._destroyed$.complete();
|
|
242
242
|
}
|
|
243
|
+
isActionDisabled(action, row) {
|
|
244
|
+
if (typeof action.isDisabled === 'function')
|
|
245
|
+
return action.isDisabled(row);
|
|
246
|
+
return !!action.isDisabled;
|
|
247
|
+
}
|
|
243
248
|
handleSecondaryAction(action, rowIndex) {
|
|
244
249
|
if (!action)
|
|
245
250
|
return;
|
|
@@ -345,16 +350,14 @@ export class QdQuickEditComponent {
|
|
|
345
350
|
initManualChangeDetectionForControlReset() {
|
|
346
351
|
if (!this.isFormControl)
|
|
347
352
|
return;
|
|
348
|
-
this.controlContainer.control.valueChanges
|
|
349
|
-
.pipe(startWith(this.controlContainer.control.value.length), map(() => this.controlContainer.control.value.length), distinctUntilChanged(), tap(() => this.changeDetectorRef.detectChanges()))
|
|
350
|
-
.subscribe();
|
|
353
|
+
this.controlContainer.control.valueChanges.pipe(startWith(this.controlContainer.control.value.length), map(() => this.controlContainer.control.value.length), distinctUntilChanged(), tap(() => this.changeDetectorRef.detectChanges())).subscribe();
|
|
351
354
|
}
|
|
352
355
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: QdQuickEditComponent, deps: [{ token: i1.FormBuilder }, { token: i2.QdPageFooterService, optional: true }, { token: i3.QdPageStoreService, optional: true }, { token: i4.QdSectionToolbarActionService, optional: true }, { token: i5.QdContainerActionService, optional: true }, { token: i6.QdEventBrokerService, optional: true }, { token: i0.ChangeDetectorRef }, { token: i1.ControlContainer, optional: true, self: true }], target: i0.ɵɵFactoryTarget.Component });
|
|
353
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", type: QdQuickEditComponent, selector: "qd-quick-edit", inputs: { config: "config", data: "data", testId: ["data-test-id", "testId"] }, outputs: { formGroupChange: "formGroupChange", addNewClicked: "addNewClicked" }, viewQueries: [{ propertyName: "customForDirective", first: true, predicate: QdCustomForDirective, descendants: true }, { propertyName: "focusables", predicate: QdFocusableDirective, descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div class=\"editable-actions\" *ngIf=\"showStandaloneCreate\">\n <button\n qdButton\n qdButtonGhost\n icon=\"plus\"\n (click)=\"createRow()\"\n [data-test-id]=\"testId + '-button-add-new'\"\n class=\"create-button-standalone\"\n >\n {{ config.standaloneCreateLabel?.i18n ?? \"i18n.qd.quick.edit.createButtonLabel\" | translate }}\n </button>\n</div>\n\n<div class=\"table\" [formGroup]=\"control\">\n <div class=\"table-header\" *ngIf=\"!config.canAdd || templateData.length > 0 || config.emptyStateView\">\n <div class=\"table-row\">\n <div class=\"table-cell\" *ngFor=\"let header of visibleColumns\">\n {{ header?.i18n | translate }}\n <qd-icon\n *ngIf=\"hasTooltip(header?.tooltip)\"\n icon=\"circleInfo\"\n class=\"additional-info\"\n qdTooltipOnClick\n [qdTooltipContent]=\"header?.tooltip?.content\"\n ></qd-icon>\n </div>\n <div class=\"table-cell actions-column\" *ngIf=\"config?.secondaryActions?.length > 0\">\n <button class=\"menu-button\">\n <qd-icon icon=\"overflowMenuHorizontal\"></qd-icon>\n </button>\n </div>\n </div>\n </div>\n <div class=\"table-body\">\n <div\n class=\"table-row\"\n *qdCustomFor=\"let row of templateData; let rowIndex = index; toggler: togglerDrawing\"\n [formGroupName]=\"rowIndex\"\n >\n <ng-container *ngFor=\"let column of visibleColumns\">\n <div class=\"table-cell\">\n <qd-dropdown\n [config]=\"{\n filter: column.filter,\n options: column.options,\n placeholder: column.placeholder,\n placeholderPrefix: column.placeholderPrefix,\n viewonly: (viewonly$ | async) === true || !column.isEditable(row, column.name)\n }\"\n [data-test-id]=\"column.name + rowIndex\"\n *ngIf=\"column.type === 'enum'; else otherTypes\"\n [dense]=\"true\"\n [formControl]=\"$any(control.controls[rowIndex])?.controls[column.name]\"\n qdFocusable\n class=\"dropdown\"\n >\n </qd-dropdown>\n\n <ng-template #otherTypes>\n <qd-input\n [data-test-id]=\"column.name + rowIndex\"\n [formControlName]=\"column.name\"\n *ngIf=\"column.type !== 'enum' && $any(control.controls[rowIndex])?.controls[column.name]\"\n [config]=\"{\n inputType: column.type === 'integer' ? 'number' : 'text',\n viewonly: (viewonly$ | async) === true || !column.isEditable(row, column.name)\n }\"\n qdFocusable\n ></qd-input>\n </ng-template>\n </div>\n </ng-container>\n <td\n *ngIf=\"config.secondaryActions?.length > 0 || canAdd\"\n class=\"table-cell actions\"\n [attr.data-test-id]=\"testId + '-cell-inline-actions'\"\n >\n <button\n type=\"button\"\n [qdPopoverOnClick]=\"menu\"\n [qdPopoverCloseStrategy]=\"'onEveryClick'\"\n [qdPopoverStopPropagation]=\"true\"\n class=\"menu-button\"\n data-test=\"secondary-actions-toggler\"\n >\n <qd-icon icon=\"overflowMenuHorizontal\"></qd-icon>\n </button>\n\n <ng-template #menu>\n <button\n *ngFor=\"let secondaryAction of actions$ | async\"\n class=\"secondary-actions\"\n [ngClass]=\"{ disabled: secondaryAction
|
|
356
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", type: QdQuickEditComponent, selector: "qd-quick-edit", inputs: { config: "config", data: "data", testId: ["data-test-id", "testId"] }, outputs: { formGroupChange: "formGroupChange", addNewClicked: "addNewClicked" }, viewQueries: [{ propertyName: "customForDirective", first: true, predicate: QdCustomForDirective, descendants: true }, { propertyName: "focusables", predicate: QdFocusableDirective, descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div class=\"editable-actions\" *ngIf=\"showStandaloneCreate\">\n <button\n qdButton\n qdButtonGhost\n icon=\"plus\"\n (click)=\"createRow()\"\n [data-test-id]=\"testId + '-button-add-new'\"\n class=\"create-button-standalone\"\n >\n {{ config.standaloneCreateLabel?.i18n ?? \"i18n.qd.quick.edit.createButtonLabel\" | translate }}\n </button>\n</div>\n\n<div class=\"table\" [formGroup]=\"control\">\n <div class=\"table-header\" *ngIf=\"!config.canAdd || templateData.length > 0 || config.emptyStateView\">\n <div class=\"table-row\">\n <div class=\"table-cell\" *ngFor=\"let header of visibleColumns\">\n {{ header?.i18n | translate }}\n <qd-icon\n *ngIf=\"hasTooltip(header?.tooltip)\"\n icon=\"circleInfo\"\n class=\"additional-info\"\n qdTooltipOnClick\n [qdTooltipContent]=\"header?.tooltip?.content\"\n ></qd-icon>\n </div>\n <div class=\"table-cell actions-column\" *ngIf=\"config?.secondaryActions?.length > 0\">\n <button class=\"menu-button\">\n <qd-icon icon=\"overflowMenuHorizontal\"></qd-icon>\n </button>\n </div>\n </div>\n </div>\n <div class=\"table-body\">\n <div\n class=\"table-row\"\n *qdCustomFor=\"let row of templateData; let rowIndex = index; toggler: togglerDrawing\"\n [formGroupName]=\"rowIndex\"\n >\n <ng-container *ngFor=\"let column of visibleColumns\">\n <div class=\"table-cell\">\n <qd-dropdown\n [config]=\"{\n filter: column.filter,\n options: column.options,\n placeholder: column.placeholder,\n placeholderPrefix: column.placeholderPrefix,\n viewonly: (viewonly$ | async) === true || !column.isEditable(row, column.name)\n }\"\n [data-test-id]=\"column.name + rowIndex\"\n *ngIf=\"column.type === 'enum'; else otherTypes\"\n [dense]=\"true\"\n [formControl]=\"$any(control.controls[rowIndex])?.controls[column.name]\"\n qdFocusable\n class=\"dropdown\"\n >\n </qd-dropdown>\n\n <ng-template #otherTypes>\n <qd-input\n [data-test-id]=\"column.name + rowIndex\"\n [formControlName]=\"column.name\"\n *ngIf=\"column.type !== 'enum' && $any(control.controls[rowIndex])?.controls[column.name]\"\n [config]=\"{\n inputType: column.type === 'integer' ? 'number' : 'text',\n viewonly: (viewonly$ | async) === true || !column.isEditable(row, column.name)\n }\"\n qdFocusable\n ></qd-input>\n </ng-template>\n </div>\n </ng-container>\n <td\n *ngIf=\"config.secondaryActions?.length > 0 || canAdd\"\n class=\"table-cell actions\"\n [attr.data-test-id]=\"testId + '-cell-inline-actions'\"\n >\n <button\n type=\"button\"\n [qdPopoverOnClick]=\"menu\"\n [qdPopoverCloseStrategy]=\"'onEveryClick'\"\n [qdPopoverStopPropagation]=\"true\"\n class=\"menu-button\"\n data-test=\"secondary-actions-toggler\"\n >\n <qd-icon icon=\"overflowMenuHorizontal\"></qd-icon>\n </button>\n\n <ng-template #menu>\n <button\n *ngFor=\"let secondaryAction of actions$ | async\"\n class=\"secondary-actions\"\n [ngClass]=\"{ disabled: isActionDisabled(secondaryAction, row) }\"\n [attr.disabled]=\"isActionDisabled(secondaryAction, row) || null\"\n (click)=\"handleSecondaryAction(secondaryAction, rowIndex)\"\n >\n {{ secondaryAction.label.i18n | translate }}\n </button>\n <button\n *ngIf=\"canAdd && (viewonly$ | async) === false\"\n class=\"secondary-actions\"\n (click)=\"removeRow(rowIndex)\"\n >\n {{ \"i18n.qd.quick.edit.removeButtonLabel\" | translate }}\n </button>\n </ng-template>\n </td>\n </div>\n </div>\n <div class=\"empty-body\" *ngIf=\"config.emptyStateView && !config.emptyStateView.disabled && templateData.length === 0\">\n <p>{{ config.emptyStateView.i18n | translate }}</p>\n </div>\n</div>\n", styles: [".table{display:flex;width:100%;flex-direction:column;margin:1.25rem auto;background-color:#fff;font-size:.875rem}.table ::ng-deep .qd-input-input{margin-bottom:0!important}.table-header .table-row{padding-top:.125rem;padding-bottom:.125rem;background-color:#e5e5e5;font-weight:700}.table-header .table-row .actions-column{flex:0;border-right:none;visibility:hidden}.table-header,.table-body{display:flex;flex-direction:column}.table-row{display:flex;flex-direction:row;padding:.25rem 1rem;border-bottom:.0625rem solid rgb(213,213,213);gap:1rem}.table-row ::ng-deep qd-form-label{display:none!important}.table-row ::ng-deep qd-input{margin-bottom:0!important}.table-cell{display:flex;height:37px;flex:1;align-items:center;text-align:left}.table-cell:has(.qd-input-error),.table-cell:has(.qd-dropdown-error),.table-cell:has(.qd-form-hint){height:auto;align-items:flex-start}.table-cell.actions{flex:0}.table-row:last-child{border-bottom:none}.table-cell:last-child{border-right:none}.editable-actions{display:flex;justify-content:flex-end;margin-right:.625rem;gap:.625rem}.menu-button{display:flex;padding:0 .625rem 0 .375rem;background:unset;color:#454545;font-size:2rem;vertical-align:middle}.menu-button:hover,.menu-button:focus{color:#000;outline:0!important}.secondary-actions{display:block;width:100%;min-height:2rem;padding:0 1rem;background:#fff0;font-size:.75rem;text-align:left}.secondary-actions:hover{background-color:#f2f7fa}.secondary-actions.disabled{color:#b4b4b4;cursor:not-allowed}.secondary-actions.disabled:hover{background-color:#fff0}.dropdown{min-width:160px}.empty-body{padding:1.5rem;background:#fff}.empty-body p{margin:0 0 .5rem}.additional-info{align-self:center;margin-left:.25rem;color:#069;cursor:pointer;font-size:1rem;font-weight:400;transform:translateY(.0625rem)}.additional-info:hover,.additional-info:focus,.additional-info:active{color:#14516f}\n"], dependencies: [{ kind: "component", type: i7.QdButtonComponent, selector: "button[qdButton], a[qdButton], button[qd-button]", inputs: ["disabled", "color", "icon", "data-test-id", "additionalInfo"] }, { kind: "directive", type: i8.QdButtonGhostDirective, selector: "button[qdButtonGhost], a[qdButtonGhost]" }, { kind: "directive", type: i9.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i9.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i9.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i10.QdDropdownComponent, selector: "qd-dropdown", inputs: ["value", "id", "formControlName", "config", "data-test-id", "qdPopoverMaxHeight", "dense"], outputs: ["valueChange", "enterClick", "clickHint", "clickReadonly", "clickViewonly"] }, { kind: "component", type: i11.QdInputComponent, selector: "qd-input", inputs: ["formControlName", "value", "config", "isError", "data-test-id"], outputs: ["valueChange", "enterClick", "clickClear", "clickHint", "clickReadonly", "clickViewonly"] }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: i1.FormGroupName, selector: "[formGroupName]", inputs: ["formGroupName"] }, { kind: "component", type: i12.QdIconComponent, selector: "qd-icon", inputs: ["icon"] }, { kind: "directive", type: i13.QdPopoverOnClickDirective, selector: "[qdPopoverOnClick]", inputs: ["qdPopoverOnClick", "positionStrategy", "qdPopoverCloseStrategy", "qdPopoverDisabled", "qdPopoverStopPropagation", "qdPopoverBackgroundColor", "qdPopoverMaxHeight", "qdPopoverMinWidth", "qdPopoverMaxWidth", "qdPopoverAutoSize", "qdPopoverEnableKeyControl"], outputs: ["opened", "closed"], exportAs: ["qdPopoverOnClick"] }, { kind: "directive", type: i14.QdFocusableDirective, selector: "[qdFocusable]" }, { kind: "directive", type: i15.QdTooltipOnClickDirective, selector: "[qdTooltipOnClick]", inputs: ["qdTooltipContent"] }, { kind: "directive", type: i16.QdCustomForDirective, selector: "[qdCustomFor]", inputs: ["qdCustomForOf", "qdCustomForToggler"] }, { kind: "pipe", type: i9.AsyncPipe, name: "async" }, { kind: "pipe", type: i17.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
354
357
|
}
|
|
355
358
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: QdQuickEditComponent, decorators: [{
|
|
356
359
|
type: Component,
|
|
357
|
-
args: [{ selector: 'qd-quick-edit', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"editable-actions\" *ngIf=\"showStandaloneCreate\">\n <button\n qdButton\n qdButtonGhost\n icon=\"plus\"\n (click)=\"createRow()\"\n [data-test-id]=\"testId + '-button-add-new'\"\n class=\"create-button-standalone\"\n >\n {{ config.standaloneCreateLabel?.i18n ?? \"i18n.qd.quick.edit.createButtonLabel\" | translate }}\n </button>\n</div>\n\n<div class=\"table\" [formGroup]=\"control\">\n <div class=\"table-header\" *ngIf=\"!config.canAdd || templateData.length > 0 || config.emptyStateView\">\n <div class=\"table-row\">\n <div class=\"table-cell\" *ngFor=\"let header of visibleColumns\">\n {{ header?.i18n | translate }}\n <qd-icon\n *ngIf=\"hasTooltip(header?.tooltip)\"\n icon=\"circleInfo\"\n class=\"additional-info\"\n qdTooltipOnClick\n [qdTooltipContent]=\"header?.tooltip?.content\"\n ></qd-icon>\n </div>\n <div class=\"table-cell actions-column\" *ngIf=\"config?.secondaryActions?.length > 0\">\n <button class=\"menu-button\">\n <qd-icon icon=\"overflowMenuHorizontal\"></qd-icon>\n </button>\n </div>\n </div>\n </div>\n <div class=\"table-body\">\n <div\n class=\"table-row\"\n *qdCustomFor=\"let row of templateData; let rowIndex = index; toggler: togglerDrawing\"\n [formGroupName]=\"rowIndex\"\n >\n <ng-container *ngFor=\"let column of visibleColumns\">\n <div class=\"table-cell\">\n <qd-dropdown\n [config]=\"{\n filter: column.filter,\n options: column.options,\n placeholder: column.placeholder,\n placeholderPrefix: column.placeholderPrefix,\n viewonly: (viewonly$ | async) === true || !column.isEditable(row, column.name)\n }\"\n [data-test-id]=\"column.name + rowIndex\"\n *ngIf=\"column.type === 'enum'; else otherTypes\"\n [dense]=\"true\"\n [formControl]=\"$any(control.controls[rowIndex])?.controls[column.name]\"\n qdFocusable\n class=\"dropdown\"\n >\n </qd-dropdown>\n\n <ng-template #otherTypes>\n <qd-input\n [data-test-id]=\"column.name + rowIndex\"\n [formControlName]=\"column.name\"\n *ngIf=\"column.type !== 'enum' && $any(control.controls[rowIndex])?.controls[column.name]\"\n [config]=\"{\n inputType: column.type === 'integer' ? 'number' : 'text',\n viewonly: (viewonly$ | async) === true || !column.isEditable(row, column.name)\n }\"\n qdFocusable\n ></qd-input>\n </ng-template>\n </div>\n </ng-container>\n <td\n *ngIf=\"config.secondaryActions?.length > 0 || canAdd\"\n class=\"table-cell actions\"\n [attr.data-test-id]=\"testId + '-cell-inline-actions'\"\n >\n <button\n type=\"button\"\n [qdPopoverOnClick]=\"menu\"\n [qdPopoverCloseStrategy]=\"'onEveryClick'\"\n [qdPopoverStopPropagation]=\"true\"\n class=\"menu-button\"\n data-test=\"secondary-actions-toggler\"\n >\n <qd-icon icon=\"overflowMenuHorizontal\"></qd-icon>\n </button>\n\n <ng-template #menu>\n <button\n *ngFor=\"let secondaryAction of actions$ | async\"\n class=\"secondary-actions\"\n [ngClass]=\"{ disabled: secondaryAction
|
|
360
|
+
args: [{ selector: 'qd-quick-edit', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"editable-actions\" *ngIf=\"showStandaloneCreate\">\n <button\n qdButton\n qdButtonGhost\n icon=\"plus\"\n (click)=\"createRow()\"\n [data-test-id]=\"testId + '-button-add-new'\"\n class=\"create-button-standalone\"\n >\n {{ config.standaloneCreateLabel?.i18n ?? \"i18n.qd.quick.edit.createButtonLabel\" | translate }}\n </button>\n</div>\n\n<div class=\"table\" [formGroup]=\"control\">\n <div class=\"table-header\" *ngIf=\"!config.canAdd || templateData.length > 0 || config.emptyStateView\">\n <div class=\"table-row\">\n <div class=\"table-cell\" *ngFor=\"let header of visibleColumns\">\n {{ header?.i18n | translate }}\n <qd-icon\n *ngIf=\"hasTooltip(header?.tooltip)\"\n icon=\"circleInfo\"\n class=\"additional-info\"\n qdTooltipOnClick\n [qdTooltipContent]=\"header?.tooltip?.content\"\n ></qd-icon>\n </div>\n <div class=\"table-cell actions-column\" *ngIf=\"config?.secondaryActions?.length > 0\">\n <button class=\"menu-button\">\n <qd-icon icon=\"overflowMenuHorizontal\"></qd-icon>\n </button>\n </div>\n </div>\n </div>\n <div class=\"table-body\">\n <div\n class=\"table-row\"\n *qdCustomFor=\"let row of templateData; let rowIndex = index; toggler: togglerDrawing\"\n [formGroupName]=\"rowIndex\"\n >\n <ng-container *ngFor=\"let column of visibleColumns\">\n <div class=\"table-cell\">\n <qd-dropdown\n [config]=\"{\n filter: column.filter,\n options: column.options,\n placeholder: column.placeholder,\n placeholderPrefix: column.placeholderPrefix,\n viewonly: (viewonly$ | async) === true || !column.isEditable(row, column.name)\n }\"\n [data-test-id]=\"column.name + rowIndex\"\n *ngIf=\"column.type === 'enum'; else otherTypes\"\n [dense]=\"true\"\n [formControl]=\"$any(control.controls[rowIndex])?.controls[column.name]\"\n qdFocusable\n class=\"dropdown\"\n >\n </qd-dropdown>\n\n <ng-template #otherTypes>\n <qd-input\n [data-test-id]=\"column.name + rowIndex\"\n [formControlName]=\"column.name\"\n *ngIf=\"column.type !== 'enum' && $any(control.controls[rowIndex])?.controls[column.name]\"\n [config]=\"{\n inputType: column.type === 'integer' ? 'number' : 'text',\n viewonly: (viewonly$ | async) === true || !column.isEditable(row, column.name)\n }\"\n qdFocusable\n ></qd-input>\n </ng-template>\n </div>\n </ng-container>\n <td\n *ngIf=\"config.secondaryActions?.length > 0 || canAdd\"\n class=\"table-cell actions\"\n [attr.data-test-id]=\"testId + '-cell-inline-actions'\"\n >\n <button\n type=\"button\"\n [qdPopoverOnClick]=\"menu\"\n [qdPopoverCloseStrategy]=\"'onEveryClick'\"\n [qdPopoverStopPropagation]=\"true\"\n class=\"menu-button\"\n data-test=\"secondary-actions-toggler\"\n >\n <qd-icon icon=\"overflowMenuHorizontal\"></qd-icon>\n </button>\n\n <ng-template #menu>\n <button\n *ngFor=\"let secondaryAction of actions$ | async\"\n class=\"secondary-actions\"\n [ngClass]=\"{ disabled: isActionDisabled(secondaryAction, row) }\"\n [attr.disabled]=\"isActionDisabled(secondaryAction, row) || null\"\n (click)=\"handleSecondaryAction(secondaryAction, rowIndex)\"\n >\n {{ secondaryAction.label.i18n | translate }}\n </button>\n <button\n *ngIf=\"canAdd && (viewonly$ | async) === false\"\n class=\"secondary-actions\"\n (click)=\"removeRow(rowIndex)\"\n >\n {{ \"i18n.qd.quick.edit.removeButtonLabel\" | translate }}\n </button>\n </ng-template>\n </td>\n </div>\n </div>\n <div class=\"empty-body\" *ngIf=\"config.emptyStateView && !config.emptyStateView.disabled && templateData.length === 0\">\n <p>{{ config.emptyStateView.i18n | translate }}</p>\n </div>\n</div>\n", styles: [".table{display:flex;width:100%;flex-direction:column;margin:1.25rem auto;background-color:#fff;font-size:.875rem}.table ::ng-deep .qd-input-input{margin-bottom:0!important}.table-header .table-row{padding-top:.125rem;padding-bottom:.125rem;background-color:#e5e5e5;font-weight:700}.table-header .table-row .actions-column{flex:0;border-right:none;visibility:hidden}.table-header,.table-body{display:flex;flex-direction:column}.table-row{display:flex;flex-direction:row;padding:.25rem 1rem;border-bottom:.0625rem solid rgb(213,213,213);gap:1rem}.table-row ::ng-deep qd-form-label{display:none!important}.table-row ::ng-deep qd-input{margin-bottom:0!important}.table-cell{display:flex;height:37px;flex:1;align-items:center;text-align:left}.table-cell:has(.qd-input-error),.table-cell:has(.qd-dropdown-error),.table-cell:has(.qd-form-hint){height:auto;align-items:flex-start}.table-cell.actions{flex:0}.table-row:last-child{border-bottom:none}.table-cell:last-child{border-right:none}.editable-actions{display:flex;justify-content:flex-end;margin-right:.625rem;gap:.625rem}.menu-button{display:flex;padding:0 .625rem 0 .375rem;background:unset;color:#454545;font-size:2rem;vertical-align:middle}.menu-button:hover,.menu-button:focus{color:#000;outline:0!important}.secondary-actions{display:block;width:100%;min-height:2rem;padding:0 1rem;background:#fff0;font-size:.75rem;text-align:left}.secondary-actions:hover{background-color:#f2f7fa}.secondary-actions.disabled{color:#b4b4b4;cursor:not-allowed}.secondary-actions.disabled:hover{background-color:#fff0}.dropdown{min-width:160px}.empty-body{padding:1.5rem;background:#fff}.empty-body p{margin:0 0 .5rem}.additional-info{align-self:center;margin-left:.25rem;color:#069;cursor:pointer;font-size:1rem;font-weight:400;transform:translateY(.0625rem)}.additional-info:hover,.additional-info:focus,.additional-info:active{color:#14516f}\n"] }]
|
|
358
361
|
}], ctorParameters: () => [{ type: i1.FormBuilder }, { type: i2.QdPageFooterService, decorators: [{
|
|
359
362
|
type: Optional
|
|
360
363
|
}] }, { type: i3.QdPageStoreService, decorators: [{
|
|
@@ -388,4 +391,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImpor
|
|
|
388
391
|
type: ViewChild,
|
|
389
392
|
args: [QdCustomForDirective]
|
|
390
393
|
}] } });
|
|
391
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"quick-edit.component.js","sourceRoot":"","sources":["../../../../../libs/qd-ui/src/lib/quick-edit/quick-edit.component.ts","../../../../../libs/qd-ui/src/lib/quick-edit/quick-edit.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  QueryList,\n  Self,\n  SimpleChanges,\n  Type,\n  ViewChild,\n  ViewChildren\n} from '@angular/core';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { ControlContainer, FormArray, FormBuilder, FormGroup } from '@angular/forms';\nimport { combineLatest, filter, Observable, of, Subject, takeUntil } from 'rxjs';\nimport { distinctUntilChanged, map, startWith, tap } from 'rxjs/operators';\n\nimport { QdContainerActionService } from '../container/services/container-action.service';\nimport { COMPONENT_MAP } from '../core/data-facets/data-facets.model';\nimport { QdFocusableDirective } from '../core/focusable/focusable.directive';\nimport { QdEventBrokerService } from '../core/services/event-broker.service';\nimport { QdFormControl } from '../forms/qd-form.module';\nimport { QdPageFooterService } from '../page/shared/services/page-footer.service';\nimport { QdPageStoreService } from '../page/shared/services/page-store.service';\nimport { QdSectionToolbarActionService } from '../section/services/section-toolbar-action.service';\nimport { QdQuickEditColumn, QdQuickEditConfig, QdQuickEditSecondaryAction } from './model/quick-edit-config';\nimport { QdQuickEditData, QdQuickEditDataValue, QdQuickEditRow } from './model/quick-edit-data';\nimport { QdCustomForDirective } from './qd-ng-for.directive';\nimport { QdTooltip } from '../forms/model/forms.interface';\n\n/**\n * The **QdQuickEditComponent** is a dynamic tool that enables users to swiftly edit data without the need for traditional forms.\n * It is specifically designed for inline editing, providing a more seamless and efficient user experience.\n * The component currently supports editing columns with data types such as string, number, and enum.\n * In addition to its editing capabilities, the QdQuickEditComponent also offers features for adding new rows and deleting existing ones.\n *\n * QuickEdit supports two modes:\n * - **Reactive Forms Mode** via `formArrayName` – recommended for full control and validation.\n * - **Template Data Mode** via `data` input – for use cases without external forms.\n *\n * ### Usage\n *\n * #### Configuration\n *\n * ```ts\n * type ColumnDefinition = 'rubrik' | 'data' | 'status';\n * const config: QdQuickEditConfig<ColumnDefinition> = {\n *   columns: [\n *     {\n *       name: 'rubrik',\n *       type: 'text',\n *       i18n: 'translation.key.rubrik',\n *       isEditable: () => false\n *     },\n *     {\n *       name: 'data',\n *       type: 'integer',\n *       i18n: 'translation.key.data',\n *       isEditable: (row, column) => !!row['rubrik'],\n *       validators: [Validators.required] // only relevant in template data mode\n *     }\n *   ],\n *   canAdd: true,\n *   secondaryActions: [...]\n * }\n * ```\n *\n * #### FormArray (recommended)\n *\n * To use QuickEdit with Angular Reactive Forms, define a FormGroup containing a FormArray. The controls must match the defined columns.\n *\n * ```ts\n * form = new FormGroup({\n *   data: new FormArray([\n *     new FormGroup({\n *       rubrik: new QdFormControl('Text'),\n *       data: new QdFormControl(123)\n *     })\n *   ])\n * })\n * ```\n *\n * Then bind the `formArrayName` directive in the template:\n *\n * ```html\n * <form [formGroup]=\"form\">\n *   <qd-quick-edit [config]=\"config\" formArrayName=\"data\"></qd-quick-edit>\n * </form>\n * ```\n *\n * You can add new rows by reacting to `(addNewClicked)`:\n *\n * ```ts\n * addControl(): void {\n *   this.form.get('data')?.insert(0, new FormGroup({ ... }));\n * }\n * ```\n *\n * #### Template Data (optional)\n *\n * Alternatively, you can provide a static `data` array. This is useful for read-only scenarios without reactive forms.\n *\n * ```ts\n * const data: QdQuickEditData<MyColumns> = [\n *   { rubrik: 'Foo', data: 42 },\n *   { rubrik: 'Bar', data: 77 }\n * ];\n * ```\n *\n * ```html\n * <qd-quick-edit [config]=\"config\" [data]=\"data\"></qd-quick-edit>\n * ```\n *\n * #### Validation\n *\n * - In **FormArray mode**, validators must be set directly on your FormControls. Validators in `config.columns` are ignored.\n * - In **template data mode**, validators defined in `config.columns` are applied.\n *\n * **Note: Do not combine both approaches. When using `formArrayName`, only the external FormGroup is used for validation and value access.**\n */\n@Component({\n  selector: 'qd-quick-edit',\n  templateUrl: 'quick-edit.component.html',\n  styleUrls: ['quick-edit.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class QdQuickEditComponent<T extends string> implements OnInit, OnChanges, OnDestroy {\n  /**\n   * Configuration of the QuickEdit. The generic type specifies the column definition. <br />\n   *\n   * **Usage:**\n   *\n   * @example\n   * type ColumnDefinition = 'article' | 'mass' | 'documents';\n   * const config: QdQuickEditConfig<ColumnDefinition> = {\n   *   columns: [\n   *     {\n   *       name: 'rubrik',\n   *       type: 'text',\n   *       i18n: 'translation.key.rubrik',\n   *       isEditable: () => false\n   *     },\n   *     {\n   *       name: 'data',\n   *       type: 'integer',\n   *       i18n: 'translation.key.data',\n   *       isEditable: (row, column) => row['active'] == 1,\n   *       validators: [Validators.required]\n   *     },\n   *     {\n   *       name: 'size',\n   *       type: 'boolean',\n   *       i18n: 'translation.key.size',\n   *       validators: [customValidatorFunction()]\n   *     }\n   *   ]\n   * }\n   */\n  @Input({ required: true }) config!: QdQuickEditConfig<T>;\n\n  /**\n   * Data provider for QuickEdit.\n   */\n  @Input() data: QdQuickEditData<T> | undefined;\n\n  get templateData(): QdQuickEditData<T> {\n    return this.controlContainer?.control?.value ?? this.data;\n  }\n\n  get templateData$(): Observable<QdQuickEditData<T>> {\n    return (\n      this.controlContainer?.control?.valueChanges.pipe(startWith(this.controlContainer.control.value)) ?? of(this.data)\n    );\n  }\n\n  /**\n   * A static test ID for integration tests can be set. <br />\n   * The value for the HTML attribute [data-test-id].\n   */\n  @Input('data-test-id')\n  testId?: string;\n\n  /**\n   * The form group instance of QdQuickEdit.\n   * Use this form group to bind it to step-control of QdStepper or other custom logics.\n   */\n  @Output() formGroupChange = new EventEmitter<any>();\n\n  @Output() addNewClicked = new EventEmitter<void>();\n\n  @ViewChildren(QdFocusableDirective)\n  focusables: QueryList<QdFocusableDirective> | undefined;\n\n  @ViewChild(QdCustomForDirective)\n  customForDirective!: QdCustomForDirective;\n\n  quickEditFormGroup!: FormGroup;\n  viewonly$: Observable<boolean> = of(false);\n  actions$!: Observable<QdQuickEditSecondaryAction<T>[]>;\n\n  private _destroyed$ = new Subject<void>();\n\n  get control(): FormGroup {\n    return (this.controlContainer?.control ?? this.quickEditFormGroup.get('rows')) as FormGroup;\n  }\n\n  get showStandaloneCreate(): boolean {\n    return !this.containerActionService && !this.sectionActionService && this.config.canAdd;\n  }\n\n  get canAdd(): boolean {\n    return this.config.canAdd ?? this.sectionActionService != null;\n  }\n\n  get rows(): FormArray {\n    return this.quickEditFormGroup.get('rows') as FormArray;\n  }\n\n  get visibleColumns(): QdQuickEditColumn<T>[] {\n    return this.config.columns.filter(column => !column.isHidden);\n  }\n\n  get isFormControl(): boolean {\n    return this.controlContainer != null;\n  }\n\n  togglerDrawing = false;\n\n  constructor(\n    private fb: FormBuilder,\n    @Optional() readonly footerService: QdPageFooterService,\n    @Optional() readonly pageService: QdPageStoreService<any>,\n    @Optional() private readonly sectionActionService: QdSectionToolbarActionService,\n    @Optional() private readonly containerActionService: QdContainerActionService,\n    @Optional() private readonly eventBrokerService: QdEventBrokerService,\n    private changeDetectorRef: ChangeDetectorRef,\n    @Optional() @Self() private controlContainer: ControlContainer\n  ) {\n    if (!this.isFormControl) {\n      this.quickEditFormGroup = this.fb.group({\n        rows: this.fb.array([])\n      });\n\n      this.quickEditFormGroup.valueChanges.pipe(takeUntilDestroyed()).subscribe(() => {\n        this.formGroupChange.emit(this.quickEditFormGroup);\n      });\n    }\n  }\n\n  ngOnInit(): void {\n    this.validateSetup();\n    this.initOpModeSubscription();\n    this.initCreating();\n    this.initActionsStream();\n    this.initManualChangeDetectionForControlReset();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['data'] || changes['config']) this.initRows();\n  }\n\n  ngOnDestroy(): void {\n    this._destroyed$.next();\n    this._destroyed$.complete();\n  }\n\n  handleSecondaryAction(action: QdQuickEditSecondaryAction<T>, rowIndex: number): void {\n    if (!action) return;\n\n    const selectedRowData =\n      (this.controlContainer?.control as FormArray)?.controls[rowIndex].value ?? this.rows.value[rowIndex];\n    action.handler(selectedRowData);\n  }\n\n  getComponentType(column: QdQuickEditColumn<T>): Type<unknown> | null {\n    return COMPONENT_MAP[column.type] || null;\n  }\n\n  getComponentInputs(column: QdQuickEditColumn<T>, row: QdQuickEditRow<T>): any {\n    const testId = this.testId && this.testId + '-cell-' + column.name;\n\n    if (column.type === 'enum')\n      return {\n        data: column.options?.find(option => option.value === row[column.name])?.i18n,\n        testId\n      };\n\n    return { data: row[column.name], testId };\n  }\n\n  createRow(): void {\n    this.redrawOnNextChange();\n\n    if (this.controlContainer) {\n      this.addNewClicked.next();\n    } else {\n      const formGroup = Object.assign(\n        {},\n        ...this.config.columns.map(column => ({\n          [column.name]: new QdFormControl<QdQuickEditDataValue>(undefined, column.validators)\n        }))\n      );\n\n      this.rows.insert(0, new FormGroup(formGroup));\n\n      if (!this.data) this.data = [];\n\n      this.data.unshift(\n        Object.assign({}, ...this.config.columns.map(column => ({ [column.name]: null }))) as QdQuickEditRow<T>\n      );\n    }\n\n    this.changeDetectorRef.detectChanges();\n\n    window.setTimeout(() => this.focusFirstControl());\n  }\n\n  removeRow(index: number): void {\n    this.redrawOnNextChange();\n\n    if (this.controlContainer) {\n      (this.controlContainer.control as FormArray).removeAt(index);\n      this.controlContainer.control?.setValue(this.controlContainer.value);\n    } else {\n      this.rows.removeAt(index);\n      this.data?.splice(index, 1);\n    }\n  }\n\n  hasTooltip(tooltip: QdTooltip): boolean {\n    return !!tooltip && !tooltip.hidden;\n  }\n\n  private initRows(): void {\n    if (this.controlContainer) return;\n\n    while (this.rows.length) {\n      this.rows.removeAt(0);\n    }\n\n    this.data?.forEach(row => this.createFormGroupRow(row));\n  }\n\n  private initCreating(): void {\n    if (this.containerActionService)\n      this.containerActionService.action$.pipe(takeUntil(this._destroyed$)).subscribe(() => this.createRow());\n\n    if (this.sectionActionService)\n      this.sectionActionService.action$\n        .pipe(\n          takeUntil(this._destroyed$),\n          filter(type => type === 'addNew')\n        )\n        .subscribe(() => this.createRow());\n  }\n\n  private createFormGroupRow(row: QdQuickEditRow<T>): void {\n    const group: any = {};\n\n    this.config.columns.forEach(column => {\n      group[column.name] = new QdFormControl<QdQuickEditDataValue>(row[column.name], column.validators);\n    });\n\n    const form = new FormGroup(group);\n    this.rows.push(form);\n  }\n\n  private focusFirstControl(): void {\n    if (!this.focusables) return;\n\n    this.focusables.first?.focus();\n  }\n\n  private initOpModeSubscription(): void {\n    this.viewonly$ =\n      typeof this.config.viewonly === 'boolean'\n        ? of(this.config.viewonly)\n        : this.eventBrokerService?.consume<{ isViewonly: boolean }>('operation_mode_changed').pipe(\n            map(e => e.payload.isViewonly),\n            startWith(false)\n          ) ?? of(false);\n  }\n\n  private validateSetup(): void {\n    if (this.data != null && this.controlContainer != null)\n      console.warn('QdQuickEdit | Data is being ignored when used as FormArray');\n\n    if (!this.data && !this.controlContainer)\n      console.warn(\n        'QdQuickEdit | Either use QuickEdit as FormControl with formArrayName binding or provide data via input.'\n      );\n\n    if (this.controlContainer && this.config.columns.some(column => column.validators != null))\n      console.warn(\n        'QdQuickEdit | Please provide validators in the specific FormControls directly for default validators to be added.'\n      );\n  }\n\n  private redrawOnNextChange(): void {\n    this.togglerDrawing = !this.togglerDrawing;\n  }\n\n  private initActionsStream(): void {\n    this.actions$ = combineLatest([of(this.config.secondaryActions ?? []), this.viewonly$]).pipe(\n      map(([actions, isViewonly]) => this.filterActionsByMode(actions, isViewonly))\n    );\n  }\n\n  private filterActionsByMode(\n    actions: QdQuickEditSecondaryAction<T>[],\n    isViewonly: boolean\n  ): QdQuickEditSecondaryAction<T>[] {\n    const currentMode = isViewonly ? 'view' : 'edit';\n\n    return actions.filter(action => !action.operationMode || action.operationMode === currentMode);\n  }\n\n  private initManualChangeDetectionForControlReset(): void {\n    if (!this.isFormControl) return;\n\n    this.controlContainer.control.valueChanges\n      .pipe(\n        startWith(this.controlContainer.control.value.length),\n        map(() => this.controlContainer.control.value.length),\n        distinctUntilChanged(),\n        tap(() => this.changeDetectorRef.detectChanges())\n      )\n      .subscribe();\n  }\n}\n","<div class=\"editable-actions\" *ngIf=\"showStandaloneCreate\">\n  <button\n    qdButton\n    qdButtonGhost\n    icon=\"plus\"\n    (click)=\"createRow()\"\n    [data-test-id]=\"testId + '-button-add-new'\"\n    class=\"create-button-standalone\"\n  >\n    {{ config.standaloneCreateLabel?.i18n ?? \"i18n.qd.quick.edit.createButtonLabel\" | translate }}\n  </button>\n</div>\n\n<div class=\"table\" [formGroup]=\"control\">\n  <div class=\"table-header\" *ngIf=\"!config.canAdd || templateData.length > 0 || config.emptyStateView\">\n    <div class=\"table-row\">\n      <div class=\"table-cell\" *ngFor=\"let header of visibleColumns\">\n        {{ header?.i18n | translate }}\n        <qd-icon\n          *ngIf=\"hasTooltip(header?.tooltip)\"\n          icon=\"circleInfo\"\n          class=\"additional-info\"\n          qdTooltipOnClick\n          [qdTooltipContent]=\"header?.tooltip?.content\"\n        ></qd-icon>\n      </div>\n      <div class=\"table-cell actions-column\" *ngIf=\"config?.secondaryActions?.length > 0\">\n        <button class=\"menu-button\">\n          <qd-icon icon=\"overflowMenuHorizontal\"></qd-icon>\n        </button>\n      </div>\n    </div>\n  </div>\n  <div class=\"table-body\">\n    <div\n      class=\"table-row\"\n      *qdCustomFor=\"let row of templateData; let rowIndex = index; toggler: togglerDrawing\"\n      [formGroupName]=\"rowIndex\"\n    >\n      <ng-container *ngFor=\"let column of visibleColumns\">\n        <div class=\"table-cell\">\n          <qd-dropdown\n            [config]=\"{\n              filter: column.filter,\n              options: column.options,\n              placeholder: column.placeholder,\n              placeholderPrefix: column.placeholderPrefix,\n              viewonly: (viewonly$ | async) === true || !column.isEditable(row, column.name)\n            }\"\n            [data-test-id]=\"column.name + rowIndex\"\n            *ngIf=\"column.type === 'enum'; else otherTypes\"\n            [dense]=\"true\"\n            [formControl]=\"$any(control.controls[rowIndex])?.controls[column.name]\"\n            qdFocusable\n            class=\"dropdown\"\n          >\n          </qd-dropdown>\n\n          <ng-template #otherTypes>\n            <qd-input\n              [data-test-id]=\"column.name + rowIndex\"\n              [formControlName]=\"column.name\"\n              *ngIf=\"column.type !== 'enum' && $any(control.controls[rowIndex])?.controls[column.name]\"\n              [config]=\"{\n                inputType: column.type === 'integer' ? 'number' : 'text',\n                viewonly: (viewonly$ | async) === true || !column.isEditable(row, column.name)\n              }\"\n              qdFocusable\n            ></qd-input>\n          </ng-template>\n        </div>\n      </ng-container>\n      <td\n        *ngIf=\"config.secondaryActions?.length > 0 || canAdd\"\n        class=\"table-cell actions\"\n        [attr.data-test-id]=\"testId + '-cell-inline-actions'\"\n      >\n        <button\n          type=\"button\"\n          [qdPopoverOnClick]=\"menu\"\n          [qdPopoverCloseStrategy]=\"'onEveryClick'\"\n          [qdPopoverStopPropagation]=\"true\"\n          class=\"menu-button\"\n          data-test=\"secondary-actions-toggler\"\n        >\n          <qd-icon icon=\"overflowMenuHorizontal\"></qd-icon>\n        </button>\n\n        <ng-template #menu>\n          <button\n            *ngFor=\"let secondaryAction of actions$ | async\"\n            class=\"secondary-actions\"\n            [ngClass]=\"{ disabled: secondaryAction.isDisabled }\"\n            (click)=\"handleSecondaryAction(secondaryAction, rowIndex)\"\n          >\n            {{ secondaryAction.label.i18n | translate }}\n          </button>\n          <button\n            *ngIf=\"canAdd && (viewonly$ | async) === false\"\n            class=\"secondary-actions\"\n            (click)=\"removeRow(rowIndex)\"\n          >\n            {{ \"i18n.qd.quick.edit.removeButtonLabel\" | translate }}\n          </button>\n        </ng-template>\n      </td>\n    </div>\n  </div>\n  <div class=\"empty-body\" *ngIf=\"config.emptyStateView && !config.emptyStateView.disabled && templateData.length === 0\">\n    <p>{{ config.emptyStateView.i18n | translate }}</p>\n  </div>\n</div>\n"]}
|
|
394
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"quick-edit.component.js","sourceRoot":"","sources":["../../../../../libs/qd-ui/src/lib/quick-edit/quick-edit.component.ts","../../../../../libs/qd-ui/src/lib/quick-edit/quick-edit.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  QueryList,\n  Self,\n  SimpleChanges,\n  Type,\n  ViewChild,\n  ViewChildren\n} from '@angular/core';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { ControlContainer, FormArray, FormBuilder, FormGroup } from '@angular/forms';\nimport { combineLatest, filter, Observable, of, Subject, takeUntil } from 'rxjs';\nimport { distinctUntilChanged, map, startWith, tap } from 'rxjs/operators';\n\nimport { QdContainerActionService } from '../container/services/container-action.service';\nimport { COMPONENT_MAP } from '../core/data-facets/data-facets.model';\nimport { QdFocusableDirective } from '../core/focusable/focusable.directive';\nimport { QdEventBrokerService } from '../core/services/event-broker.service';\nimport { QdTooltip } from '../forms/model/forms.interface';\nimport { QdFormControl } from '../forms/qd-form.module';\nimport { QdPageFooterService } from '../page/shared/services/page-footer.service';\nimport { QdPageStoreService } from '../page/shared/services/page-store.service';\nimport { QdSectionToolbarActionService } from '../section/services/section-toolbar-action.service';\nimport { QdQuickEditColumn, QdQuickEditConfig, QdQuickEditSecondaryAction } from './model/quick-edit-config';\nimport { QdQuickEditData, QdQuickEditDataValue, QdQuickEditRow } from './model/quick-edit-data';\nimport { QdCustomForDirective } from './qd-ng-for.directive';\n\n/**\n * The **QdQuickEditComponent** is a dynamic tool that enables users to swiftly edit data without the need for traditional forms.\n * It is specifically designed for inline editing, providing a more seamless and efficient user experience.\n * The component currently supports editing columns with data types such as string, number, and enum.\n * In addition to its editing capabilities, the QdQuickEditComponent also offers features for adding new rows and deleting existing ones.\n *\n * QuickEdit supports two modes:\n * - **Reactive Forms Mode** via `formArrayName` – recommended for full control and validation.\n * - **Template Data Mode** via `data` input – for use cases without external forms.\n *\n * ### Usage\n *\n * #### Configuration\n *\n * ```ts\n * type ColumnDefinition = 'rubrik' | 'data' | 'status';\n * const config: QdQuickEditConfig<ColumnDefinition> = {\n *   columns: [\n *     {\n *       name: 'rubrik',\n *       type: 'text',\n *       i18n: 'translation.key.rubrik',\n *       isEditable: () => false\n *     },\n *     {\n *       name: 'data',\n *       type: 'integer',\n *       i18n: 'translation.key.data',\n *       isEditable: (row, column) => !!row['rubrik'],\n *       validators: [Validators.required] // only relevant in template data mode\n *     }\n *   ],\n *   canAdd: true,\n *   secondaryActions: [...]\n * }\n * ```\n *\n * #### FormArray (recommended)\n *\n * To use QuickEdit with Angular Reactive Forms, define a FormGroup containing a FormArray. The controls must match the defined columns.\n *\n * ```ts\n * form = new FormGroup({\n *   data: new FormArray([\n *     new FormGroup({\n *       rubrik: new QdFormControl('Text'),\n *       data: new QdFormControl(123)\n *     })\n *   ])\n * })\n * ```\n *\n * Then bind the `formArrayName` directive in the template:\n *\n * ```html\n * <form [formGroup]=\"form\">\n *   <qd-quick-edit [config]=\"config\" formArrayName=\"data\"></qd-quick-edit>\n * </form>\n * ```\n *\n * You can add new rows by reacting to `(addNewClicked)`:\n *\n * ```ts\n * addControl(): void {\n *   this.form.get('data')?.insert(0, new FormGroup({ ... }));\n * }\n * ```\n *\n * #### Template Data (optional)\n *\n * Alternatively, you can provide a static `data` array. This is useful for read-only scenarios without reactive forms.\n *\n * ```ts\n * const data: QdQuickEditData<MyColumns> = [\n *   { rubrik: 'Foo', data: 42 },\n *   { rubrik: 'Bar', data: 77 }\n * ];\n * ```\n *\n * ```html\n * <qd-quick-edit [config]=\"config\" [data]=\"data\"></qd-quick-edit>\n * ```\n *\n * #### Validation\n *\n * - In **FormArray mode**, validators must be set directly on your FormControls. Validators in `config.columns` are ignored.\n * - In **template data mode**, validators defined in `config.columns` are applied.\n *\n * **Note: Do not combine both approaches. When using `formArrayName`, only the external FormGroup is used for validation and value access.**\n */\n@Component({\n  selector: 'qd-quick-edit',\n  templateUrl: 'quick-edit.component.html',\n  styleUrls: ['quick-edit.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class QdQuickEditComponent<T extends string> implements OnInit, OnChanges, OnDestroy {\n  /**\n   * Configuration of the QuickEdit. The generic type specifies the column definition. <br />\n   *\n   * **Usage:**\n   *\n   * @example\n   * type ColumnDefinition = 'article' | 'mass' | 'documents';\n   * const config: QdQuickEditConfig<ColumnDefinition> = {\n   *   columns: [\n   *     {\n   *       name: 'rubrik',\n   *       type: 'text',\n   *       i18n: 'translation.key.rubrik',\n   *       isEditable: () => false\n   *     },\n   *     {\n   *       name: 'data',\n   *       type: 'integer',\n   *       i18n: 'translation.key.data',\n   *       isEditable: (row, column) => row['active'] == 1,\n   *       validators: [Validators.required]\n   *     },\n   *     {\n   *       name: 'size',\n   *       type: 'boolean',\n   *       i18n: 'translation.key.size',\n   *       validators: [customValidatorFunction()]\n   *     }\n   *   ]\n   * }\n   */\n  @Input({ required: true }) config!: QdQuickEditConfig<T>;\n\n  /**\n   * Data provider for QuickEdit.\n   */\n  @Input() data: QdQuickEditData<T> | undefined;\n\n  get templateData(): QdQuickEditData<T> {\n    return this.controlContainer?.control?.value ?? this.data;\n  }\n\n  get templateData$(): Observable<QdQuickEditData<T>> {\n    return (\n      this.controlContainer?.control?.valueChanges.pipe(startWith(this.controlContainer.control.value)) ?? of(this.data)\n    );\n  }\n\n  /**\n   * A static test ID for integration tests can be set. <br />\n   * The value for the HTML attribute [data-test-id].\n   */\n  @Input('data-test-id')\n  testId?: string;\n\n  /**\n   * The form group instance of QdQuickEdit.\n   * Use this form group to bind it to step-control of QdStepper or other custom logics.\n   */\n  @Output() formGroupChange = new EventEmitter<any>();\n\n  @Output() addNewClicked = new EventEmitter<void>();\n\n  @ViewChildren(QdFocusableDirective)\n  focusables: QueryList<QdFocusableDirective> | undefined;\n\n  @ViewChild(QdCustomForDirective)\n  customForDirective!: QdCustomForDirective;\n\n  quickEditFormGroup!: FormGroup;\n  viewonly$: Observable<boolean> = of(false);\n  actions$!: Observable<QdQuickEditSecondaryAction<T>[]>;\n\n  private _destroyed$ = new Subject<void>();\n\n  get control(): FormGroup {\n    return (this.controlContainer?.control ?? this.quickEditFormGroup.get('rows')) as FormGroup;\n  }\n\n  get showStandaloneCreate(): boolean {\n    return !this.containerActionService && !this.sectionActionService && !!this.config.canAdd;\n  }\n\n  get canAdd(): boolean {\n    return this.config.canAdd ?? this.sectionActionService != null;\n  }\n\n  get rows(): FormArray {\n    return this.quickEditFormGroup.get('rows') as FormArray;\n  }\n\n  get visibleColumns(): QdQuickEditColumn<T>[] {\n    return this.config.columns.filter(column => !column.isHidden);\n  }\n\n  get isFormControl(): boolean {\n    return this.controlContainer != null;\n  }\n\n  togglerDrawing = false;\n\n  constructor(\n    private fb: FormBuilder,\n    @Optional() readonly footerService: QdPageFooterService,\n    @Optional() readonly pageService: QdPageStoreService<any>,\n    @Optional() private readonly sectionActionService: QdSectionToolbarActionService,\n    @Optional() private readonly containerActionService: QdContainerActionService,\n    @Optional() private readonly eventBrokerService: QdEventBrokerService,\n    private changeDetectorRef: ChangeDetectorRef,\n    @Optional() @Self() private controlContainer: ControlContainer\n  ) {\n    if (!this.isFormControl) {\n      this.quickEditFormGroup = this.fb.group({\n        rows: this.fb.array([])\n      });\n\n      this.quickEditFormGroup.valueChanges.pipe(takeUntilDestroyed()).subscribe(() => {\n        this.formGroupChange.emit(this.quickEditFormGroup);\n      });\n    }\n  }\n\n  ngOnInit(): void {\n    this.validateSetup();\n    this.initOpModeSubscription();\n    this.initCreating();\n    this.initActionsStream();\n    this.initManualChangeDetectionForControlReset();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['data'] || changes['config']) this.initRows();\n  }\n\n  ngOnDestroy(): void {\n    this._destroyed$.next();\n    this._destroyed$.complete();\n  }\n\n  isActionDisabled(action: QdQuickEditSecondaryAction<T>, row: QdQuickEditRow<T>): boolean {\n    if (typeof action.isDisabled === 'function') return action.isDisabled(row);\n    return !!action.isDisabled;\n  }\n\n  handleSecondaryAction(action: QdQuickEditSecondaryAction<T>, rowIndex: number): void {\n    if (!action) return;\n\n    const selectedRowData =\n      (this.controlContainer?.control as FormArray)?.controls[rowIndex].value ?? this.rows.value[rowIndex];\n    action.handler(selectedRowData);\n  }\n\n  getComponentType(column: QdQuickEditColumn<T>): Type<unknown> | null {\n    return COMPONENT_MAP[column.type] || null;\n  }\n\n  getComponentInputs(column: QdQuickEditColumn<T>, row: QdQuickEditRow<T>): any {\n    const testId = this.testId && this.testId + '-cell-' + column.name;\n\n    if (column.type === 'enum')\n      return {\n        data: column.options?.find(option => option.value === row[column.name])?.i18n,\n        testId\n      };\n\n    return { data: row[column.name], testId };\n  }\n\n  createRow(): void {\n    this.redrawOnNextChange();\n\n    if (this.controlContainer) {\n      this.addNewClicked.next();\n    } else {\n      const formGroup = Object.assign(\n        {},\n        ...this.config.columns.map(column => ({\n          [column.name]: new QdFormControl<QdQuickEditDataValue>(undefined, column.validators)\n        }))\n      );\n\n      this.rows.insert(0, new FormGroup(formGroup));\n\n      if (!this.data) this.data = [];\n\n      this.data.unshift(\n        Object.assign({}, ...this.config.columns.map(column => ({ [column.name]: null }))) as QdQuickEditRow<T>\n      );\n    }\n\n    this.changeDetectorRef.detectChanges();\n\n    window.setTimeout(() => this.focusFirstControl());\n  }\n\n  removeRow(index: number): void {\n    this.redrawOnNextChange();\n\n    if (this.controlContainer) {\n      (this.controlContainer.control as FormArray).removeAt(index);\n      this.controlContainer.control?.setValue(this.controlContainer.value);\n    } else {\n      this.rows.removeAt(index);\n      this.data?.splice(index, 1);\n    }\n  }\n\n  hasTooltip(tooltip: QdTooltip): boolean {\n    return !!tooltip && !tooltip.hidden;\n  }\n\n  private initRows(): void {\n    if (this.controlContainer) return;\n\n    while (this.rows.length) {\n      this.rows.removeAt(0);\n    }\n\n    this.data?.forEach(row => this.createFormGroupRow(row));\n  }\n\n  private initCreating(): void {\n    if (this.containerActionService)\n      this.containerActionService.action$.pipe(takeUntil(this._destroyed$)).subscribe(() => this.createRow());\n\n    if (this.sectionActionService)\n      this.sectionActionService.action$\n        .pipe(\n          takeUntil(this._destroyed$),\n          filter(type => type === 'addNew')\n        )\n        .subscribe(() => this.createRow());\n  }\n\n  private createFormGroupRow(row: QdQuickEditRow<T>): void {\n    const group: any = {};\n\n    this.config.columns.forEach(column => {\n      group[column.name] = new QdFormControl<QdQuickEditDataValue>(row[column.name], column.validators);\n    });\n\n    const form = new FormGroup(group);\n    this.rows.push(form);\n  }\n\n  private focusFirstControl(): void {\n    if (!this.focusables) return;\n\n    this.focusables.first?.focus();\n  }\n\n  private initOpModeSubscription(): void {\n    this.viewonly$ =\n      typeof this.config.viewonly === 'boolean'\n        ? of(this.config.viewonly)\n        : this.eventBrokerService?.consume<{ isViewonly: boolean }>('operation_mode_changed').pipe(\n            map(e => e.payload.isViewonly),\n            startWith(false)\n          ) ?? of(false);\n  }\n\n  private validateSetup(): void {\n    if (this.data != null && this.controlContainer != null)\n      console.warn('QdQuickEdit | Data is being ignored when used as FormArray');\n\n    if (!this.data && !this.controlContainer)\n      console.warn(\n        'QdQuickEdit | Either use QuickEdit as FormControl with formArrayName binding or provide data via input.'\n      );\n\n    if (this.controlContainer && this.config.columns.some(column => column.validators != null))\n      console.warn(\n        'QdQuickEdit | Please provide validators in the specific FormControls directly for default validators to be added.'\n      );\n  }\n\n  private redrawOnNextChange(): void {\n    this.togglerDrawing = !this.togglerDrawing;\n  }\n\n  private initActionsStream(): void {\n    this.actions$ = combineLatest([of(this.config.secondaryActions ?? []), this.viewonly$]).pipe(\n      map(([actions, isViewonly]) => this.filterActionsByMode(actions, isViewonly))\n    );\n  }\n\n  private filterActionsByMode(\n    actions: QdQuickEditSecondaryAction<T>[],\n    isViewonly: boolean\n  ): QdQuickEditSecondaryAction<T>[] {\n    const currentMode = isViewonly ? 'view' : 'edit';\n\n    return actions.filter(action => !action.operationMode || action.operationMode === currentMode);\n  }\n\n  private initManualChangeDetectionForControlReset(): void {\n    if (!this.isFormControl) return;\n\n    this.controlContainer!.control!.valueChanges.pipe(\n      startWith(this.controlContainer!.control!.value.length),\n      map(() => this.controlContainer!.control!.value.length),\n      distinctUntilChanged(),\n      tap(() => this.changeDetectorRef.detectChanges())\n    ).subscribe();\n  }\n}\n","<div class=\"editable-actions\" *ngIf=\"showStandaloneCreate\">\n  <button\n    qdButton\n    qdButtonGhost\n    icon=\"plus\"\n    (click)=\"createRow()\"\n    [data-test-id]=\"testId + '-button-add-new'\"\n    class=\"create-button-standalone\"\n  >\n    {{ config.standaloneCreateLabel?.i18n ?? \"i18n.qd.quick.edit.createButtonLabel\" | translate }}\n  </button>\n</div>\n\n<div class=\"table\" [formGroup]=\"control\">\n  <div class=\"table-header\" *ngIf=\"!config.canAdd || templateData.length > 0 || config.emptyStateView\">\n    <div class=\"table-row\">\n      <div class=\"table-cell\" *ngFor=\"let header of visibleColumns\">\n        {{ header?.i18n | translate }}\n        <qd-icon\n          *ngIf=\"hasTooltip(header?.tooltip)\"\n          icon=\"circleInfo\"\n          class=\"additional-info\"\n          qdTooltipOnClick\n          [qdTooltipContent]=\"header?.tooltip?.content\"\n        ></qd-icon>\n      </div>\n      <div class=\"table-cell actions-column\" *ngIf=\"config?.secondaryActions?.length > 0\">\n        <button class=\"menu-button\">\n          <qd-icon icon=\"overflowMenuHorizontal\"></qd-icon>\n        </button>\n      </div>\n    </div>\n  </div>\n  <div class=\"table-body\">\n    <div\n      class=\"table-row\"\n      *qdCustomFor=\"let row of templateData; let rowIndex = index; toggler: togglerDrawing\"\n      [formGroupName]=\"rowIndex\"\n    >\n      <ng-container *ngFor=\"let column of visibleColumns\">\n        <div class=\"table-cell\">\n          <qd-dropdown\n            [config]=\"{\n              filter: column.filter,\n              options: column.options,\n              placeholder: column.placeholder,\n              placeholderPrefix: column.placeholderPrefix,\n              viewonly: (viewonly$ | async) === true || !column.isEditable(row, column.name)\n            }\"\n            [data-test-id]=\"column.name + rowIndex\"\n            *ngIf=\"column.type === 'enum'; else otherTypes\"\n            [dense]=\"true\"\n            [formControl]=\"$any(control.controls[rowIndex])?.controls[column.name]\"\n            qdFocusable\n            class=\"dropdown\"\n          >\n          </qd-dropdown>\n\n          <ng-template #otherTypes>\n            <qd-input\n              [data-test-id]=\"column.name + rowIndex\"\n              [formControlName]=\"column.name\"\n              *ngIf=\"column.type !== 'enum' && $any(control.controls[rowIndex])?.controls[column.name]\"\n              [config]=\"{\n                inputType: column.type === 'integer' ? 'number' : 'text',\n                viewonly: (viewonly$ | async) === true || !column.isEditable(row, column.name)\n              }\"\n              qdFocusable\n            ></qd-input>\n          </ng-template>\n        </div>\n      </ng-container>\n      <td\n        *ngIf=\"config.secondaryActions?.length > 0 || canAdd\"\n        class=\"table-cell actions\"\n        [attr.data-test-id]=\"testId + '-cell-inline-actions'\"\n      >\n        <button\n          type=\"button\"\n          [qdPopoverOnClick]=\"menu\"\n          [qdPopoverCloseStrategy]=\"'onEveryClick'\"\n          [qdPopoverStopPropagation]=\"true\"\n          class=\"menu-button\"\n          data-test=\"secondary-actions-toggler\"\n        >\n          <qd-icon icon=\"overflowMenuHorizontal\"></qd-icon>\n        </button>\n\n        <ng-template #menu>\n          <button\n            *ngFor=\"let secondaryAction of actions$ | async\"\n            class=\"secondary-actions\"\n            [ngClass]=\"{ disabled: isActionDisabled(secondaryAction, row) }\"\n            [attr.disabled]=\"isActionDisabled(secondaryAction, row) || null\"\n            (click)=\"handleSecondaryAction(secondaryAction, rowIndex)\"\n          >\n            {{ secondaryAction.label.i18n | translate }}\n          </button>\n          <button\n            *ngIf=\"canAdd && (viewonly$ | async) === false\"\n            class=\"secondary-actions\"\n            (click)=\"removeRow(rowIndex)\"\n          >\n            {{ \"i18n.qd.quick.edit.removeButtonLabel\" | translate }}\n          </button>\n        </ng-template>\n      </td>\n    </div>\n  </div>\n  <div class=\"empty-body\" *ngIf=\"config.emptyStateView && !config.emptyStateView.disabled && templateData.length === 0\">\n    <p>{{ config.emptyStateView.i18n | translate }}</p>\n  </div>\n</div>\n"]}
|
|
@@ -192,11 +192,11 @@ export class QdSearchComponent {
|
|
|
192
192
|
return this.configData.emitEmptySearch ?? !!this.configData.clearable;
|
|
193
193
|
}
|
|
194
194
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: QdSearchComponent, deps: [{ token: i1.QdSearchStoreService }, { token: i2.QdSearchRouterConnectorService }, { token: i3.QdSearchService, self: true }, { token: i3.QdSearchService, optional: true, skipSelf: true }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
195
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", type: QdSearchComponent, selector: "qd-search", inputs: { configData: "configData" }, host: { properties: { "class.hidden": "!hasConfig" }, classAttribute: "qd-search" }, providers: [QdSearchService, QdSearchRouterConnectorService], usesOnChanges: true, ngImport: i0, template: "<ng-container *ngIf=\"hasConfig\">\n <div class=\"search-field\">\n <qd-dropdown\n *ngIf=\"preSelectedEnabled\"\n class=\"preselect\"\n [(value)]=\"preSelect\"\n [config]=\"dropdownConfig\"\n ></qd-dropdown>\n\n <qd-input\n class=\"search-input\"\n [(value)]=\"search\"\n [config]=\"inputConfig\"\n (keydown.enter)=\"startSearch()\"\n (clickClear)=\"handleDelete()\"\n data-test-id=\"search-input\"\n ></qd-input>\n <button\n type=\"button\"\n qdIconButton\n qdStopPropagation\n data-test-id=\"search-button\"\n class=\"search-button\"\n (click)=\"startSearch()\"\n [attr.aria-label]=\"'i18n.qd.container.toolbar.search' | translate\"\n >\n <qd-icon [icon]=\"'magnifier'\"></qd-icon>\n </button>\n </div>\n\n <qd-icon\n *ngIf=\"hasAdditionalInfo\"\n icon=\"circleInfo\"\n class=\"additional-info\"\n qdTooltipOnClick\n [qdTooltipContent]=\"configData.additionalInfo.content\"\n ></qd-icon>\n</ng-container>\n", styles: [".qd-search
|
|
195
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", type: QdSearchComponent, selector: "qd-search", inputs: { configData: "configData" }, host: { properties: { "class.hidden": "!hasConfig" }, classAttribute: "qd-search" }, providers: [QdSearchService, QdSearchRouterConnectorService], usesOnChanges: true, ngImport: i0, template: "<ng-container *ngIf=\"hasConfig\">\n <div class=\"search-field\">\n <qd-dropdown\n *ngIf=\"preSelectedEnabled\"\n class=\"preselect\"\n [(value)]=\"preSelect\"\n [config]=\"dropdownConfig\"\n ></qd-dropdown>\n\n <qd-input\n class=\"search-input\"\n [(value)]=\"search\"\n [config]=\"inputConfig\"\n (keydown.enter)=\"startSearch()\"\n (clickClear)=\"handleDelete()\"\n data-test-id=\"search-input\"\n ></qd-input>\n <button\n type=\"button\"\n qdIconButton\n qdStopPropagation\n data-test-id=\"search-button\"\n class=\"search-button\"\n (click)=\"startSearch()\"\n [attr.aria-label]=\"'i18n.qd.container.toolbar.search' | translate\"\n >\n <qd-icon [icon]=\"'magnifier'\"></qd-icon>\n </button>\n </div>\n\n <qd-icon\n *ngIf=\"hasAdditionalInfo\"\n icon=\"circleInfo\"\n class=\"additional-info\"\n qdTooltipOnClick\n [qdTooltipContent]=\"configData.additionalInfo.content\"\n ></qd-icon>\n</ng-container>\n", styles: [".qd-search.hidden{display:none}.qd-search .search-field{position:relative;display:flex;flex-wrap:nowrap}@media (max-width: 959.98px){.qd-search .search-field,.qd-search .search-field .search-input{width:100%}}.qd-search{position:relative;display:flex;height:2.25rem}.qd-search .preselect{display:flex;height:2.25rem}.qd-search .preselect .qd-dropdown__wrapper{height:2.25rem;margin-bottom:0}.qd-search .preselect .qd-dropdown__wrapper .qd-dropdown__box{background:#e5e5e5;color:#171717;font-size:.8125rem}.qd-search .search-input{display:flex;overflow:hidden;width:16.25rem;margin:0}.qd-search .search-input .qd-form-label,.qd-search .search-input .qd-form-hint{display:none;margin:0}.qd-search .search-input .qd-input-input{padding-right:1.25rem;margin:0!important}.qd-search .search-input .qd-input-input .qd-input-clearable-icon{margin-right:1.75rem!important}.qd-search .search-button{position:absolute;top:0;right:0;width:1.875rem;height:2.25rem;padding:0!important;padding-right:.375rem!important;padding-left:.375rem!important;margin:0!important;background:none}.qd-search .search-button:hover,.qd-search .search-button:focus,.qd-search .search-button:active{background:none}.qd-search .search-button .qd-icon{color:#979797!important;font-size:1.125rem!important;line-height:2.25rem;transform:translate(-.125rem,.0625rem)}.qd-search .search-button .qd-icon:hover,.qd-search .search-button .qd-icon:focus,.qd-search .search-button .qd-icon:active{color:#171717!important}.qd-search .additional-info{align-self:center;padding:0 .375rem 0 0;margin-right:-.375rem;margin-left:.5rem;color:#069;cursor:pointer;font-size:1.3125rem;line-height:2.25rem}.qd-search .additional-info:hover,.qd-search .additional-info:focus,.qd-search .additional-info:active{color:#14516f}\n"], dependencies: [{ kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i5.QdIconButtonComponent, selector: "button[qdIconButton], a[qdIconButton], button[qd-icon-button]", inputs: ["color", "data-test-id"] }, { kind: "component", type: i6.QdDropdownComponent, selector: "qd-dropdown", inputs: ["value", "id", "formControlName", "config", "data-test-id", "qdPopoverMaxHeight", "dense"], outputs: ["valueChange", "enterClick", "clickHint", "clickReadonly", "clickViewonly"] }, { kind: "component", type: i7.QdInputComponent, selector: "qd-input", inputs: ["formControlName", "value", "config", "isError", "data-test-id"], outputs: ["valueChange", "enterClick", "clickClear", "clickHint", "clickReadonly", "clickViewonly"] }, { kind: "component", type: i8.QdIconComponent, selector: "qd-icon", inputs: ["icon"] }, { kind: "directive", type: i9.QdTooltipOnClickDirective, selector: "[qdTooltipOnClick]", inputs: ["qdTooltipContent"] }, { kind: "pipe", type: i10.TranslatePipe, name: "translate" }], encapsulation: i0.ViewEncapsulation.None });
|
|
196
196
|
}
|
|
197
197
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: QdSearchComponent, decorators: [{
|
|
198
198
|
type: Component,
|
|
199
|
-
args: [{ selector: 'qd-search', encapsulation: ViewEncapsulation.None, host: { class: 'qd-search', '[class.hidden]': '!hasConfig' }, providers: [QdSearchService, QdSearchRouterConnectorService], template: "<ng-container *ngIf=\"hasConfig\">\n <div class=\"search-field\">\n <qd-dropdown\n *ngIf=\"preSelectedEnabled\"\n class=\"preselect\"\n [(value)]=\"preSelect\"\n [config]=\"dropdownConfig\"\n ></qd-dropdown>\n\n <qd-input\n class=\"search-input\"\n [(value)]=\"search\"\n [config]=\"inputConfig\"\n (keydown.enter)=\"startSearch()\"\n (clickClear)=\"handleDelete()\"\n data-test-id=\"search-input\"\n ></qd-input>\n <button\n type=\"button\"\n qdIconButton\n qdStopPropagation\n data-test-id=\"search-button\"\n class=\"search-button\"\n (click)=\"startSearch()\"\n [attr.aria-label]=\"'i18n.qd.container.toolbar.search' | translate\"\n >\n <qd-icon [icon]=\"'magnifier'\"></qd-icon>\n </button>\n </div>\n\n <qd-icon\n *ngIf=\"hasAdditionalInfo\"\n icon=\"circleInfo\"\n class=\"additional-info\"\n qdTooltipOnClick\n [qdTooltipContent]=\"configData.additionalInfo.content\"\n ></qd-icon>\n</ng-container>\n", styles: [".qd-search
|
|
199
|
+
args: [{ selector: 'qd-search', encapsulation: ViewEncapsulation.None, host: { class: 'qd-search', '[class.hidden]': '!hasConfig' }, providers: [QdSearchService, QdSearchRouterConnectorService], template: "<ng-container *ngIf=\"hasConfig\">\n <div class=\"search-field\">\n <qd-dropdown\n *ngIf=\"preSelectedEnabled\"\n class=\"preselect\"\n [(value)]=\"preSelect\"\n [config]=\"dropdownConfig\"\n ></qd-dropdown>\n\n <qd-input\n class=\"search-input\"\n [(value)]=\"search\"\n [config]=\"inputConfig\"\n (keydown.enter)=\"startSearch()\"\n (clickClear)=\"handleDelete()\"\n data-test-id=\"search-input\"\n ></qd-input>\n <button\n type=\"button\"\n qdIconButton\n qdStopPropagation\n data-test-id=\"search-button\"\n class=\"search-button\"\n (click)=\"startSearch()\"\n [attr.aria-label]=\"'i18n.qd.container.toolbar.search' | translate\"\n >\n <qd-icon [icon]=\"'magnifier'\"></qd-icon>\n </button>\n </div>\n\n <qd-icon\n *ngIf=\"hasAdditionalInfo\"\n icon=\"circleInfo\"\n class=\"additional-info\"\n qdTooltipOnClick\n [qdTooltipContent]=\"configData.additionalInfo.content\"\n ></qd-icon>\n</ng-container>\n", styles: [".qd-search.hidden{display:none}.qd-search .search-field{position:relative;display:flex;flex-wrap:nowrap}@media (max-width: 959.98px){.qd-search .search-field,.qd-search .search-field .search-input{width:100%}}.qd-search{position:relative;display:flex;height:2.25rem}.qd-search .preselect{display:flex;height:2.25rem}.qd-search .preselect .qd-dropdown__wrapper{height:2.25rem;margin-bottom:0}.qd-search .preselect .qd-dropdown__wrapper .qd-dropdown__box{background:#e5e5e5;color:#171717;font-size:.8125rem}.qd-search .search-input{display:flex;overflow:hidden;width:16.25rem;margin:0}.qd-search .search-input .qd-form-label,.qd-search .search-input .qd-form-hint{display:none;margin:0}.qd-search .search-input .qd-input-input{padding-right:1.25rem;margin:0!important}.qd-search .search-input .qd-input-input .qd-input-clearable-icon{margin-right:1.75rem!important}.qd-search .search-button{position:absolute;top:0;right:0;width:1.875rem;height:2.25rem;padding:0!important;padding-right:.375rem!important;padding-left:.375rem!important;margin:0!important;background:none}.qd-search .search-button:hover,.qd-search .search-button:focus,.qd-search .search-button:active{background:none}.qd-search .search-button .qd-icon{color:#979797!important;font-size:1.125rem!important;line-height:2.25rem;transform:translate(-.125rem,.0625rem)}.qd-search .search-button .qd-icon:hover,.qd-search .search-button .qd-icon:focus,.qd-search .search-button .qd-icon:active{color:#171717!important}.qd-search .additional-info{align-self:center;padding:0 .375rem 0 0;margin-right:-.375rem;margin-left:.5rem;color:#069;cursor:pointer;font-size:1.3125rem;line-height:2.25rem}.qd-search .additional-info:hover,.qd-search .additional-info:focus,.qd-search .additional-info:active{color:#14516f}\n"] }]
|
|
200
200
|
}], ctorParameters: () => [{ type: i1.QdSearchStoreService }, { type: i2.QdSearchRouterConnectorService }, { type: i3.QdSearchService, decorators: [{
|
|
201
201
|
type: Self
|
|
202
202
|
}] }, { type: i3.QdSearchService, decorators: [{
|
|
@@ -13,7 +13,7 @@ import * as i2 from "@ngx-translate/core";
|
|
|
13
13
|
import * as i3 from "../../../master-layout/service/language-from-url.service";
|
|
14
14
|
import * as i4 from "../../services/pams-environment.service";
|
|
15
15
|
import * as i5 from "@angular/common";
|
|
16
|
-
const DEFAULT_JAVASCRIPT_ASSET_PATH = 'assets/service-navigation-web-component.js?version=
|
|
16
|
+
const DEFAULT_JAVASCRIPT_ASSET_PATH = 'assets/service-navigation-web-component.js?version=15.0.3';
|
|
17
17
|
export class QdShellServiceNavigationComponent {
|
|
18
18
|
serviceNavigationService;
|
|
19
19
|
translateService;
|
|
@@ -137,11 +137,11 @@ export class QdShellServiceNavigationComponent {
|
|
|
137
137
|
updateHtmlLang(language);
|
|
138
138
|
}
|
|
139
139
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: QdShellServiceNavigationComponent, deps: [{ token: i1.QdShellServiceNavigationService }, { token: i2.TranslateService }, { token: i3.QdLanguageFromUrlService }, { token: i4.QdShellPamsEnvironmentService }, { token: 'QdAuthenticationService', optional: true }], target: i0.ɵɵFactoryTarget.Component });
|
|
140
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", type: QdShellServiceNavigationComponent, selector: "qd-shell-service-navigation", inputs: { config: "config" }, providers: [QdShellServiceNavigationService], viewQueries: [{ propertyName: "serviceNavigation", first: true, predicate: ["serviceNavigation"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<ob-service-navigation-web-component\n *ngIf=\"pamsEnvironment\"\n #serviceNavigation\n [languageList]=\"languageListStringified\"\n [pamsAppId]=\"pamsAppId\"\n [environment]=\"pamsEnvironment\"\n (languageChange)=\"handleLanguageChange($event)\"\n (loginState)=\"handleLoginStatusChange($event)\"\n (logoutTriggered)=\"handleLogoutTriggered($event)\"\n></ob-service-navigation-web-component>\n", styles: [":host{display:flex;justify-content:end}:host.expanded{visibility:visible}@media (max-width: 599.98px){:host.expanded{visibility:collapse}}@media (max-width: 599.98px){:host{flex-basis:100%;margin-top:1rem}}\n"], dependencies: [{ kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
|
|
140
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", type: QdShellServiceNavigationComponent, selector: "qd-shell-service-navigation", inputs: { config: "config" }, providers: [QdShellServiceNavigationService], viewQueries: [{ propertyName: "serviceNavigation", first: true, predicate: ["serviceNavigation"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<ob-service-navigation-web-component\n *ngIf=\"pamsEnvironment\"\n #serviceNavigation\n [languageList]=\"languageListStringified\"\n [pamsAppId]=\"pamsAppId\"\n [environment]=\"pamsEnvironment\"\n (languageChange)=\"handleLanguageChange($event)\"\n (loginState)=\"handleLoginStatusChange($event)\"\n (logoutTriggered)=\"handleLogoutTriggered($event)\"\n [eportalLanguageSynchronization]=\"true\"\n></ob-service-navigation-web-component>\n", styles: [":host{display:flex;justify-content:end}:host.expanded{visibility:visible}@media (max-width: 599.98px){:host.expanded{visibility:collapse}}@media (max-width: 599.98px){:host{flex-basis:100%;margin-top:1rem}}\n"], dependencies: [{ kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
|
|
141
141
|
}
|
|
142
142
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: QdShellServiceNavigationComponent, decorators: [{
|
|
143
143
|
type: Component,
|
|
144
|
-
args: [{ selector: 'qd-shell-service-navigation', providers: [QdShellServiceNavigationService], template: "<ob-service-navigation-web-component\n *ngIf=\"pamsEnvironment\"\n #serviceNavigation\n [languageList]=\"languageListStringified\"\n [pamsAppId]=\"pamsAppId\"\n [environment]=\"pamsEnvironment\"\n (languageChange)=\"handleLanguageChange($event)\"\n (loginState)=\"handleLoginStatusChange($event)\"\n (logoutTriggered)=\"handleLogoutTriggered($event)\"\n></ob-service-navigation-web-component>\n", styles: [":host{display:flex;justify-content:end}:host.expanded{visibility:visible}@media (max-width: 599.98px){:host.expanded{visibility:collapse}}@media (max-width: 599.98px){:host{flex-basis:100%;margin-top:1rem}}\n"] }]
|
|
144
|
+
args: [{ selector: 'qd-shell-service-navigation', providers: [QdShellServiceNavigationService], template: "<ob-service-navigation-web-component\n *ngIf=\"pamsEnvironment\"\n #serviceNavigation\n [languageList]=\"languageListStringified\"\n [pamsAppId]=\"pamsAppId\"\n [environment]=\"pamsEnvironment\"\n (languageChange)=\"handleLanguageChange($event)\"\n (loginState)=\"handleLoginStatusChange($event)\"\n (logoutTriggered)=\"handleLogoutTriggered($event)\"\n [eportalLanguageSynchronization]=\"true\"\n></ob-service-navigation-web-component>\n", styles: [":host{display:flex;justify-content:end}:host.expanded{visibility:visible}@media (max-width: 599.98px){:host.expanded{visibility:collapse}}@media (max-width: 599.98px){:host{flex-basis:100%;margin-top:1rem}}\n"] }]
|
|
145
145
|
}], ctorParameters: () => [{ type: i1.QdShellServiceNavigationService }, { type: i2.TranslateService }, { type: i3.QdLanguageFromUrlService }, { type: i4.QdShellPamsEnvironmentService }, { type: undefined, decorators: [{
|
|
146
146
|
type: Optional
|
|
147
147
|
}, {
|
|
@@ -153,4 +153,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImpor
|
|
|
153
153
|
type: ViewChild,
|
|
154
154
|
args: ['serviceNavigation']
|
|
155
155
|
}] } });
|
|
156
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"shell-service-navigation.component.js","sourceRoot":"","sources":["../../../../../../../libs/qd-ui/src/lib/shell/header/service-navigation/shell-service-navigation.component.ts","../../../../../../../libs/qd-ui/src/lib/shell/header/service-navigation/shell-service-navigation.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  ElementRef,\n  Inject,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Optional,\n  SimpleChanges,\n  ViewChild\n} from '@angular/core';\nimport { TranslateService } from '@ngx-translate/core';\nimport { delayWhen, ReplaySubject, Subject, takeUntil } from 'rxjs';\nimport { filter, tap } from 'rxjs/operators';\nimport { updateHtmlLang } from '../../../helpers/language.helper';\nimport { loadJavascriptAsset } from '../../../helpers/load-javascript-asset.helper';\nimport { QdLanguageFromUrlService } from '../../../master-layout/service/language-from-url.service';\nimport {\n  QdShellServiceNavigationConfig,\n  QdShellServiceNavigationLanguage\n} from '../../model/shell-service-navigation-config.interface';\nimport { QdShellPamsEnvironmentService } from '../../services/pams-environment.service';\nimport { DEFAULT_LANGUAGE_LIST, QdShellServiceNavigationService } from '../../services/service-navigation.service';\n\nconst DEFAULT_JAVASCRIPT_ASSET_PATH = 'assets/service-navigation-web-component.js?version=14.2.0';\n\n@Component({\n  selector: 'qd-shell-service-navigation',\n  templateUrl: './shell-service-navigation.component.html',\n  styleUrls: ['./shell-service-navigation.component.scss'],\n  providers: [QdShellServiceNavigationService]\n})\nexport class QdShellServiceNavigationComponent implements OnInit, OnDestroy, AfterViewInit, OnChanges {\n  /**\n   * The configuration for service navigation\n   */\n  @Input() set config(config: QdShellServiceNavigationConfig) {\n    // TODO remove these defaults after update to Oblique 13 (defaults will be provided by Oblique itself then)\n    const defaultConfig = {\n      showNotifications: true,\n      isInfoActive: true,\n      showEportalServices: true,\n      showProfile: true,\n      showAuthentication: true,\n      handleLogout: true // TODO keep this default after update to Oblique 13\n    };\n\n    this._config = { ...defaultConfig, ...config };\n  }\n\n  get config(): QdShellServiceNavigationConfig {\n    return this._config;\n  }\n\n  @ViewChild('serviceNavigation') serviceNavigation: ElementRef;\n\n  pamsEnvironment;\n\n  get languageList(): string[] {\n    return this.config?.languageList ?? DEFAULT_LANGUAGE_LIST;\n  }\n\n  get languageListStringified(): string {\n    return this.languageList.join(',');\n  }\n\n  get pamsAppId(): string {\n    return this.config.pamsAppId;\n  }\n\n  private _config: QdShellServiceNavigationConfig;\n  private _destroyed$ = new Subject<void>();\n  private _attributesHaveBeenSet$ = new ReplaySubject<void>(1);\n\n  constructor(\n    private readonly serviceNavigationService: QdShellServiceNavigationService,\n    private readonly translateService: TranslateService,\n    private readonly languageFromUrlService: QdLanguageFromUrlService,\n    private readonly pamsEnvironmentService: QdShellPamsEnvironmentService,\n    @Optional() @Inject('QdAuthenticationService') private readonly authenticationService: any\n  ) {}\n\n  ngOnInit(): void {\n    loadJavascriptAsset(this.config?.javascriptAssetPath ?? DEFAULT_JAVASCRIPT_ASSET_PATH, {\n      defer: '',\n      type: 'module'\n    });\n    this.setPamsEnvironment();\n    this.setLanguageFromUrlAfterNavigation();\n  }\n\n  private setPamsEnvironment(): void {\n    this.pamsEnvironment = this.config?.pamsEnvironment || this.pamsEnvironmentService.getPamsEnvironment();\n\n    if (!this.pamsEnvironment) this.logPamsEnvironmentMissingError();\n  }\n\n  private logPamsEnvironmentMissingError(): void {\n    console.error(\n      'QdShellServiceNavigationComponent - The service navigation could not be rendered because the ' +\n        'pamsEnvrionment is missing. The pamsEnvironment has to be given in the shell service navigation config or ' +\n        'has to be provided in the backend auth config!'\n    );\n  }\n\n  private setLanguageFromUrlAfterNavigation(): void {\n    this.languageFromUrlService\n      .getLanguageFromUrl()\n      .pipe(\n        delayWhen(() => this._attributesHaveBeenSet$),\n        filter(languageFromUrl => this.languageList.includes(languageFromUrl)),\n        takeUntil(this._destroyed$)\n      )\n      .subscribe(languageFromUrl => {\n        this.serviceNavigationService.config.defaultLanguage = languageFromUrl as QdShellServiceNavigationLanguage;\n        this.translateService.setDefaultLang(languageFromUrl);\n        this.serviceNavigation.nativeElement.setAttribute('default-language', languageFromUrl);\n        this.serviceNavigation.nativeElement.setAttribute('language', languageFromUrl);\n        this.useLanguage(languageFromUrl);\n      });\n\n    this.languageFromUrlService.removeLangParameterFromUrlAfterNavigation();\n  }\n\n  ngAfterViewInit(): void {\n    this.passConfig(this.config);\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes.hasOwnProperty('config') && !changes['config'].isFirstChange()) {\n      this.setPamsEnvironment();\n      this.passConfig(changes['config'].currentValue);\n    }\n  }\n\n  ngOnDestroy(): void {\n    this._destroyed$.complete();\n  }\n\n  handleLanguageChange($event: any): void {\n    this.useLanguage($event.detail);\n  }\n\n  handleLoginStatusChange($event: any): void {\n    this.authenticationService?.pamsStatus.next($event);\n  }\n\n  handleLogoutTriggered($event: any): void {\n    this.config?.logoutHandler?.($event);\n  }\n\n  private passConfig(config: QdShellServiceNavigationConfig): void {\n    if (!this.serviceNavigation) return;\n\n    this.serviceNavigationService.config = config;\n    this.setAttributesForServiceNavigation();\n  }\n\n  private setAttributesForServiceNavigation(): void {\n    this.serviceNavigationService\n      .getMappedAttributes$()\n      .pipe(\n        takeUntil(this._destroyed$),\n        tap(attributes => {\n          if (!attributes) return;\n\n          Object.keys(attributes).forEach(attribute => {\n            this.serviceNavigation.nativeElement.setAttribute(attribute, attributes[attribute]);\n          });\n\n          const language = attributes['language'] || attributes['default-language'];\n          if (language) this.useLanguage(language);\n        }),\n        tap(() => this._attributesHaveBeenSet$.next())\n      )\n      .subscribe();\n  }\n\n  private useLanguage(language: string): void {\n    this.translateService.use(language);\n    updateHtmlLang(language);\n  }\n}\n","<ob-service-navigation-web-component\n  *ngIf=\"pamsEnvironment\"\n  #serviceNavigation\n  [languageList]=\"languageListStringified\"\n  [pamsAppId]=\"pamsAppId\"\n  [environment]=\"pamsEnvironment\"\n  (languageChange)=\"handleLanguageChange($event)\"\n  (loginState)=\"handleLoginStatusChange($event)\"\n  (logoutTriggered)=\"handleLogoutTriggered($event)\"\n></ob-service-navigation-web-component>\n"]}
|
|
156
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"shell-service-navigation.component.js","sourceRoot":"","sources":["../../../../../../../libs/qd-ui/src/lib/shell/header/service-navigation/shell-service-navigation.component.ts","../../../../../../../libs/qd-ui/src/lib/shell/header/service-navigation/shell-service-navigation.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  ElementRef,\n  Inject,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Optional,\n  SimpleChanges,\n  ViewChild\n} from '@angular/core';\nimport { TranslateService } from '@ngx-translate/core';\nimport { delayWhen, ReplaySubject, Subject, takeUntil } from 'rxjs';\nimport { filter, tap } from 'rxjs/operators';\nimport { updateHtmlLang } from '../../../helpers/language.helper';\nimport { loadJavascriptAsset } from '../../../helpers/load-javascript-asset.helper';\nimport { QdLanguageFromUrlService } from '../../../master-layout/service/language-from-url.service';\nimport {\n  QdShellServiceNavigationConfig,\n  QdShellServiceNavigationLanguage\n} from '../../model/shell-service-navigation-config.interface';\nimport { QdShellPamsEnvironmentService } from '../../services/pams-environment.service';\nimport { DEFAULT_LANGUAGE_LIST, QdShellServiceNavigationService } from '../../services/service-navigation.service';\n\nconst DEFAULT_JAVASCRIPT_ASSET_PATH = 'assets/service-navigation-web-component.js?version=15.0.3';\n\n@Component({\n  selector: 'qd-shell-service-navigation',\n  templateUrl: './shell-service-navigation.component.html',\n  styleUrls: ['./shell-service-navigation.component.scss'],\n  providers: [QdShellServiceNavigationService]\n})\nexport class QdShellServiceNavigationComponent implements OnInit, OnDestroy, AfterViewInit, OnChanges {\n  /**\n   * The configuration for service navigation\n   */\n  @Input() set config(config: QdShellServiceNavigationConfig) {\n    // TODO remove these defaults after update to Oblique 13 (defaults will be provided by Oblique itself then)\n    const defaultConfig = {\n      showNotifications: true,\n      isInfoActive: true,\n      showEportalServices: true,\n      showProfile: true,\n      showAuthentication: true,\n      handleLogout: true // TODO keep this default after update to Oblique 13\n    };\n\n    this._config = { ...defaultConfig, ...config };\n  }\n\n  get config(): QdShellServiceNavigationConfig {\n    return this._config;\n  }\n\n  @ViewChild('serviceNavigation') serviceNavigation: ElementRef;\n\n  pamsEnvironment;\n\n  get languageList(): string[] {\n    return this.config?.languageList ?? DEFAULT_LANGUAGE_LIST;\n  }\n\n  get languageListStringified(): string {\n    return this.languageList.join(',');\n  }\n\n  get pamsAppId(): string {\n    return this.config.pamsAppId;\n  }\n\n  private _config: QdShellServiceNavigationConfig;\n  private _destroyed$ = new Subject<void>();\n  private _attributesHaveBeenSet$ = new ReplaySubject<void>(1);\n\n  constructor(\n    private readonly serviceNavigationService: QdShellServiceNavigationService,\n    private readonly translateService: TranslateService,\n    private readonly languageFromUrlService: QdLanguageFromUrlService,\n    private readonly pamsEnvironmentService: QdShellPamsEnvironmentService,\n    @Optional() @Inject('QdAuthenticationService') private readonly authenticationService: any\n  ) {}\n\n  ngOnInit(): void {\n    loadJavascriptAsset(this.config?.javascriptAssetPath ?? DEFAULT_JAVASCRIPT_ASSET_PATH, {\n      defer: '',\n      type: 'module'\n    });\n    this.setPamsEnvironment();\n    this.setLanguageFromUrlAfterNavigation();\n  }\n\n  private setPamsEnvironment(): void {\n    this.pamsEnvironment = this.config?.pamsEnvironment || this.pamsEnvironmentService.getPamsEnvironment();\n\n    if (!this.pamsEnvironment) this.logPamsEnvironmentMissingError();\n  }\n\n  private logPamsEnvironmentMissingError(): void {\n    console.error(\n      'QdShellServiceNavigationComponent - The service navigation could not be rendered because the ' +\n        'pamsEnvrionment is missing. The pamsEnvironment has to be given in the shell service navigation config or ' +\n        'has to be provided in the backend auth config!'\n    );\n  }\n\n  private setLanguageFromUrlAfterNavigation(): void {\n    this.languageFromUrlService\n      .getLanguageFromUrl()\n      .pipe(\n        delayWhen(() => this._attributesHaveBeenSet$),\n        filter(languageFromUrl => this.languageList.includes(languageFromUrl)),\n        takeUntil(this._destroyed$)\n      )\n      .subscribe(languageFromUrl => {\n        this.serviceNavigationService.config.defaultLanguage = languageFromUrl as QdShellServiceNavigationLanguage;\n        this.translateService.setDefaultLang(languageFromUrl);\n        this.serviceNavigation.nativeElement.setAttribute('default-language', languageFromUrl);\n        this.serviceNavigation.nativeElement.setAttribute('language', languageFromUrl);\n        this.useLanguage(languageFromUrl);\n      });\n\n    this.languageFromUrlService.removeLangParameterFromUrlAfterNavigation();\n  }\n\n  ngAfterViewInit(): void {\n    this.passConfig(this.config);\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes.hasOwnProperty('config') && !changes['config'].isFirstChange()) {\n      this.setPamsEnvironment();\n      this.passConfig(changes['config'].currentValue);\n    }\n  }\n\n  ngOnDestroy(): void {\n    this._destroyed$.complete();\n  }\n\n  handleLanguageChange($event: any): void {\n    this.useLanguage($event.detail);\n  }\n\n  handleLoginStatusChange($event: any): void {\n    this.authenticationService?.pamsStatus.next($event);\n  }\n\n  handleLogoutTriggered($event: any): void {\n    this.config?.logoutHandler?.($event);\n  }\n\n  private passConfig(config: QdShellServiceNavigationConfig): void {\n    if (!this.serviceNavigation) return;\n\n    this.serviceNavigationService.config = config;\n    this.setAttributesForServiceNavigation();\n  }\n\n  private setAttributesForServiceNavigation(): void {\n    this.serviceNavigationService\n      .getMappedAttributes$()\n      .pipe(\n        takeUntil(this._destroyed$),\n        tap(attributes => {\n          if (!attributes) return;\n\n          Object.keys(attributes).forEach(attribute => {\n            this.serviceNavigation.nativeElement.setAttribute(attribute, attributes[attribute]);\n          });\n\n          const language = attributes['language'] || attributes['default-language'];\n          if (language) this.useLanguage(language);\n        }),\n        tap(() => this._attributesHaveBeenSet$.next())\n      )\n      .subscribe();\n  }\n\n  private useLanguage(language: string): void {\n    this.translateService.use(language);\n    updateHtmlLang(language);\n  }\n}\n","<ob-service-navigation-web-component\n  *ngIf=\"pamsEnvironment\"\n  #serviceNavigation\n  [languageList]=\"languageListStringified\"\n  [pamsAppId]=\"pamsAppId\"\n  [environment]=\"pamsEnvironment\"\n  (languageChange)=\"handleLanguageChange($event)\"\n  (loginState)=\"handleLoginStatusChange($event)\"\n  (logoutTriggered)=\"handleLogoutTriggered($event)\"\n  [eportalLanguageSynchronization]=\"true\"\n></ob-service-navigation-web-component>\n"]}
|