@alauda-fe/common
Version:
Alauda frontend team common codes.
114 lines • 18.8 kB
JavaScript
import { ButtonModule, DIALOG_DATA, DialogModule, DialogRef, MessageService, } from '@alauda/ui';
import { AsyncPipe } from '@angular/common';
import { ChangeDetectionStrategy, Component, Inject, Optional, } from '@angular/core';
import { FormsModule } from '@angular/forms';
import { cloneDeep } from 'lodash-es';
import { BehaviorSubject, EMPTY, Subject, from, catchError, switchMap, takeUntil, tap, } from 'rxjs';
import { KeyValueFormTableComponent } from '../../array-form-table/key-value-form/component';
import { isEqual } from '../../core/public-api';
import { TranslateModule, TranslateService } from '../../translate/public-api';
import * as i0 from "@angular/core";
import * as i1 from "@alauda/ui";
import * as i2 from "../../translate/public-api";
import * as i3 from "@angular/forms";
import * as i4 from "../../translate/translate.pipe";
export class UpdateKeyValueDialogComponent {
constructor(dialogRef, message, translate, data = {}) {
this.dialogRef = dialogRef;
this.message = message;
this.translate = translate;
this.data = data;
this.onUpdate$$ = new Subject();
this.submitting$$ = new BehaviorSubject(false);
this.destroy$$ = new Subject();
this.originalKeyValues = this.data.keyValues || {};
this.keyValues = cloneDeep(this.originalKeyValues);
}
ngOnInit() {
const { context, onUpdate, updateSuccessMsg, updateFailMsg, showMessage } = this.data;
if (!onUpdate) {
return;
}
this.onUpdate$$
.pipe(takeUntil(this.destroy$$), tap(() => this.submitting$$.next(true)), switchMap(() => {
// nothing changed
if (isEqual(this.originalKeyValues, this.keyValues)) {
this.dialogRef.close();
return EMPTY;
}
return from(onUpdate.call(context, this.keyValues)).pipe(tap(() => {
if (showMessage ?? true) {
this.message.success(this.translate.get(updateSuccessMsg || 'update_succeeded'));
}
this.submitting$$.next(false);
this.dialogRef.close();
}), catchError(() => {
if (showMessage ?? true) {
this.message.error(this.translate.get(updateFailMsg || 'update_failed'));
}
this.submitting$$.next(false);
return EMPTY;
}));
}))
.subscribe();
}
ngOnDestroy() {
this.destroy$$.next();
this.destroy$$.complete();
}
static { this.ɵfac = function UpdateKeyValueDialogComponent_Factory(t) { return new (t || UpdateKeyValueDialogComponent)(i0.ɵɵdirectiveInject(i1.DialogRef), i0.ɵɵdirectiveInject(i1.MessageService), i0.ɵɵdirectiveInject(i2.TranslateService), i0.ɵɵdirectiveInject(DIALOG_DATA, 8)); }; }
static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: UpdateKeyValueDialogComponent, selectors: [["ng-component"]], standalone: true, features: [i0.ɵɵStandaloneFeature], decls: 16, vars: 19, consts: [["ngForm", "ngForm"], [3, "ngSubmit"], ["name", "key-values", 3, "ngModelChange", "ngModel", "readonlyKeys", "validator", "errorMapper"], ["aui-button", "primary", 3, "click", "loading", "disabled"], ["aui-button", "", "type", "button", "auiDialogClose", ""]], template: function UpdateKeyValueDialogComponent_Template(rf, ctx) { if (rf & 1) {
const _r1 = i0.ɵɵgetCurrentView();
i0.ɵɵelementStart(0, "aui-dialog-header");
i0.ɵɵtext(1);
i0.ɵɵpipe(2, "translate");
i0.ɵɵelementEnd();
i0.ɵɵelementStart(3, "aui-dialog-content")(4, "form", 1, 0);
i0.ɵɵlistener("ngSubmit", function UpdateKeyValueDialogComponent_Template_form_ngSubmit_4_listener() { i0.ɵɵrestoreView(_r1); const ngForm_r2 = i0.ɵɵreference(5); return i0.ɵɵresetView(ngForm_r2.valid && ctx.onUpdate$$.next()); });
i0.ɵɵelementStart(6, "acl-key-value-form-table", 2);
i0.ɵɵtwoWayListener("ngModelChange", function UpdateKeyValueDialogComponent_Template_acl_key_value_form_table_ngModelChange_6_listener($event) { i0.ɵɵrestoreView(_r1); i0.ɵɵtwoWayBindingSet(ctx.keyValues, $event) || (ctx.keyValues = $event); return i0.ɵɵresetView($event); });
i0.ɵɵelementEnd()()();
i0.ɵɵelementStart(7, "aui-dialog-footer")(8, "button", 3);
i0.ɵɵpipe(9, "async");
i0.ɵɵpipe(10, "async");
i0.ɵɵlistener("click", function UpdateKeyValueDialogComponent_Template_button_click_8_listener() { i0.ɵɵrestoreView(_r1); const ngForm_r2 = i0.ɵɵreference(5); return i0.ɵɵresetView(ngForm_r2.onSubmit(null)); });
i0.ɵɵtext(11);
i0.ɵɵpipe(12, "translate");
i0.ɵɵelementEnd();
i0.ɵɵelementStart(13, "button", 4);
i0.ɵɵtext(14);
i0.ɵɵpipe(15, "translate");
i0.ɵɵelementEnd()();
} if (rf & 2) {
i0.ɵɵadvance();
i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(2, 9, ctx.data.title || "update"), "\n");
i0.ɵɵadvance(5);
i0.ɵɵtwoWayProperty("ngModel", ctx.keyValues);
i0.ɵɵproperty("readonlyKeys", ctx.data.readonlyKeys)("validator", ctx.data.validator)("errorMapper", ctx.data.errorMapper);
i0.ɵɵadvance(2);
i0.ɵɵproperty("loading", i0.ɵɵpipeBind1(9, 11, ctx.submitting$$))("disabled", i0.ɵɵpipeBind1(10, 13, ctx.submitting$$));
i0.ɵɵadvance(3);
i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(12, 15, ctx.data.confirmButton || "update"), " ");
i0.ɵɵadvance(3);
i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(15, 17, "cancel"), " ");
} }, dependencies: [DialogModule, i1.DialogHeaderComponent, i1.DialogContentComponent, i1.DialogFooterComponent, i1.DialogCloseDirective, KeyValueFormTableComponent,
FormsModule, i3.ɵNgNoValidate, i3.NgControlStatus, i3.NgControlStatusGroup, i3.NgModel, i3.NgForm, TranslateModule, i4.TranslatePipe, ButtonModule, i1.ButtonComponent, AsyncPipe], encapsulation: 2, changeDetection: 0 }); }
}
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(UpdateKeyValueDialogComponent, [{
type: Component,
args: [{ standalone: true, preserveWhitespaces: false, changeDetection: ChangeDetectionStrategy.OnPush, imports: [
DialogModule,
KeyValueFormTableComponent,
FormsModule,
TranslateModule,
ButtonModule,
AsyncPipe,
], template: "<aui-dialog-header>\n {{ data.title || 'update' | translate }}\n</aui-dialog-header>\n<aui-dialog-content>\n <form\n #ngForm=\"ngForm\"\n (ngSubmit)=\"ngForm.valid && onUpdate$$.next()\"\n >\n <acl-key-value-form-table\n [(ngModel)]=\"keyValues\"\n [readonlyKeys]=\"data.readonlyKeys\"\n [validator]=\"data.validator\"\n [errorMapper]=\"data.errorMapper\"\n name=\"key-values\"\n ></acl-key-value-form-table>\n </form>\n</aui-dialog-content>\n<aui-dialog-footer>\n <button\n aui-button=\"primary\"\n [loading]=\"submitting$$ | async\"\n [disabled]=\"submitting$$ | async\"\n (click)=\"ngForm.onSubmit(null)\"\n >\n {{ data.confirmButton || 'update' | translate }}\n </button>\n <button\n aui-button\n type=\"button\"\n auiDialogClose\n >\n {{ 'cancel' | translate }}\n </button>\n</aui-dialog-footer>\n" }]
}], () => [{ type: i1.DialogRef }, { type: i1.MessageService }, { type: i2.TranslateService }, { type: undefined, decorators: [{
type: Optional
}, {
type: Inject,
args: [DIALOG_DATA]
}] }], null); })();
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(UpdateKeyValueDialogComponent, { className: "UpdateKeyValueDialogComponent" }); })();
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"component.js","sourceRoot":"","sources":["../../../../../../libs/common/src/k8s-shared/update-key-value-dialog/component.ts","../../../../../../libs/common/src/k8s-shared/update-key-value-dialog/template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ButtonModule,\n  DIALOG_DATA,\n  DialogModule,\n  DialogRef,\n  MessageService,\n} from '@alauda/ui';\nimport { AsyncPipe } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  Inject,\n  OnDestroy,\n  OnInit,\n  Optional,\n} from '@angular/core';\nimport { FormsModule, ValidatorFn } from '@angular/forms';\nimport { cloneDeep } from 'lodash-es';\nimport {\n  BehaviorSubject,\n  EMPTY,\n  Observable,\n  Subject,\n  from,\n  catchError,\n  switchMap,\n  takeUntil,\n  tap,\n} from 'rxjs';\n\nimport { KeyValueFormTableComponent } from '../../array-form-table/key-value-form/component';\nimport { isEqual, StringMap } from '../../core/public-api';\nimport { TranslateModule, TranslateService } from '../../translate/public-api';\n\nexport interface UpdateKeyValueDialogData<\n  R = unknown,\n  Context = unknown,\n  T = StringMap,\n> {\n  title?: string;\n  keyValues?: T;\n  confirmButton?: string;\n  readonlyKeys?: Array<string | RegExp>;\n  onUpdate?: (keyValues: T) => Promise<R> | Observable<R>;\n  context?: Context;\n  updateSuccessMsg?: string;\n  updateFailMsg?: string;\n  validator?: {\n    key: ValidatorFn | ValidatorFn[];\n    value?: ValidatorFn | ValidatorFn[];\n  };\n  errorMapper?: Record<string, unknown>;\n  showMessage?: boolean;\n}\n\n@Component({\n  standalone: true,\n  templateUrl: './template.html',\n  preserveWhitespaces: false,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [\n    DialogModule,\n    KeyValueFormTableComponent,\n    FormsModule,\n    TranslateModule,\n    ButtonModule,\n    AsyncPipe,\n  ],\n})\nexport class UpdateKeyValueDialogComponent<\n  R = unknown,\n  Context = unknown,\n  T = StringMap,\n> implements OnInit, OnDestroy\n{\n  readonly onUpdate$$ = new Subject<void>();\n\n  readonly submitting$$ = new BehaviorSubject(false);\n\n  private readonly originalKeyValues: T;\n\n  keyValues: T;\n\n  private readonly destroy$$ = new Subject<void>();\n\n  constructor(\n    private readonly dialogRef: DialogRef<\n      UpdateKeyValueDialogComponent<R, Context, T>,\n      UpdateKeyValueDialogData<R, Context, T>\n    >,\n    private readonly message: MessageService,\n    private readonly translate: TranslateService,\n    @Optional()\n    @Inject(DIALOG_DATA)\n    public data: UpdateKeyValueDialogData<R, Context, T> = {},\n  ) {\n    this.originalKeyValues = this.data.keyValues || ({} as T);\n    this.keyValues = cloneDeep(this.originalKeyValues);\n  }\n\n  ngOnInit() {\n    const { context, onUpdate, updateSuccessMsg, updateFailMsg, showMessage } =\n      this.data;\n    if (!onUpdate) {\n      return;\n    }\n    this.onUpdate$$\n      .pipe(\n        takeUntil(this.destroy$$),\n        tap(() => this.submitting$$.next(true)),\n        switchMap(() => {\n          // nothing changed\n          if (isEqual(this.originalKeyValues, this.keyValues)) {\n            this.dialogRef.close();\n            return EMPTY;\n          }\n          return from(onUpdate.call(context, this.keyValues)).pipe(\n            tap(() => {\n              if (showMessage ?? true) {\n                this.message.success(\n                  this.translate.get(updateSuccessMsg || 'update_succeeded'),\n                );\n              }\n              this.submitting$$.next(false);\n              this.dialogRef.close();\n            }),\n            catchError(() => {\n              if (showMessage ?? true) {\n                this.message.error(\n                  this.translate.get(updateFailMsg || 'update_failed'),\n                );\n              }\n              this.submitting$$.next(false);\n              return EMPTY;\n            }),\n          );\n        }),\n      )\n      .subscribe();\n  }\n\n  ngOnDestroy() {\n    this.destroy$$.next();\n    this.destroy$$.complete();\n  }\n}\n","<aui-dialog-header>\n  {{ data.title || 'update' | translate }}\n</aui-dialog-header>\n<aui-dialog-content>\n  <form\n    #ngForm=\"ngForm\"\n    (ngSubmit)=\"ngForm.valid && onUpdate$$.next()\"\n  >\n    <acl-key-value-form-table\n      [(ngModel)]=\"keyValues\"\n      [readonlyKeys]=\"data.readonlyKeys\"\n      [validator]=\"data.validator\"\n      [errorMapper]=\"data.errorMapper\"\n      name=\"key-values\"\n    ></acl-key-value-form-table>\n  </form>\n</aui-dialog-content>\n<aui-dialog-footer>\n  <button\n    aui-button=\"primary\"\n    [loading]=\"submitting$$ | async\"\n    [disabled]=\"submitting$$ | async\"\n    (click)=\"ngForm.onSubmit(null)\"\n  >\n    {{ data.confirmButton || 'update' | translate }}\n  </button>\n  <button\n    aui-button\n    type=\"button\"\n    auiDialogClose\n  >\n    {{ 'cancel' | translate }}\n  </button>\n</aui-dialog-footer>\n"]}