UNPKG

@alauda-fe/common

Version:

Alauda frontend team common codes.

119 lines 16 kB
import { DialogRef, DIALOG_DATA, DialogModule, FormModule, ButtonModule, InputModule, } from '@alauda/ui'; import { AsyncPipe } from '@angular/common'; import { ChangeDetectionStrategy, Component, Inject } from '@angular/core'; import { FormsModule } from '@angular/forms'; import { snakeCase } from 'lodash-es'; import { BehaviorSubject, finalize } from 'rxjs'; import { K8sApiService } from '../../api/k8s-api.service'; import { K8S_UTIL_PIPES_MODULE, DESCRIPTION, K8sUtilService, } from '../../core/public-api'; import { TRANSLATE_MODULE } from '../../translate/public-api'; import * as i0 from "@angular/core"; import * as i1 from "@alauda/ui"; import * as i2 from "../../api/k8s-api.service"; import * as i3 from "../../core/public-api"; import * as i4 from "@angular/forms"; import * as i5 from "../../translate/translate.pipe"; import * as i6 from "../../core/pipes/k8s-util.pipe"; export class UpdateDescriptionDialogComponent { constructor(dialogRef, k8sApi, k8sUtil, data) { this.dialogRef = dialogRef; this.k8sApi = k8sApi; this.k8sUtil = k8sUtil; this.data = data; this.description = this.k8sUtil.getDescription(this.data.resource); this.confirming$$ = new BehaviorSubject(false); } confirm() { this.confirming$$.next(true); this.k8sApi .patchResource({ ...(this.data.definition ? { definition: this.data.definition, } : { type: this.data.type || snakeCase(this.data.resource.kind).toUpperCase(), }), cluster: this.data.cluster, resource: this.data.resource, part: { metadata: { annotations: { [this.k8sUtil.normalizeType(DESCRIPTION)]: this.description, }, }, }, }) .pipe(finalize(() => this.confirming$$.next(false))) .subscribe(resource => this.dialogRef.close(resource)); } static { this.ɵfac = function UpdateDescriptionDialogComponent_Factory(t) { return new (t || UpdateDescriptionDialogComponent)(i0.ɵɵdirectiveInject(i1.DialogRef), i0.ɵɵdirectiveInject(i2.K8sApiService), i0.ɵɵdirectiveInject(i3.K8sUtilService), i0.ɵɵdirectiveInject(DIALOG_DATA)); }; } static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: UpdateDescriptionDialogComponent, selectors: [["ng-component"]], standalone: true, features: [i0.ɵɵStandaloneFeature], decls: 24, vars: 25, consts: [["auiFormItemLabel", ""], [1, "last-form-item-no-margin"], ["aui-input", "", "name", "description", 3, "ngModelChange", "ngModel"], ["aui-button", "primary", 3, "click", "loading", "disabled"], ["aui-button", "", "auiDialogClose", ""]], template: function UpdateDescriptionDialogComponent_Template(rf, ctx) { if (rf & 1) { i0.ɵɵelementStart(0, "aui-dialog-header"); i0.ɵɵtext(1); i0.ɵɵpipe(2, "translate"); i0.ɵɵelementEnd(); i0.ɵɵelementStart(3, "aui-dialog-content")(4, "aui-form-item")(5, "label", 0); i0.ɵɵtext(6); i0.ɵɵpipe(7, "translate"); i0.ɵɵelementEnd(); i0.ɵɵtext(8); i0.ɵɵpipe(9, "aclName"); i0.ɵɵelementEnd(); i0.ɵɵelementStart(10, "aui-form-item", 1)(11, "label", 0); i0.ɵɵtext(12); i0.ɵɵpipe(13, "translate"); i0.ɵɵelementEnd(); i0.ɵɵelementStart(14, "textarea", 2); i0.ɵɵtwoWayListener("ngModelChange", function UpdateDescriptionDialogComponent_Template_textarea_ngModelChange_14_listener($event) { i0.ɵɵtwoWayBindingSet(ctx.description, $event) || (ctx.description = $event); return $event; }); i0.ɵɵelementEnd()()(); i0.ɵɵelementStart(15, "aui-dialog-footer")(16, "button", 3); i0.ɵɵpipe(17, "async"); i0.ɵɵpipe(18, "async"); i0.ɵɵlistener("click", function UpdateDescriptionDialogComponent_Template_button_click_16_listener() { return ctx.confirm(); }); i0.ɵɵtext(19); i0.ɵɵpipe(20, "translate"); i0.ɵɵelementEnd(); i0.ɵɵelementStart(21, "button", 4); i0.ɵɵtext(22); i0.ɵɵpipe(23, "translate"); i0.ɵɵelementEnd()(); } if (rf & 2) { i0.ɵɵadvance(); i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(2, 9, "update_description"), "\n"); i0.ɵɵadvance(5); i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(7, 11, "name"), " "); i0.ɵɵadvance(2); i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(9, 13, ctx.data.resource), " "); i0.ɵɵadvance(4); i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(13, 15, "description"), " "); i0.ɵɵadvance(2); i0.ɵɵtwoWayProperty("ngModel", ctx.description); i0.ɵɵadvance(2); i0.ɵɵproperty("loading", i0.ɵɵpipeBind1(17, 17, ctx.confirming$$))("disabled", i0.ɵɵpipeBind1(18, 19, ctx.confirming$$)); i0.ɵɵadvance(3); i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(20, 21, "update"), " "); i0.ɵɵadvance(3); i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(23, 23, "cancel"), " "); } }, dependencies: [AsyncPipe, ButtonModule, i1.ButtonComponent, DialogModule, i1.DialogHeaderComponent, i1.DialogContentComponent, i1.DialogFooterComponent, i1.DialogCloseDirective, InputModule, i1.InputComponent, FormModule, i1.FormItemComponent, i1.FormItemLabelDirective, FormsModule, i4.DefaultValueAccessor, i4.NgControlStatus, i4.NgModel, i5.TranslatePipe, i6.K8sNamePipe], encapsulation: 2, changeDetection: 0 }); } } (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(UpdateDescriptionDialogComponent, [{ type: Component, args: [{ standalone: true, preserveWhitespaces: false, changeDetection: ChangeDetectionStrategy.OnPush, imports: [ AsyncPipe, ButtonModule, DialogModule, InputModule, FormModule, FormsModule, TRANSLATE_MODULE, K8S_UTIL_PIPES_MODULE, ], template: "<aui-dialog-header>\n {{ 'update_description' | translate }}\n</aui-dialog-header>\n<aui-dialog-content>\n <aui-form-item>\n <label auiFormItemLabel>\n {{ 'name' | translate }}\n </label>\n {{ data.resource | aclName }}\n </aui-form-item>\n <aui-form-item class=\"last-form-item-no-margin\">\n <label auiFormItemLabel>\n {{ 'description' | translate }}\n </label>\n <textarea\n aui-input\n name=\"description\"\n [(ngModel)]=\"description\"\n ></textarea>\n </aui-form-item>\n</aui-dialog-content>\n<aui-dialog-footer>\n <button\n aui-button=\"primary\"\n [loading]=\"confirming$$ | async\"\n [disabled]=\"confirming$$ | async\"\n (click)=\"confirm()\"\n >\n {{ 'update' | translate }}\n </button>\n <button\n aui-button\n auiDialogClose\n >\n {{ 'cancel' | translate }}\n </button>\n</aui-dialog-footer>\n" }] }], () => [{ type: i1.DialogRef }, { type: i2.K8sApiService }, { type: i3.K8sUtilService }, { type: undefined, decorators: [{ type: Inject, args: [DIALOG_DATA] }] }], null); })(); (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(UpdateDescriptionDialogComponent, { className: "UpdateDescriptionDialogComponent" }); })(); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"component.js","sourceRoot":"","sources":["../../../../../../libs/common/src/k8s-shared/update-description-dialog/component.ts","../../../../../../libs/common/src/k8s-shared/update-description-dialog/template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  DialogRef,\n  DIALOG_DATA,\n  DialogModule,\n  FormModule,\n  ButtonModule,\n  InputModule,\n} from '@alauda/ui';\nimport { AsyncPipe } from '@angular/common';\nimport { ChangeDetectionStrategy, Component, Inject } from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { snakeCase } from 'lodash-es';\nimport { BehaviorSubject, finalize } from 'rxjs';\nimport { DeepPartial } from 'ts-essentials/dist/deep-partial';\n\nimport { K8sApiService } from '../../api/k8s-api.service';\nimport { K8sResourceDefinition } from '../../api/types';\nimport {\n  K8S_UTIL_PIPES_MODULE,\n  DESCRIPTION,\n  K8sUtilService,\n  KubernetesResource,\n  ResourceType,\n} from '../../core/public-api';\nimport { TRANSLATE_MODULE } from '../../translate/public-api';\n\n@Component({\n  standalone: true,\n  templateUrl: 'template.html',\n  preserveWhitespaces: false,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [\n    AsyncPipe,\n    ButtonModule,\n    DialogModule,\n    InputModule,\n    FormModule,\n    FormsModule,\n    TRANSLATE_MODULE,\n    K8S_UTIL_PIPES_MODULE,\n  ],\n})\nexport class UpdateDescriptionDialogComponent<T extends KubernetesResource> {\n  description = this.k8sUtil.getDescription(this.data.resource);\n\n  confirming$$ = new BehaviorSubject(false);\n\n  constructor(\n    private readonly dialogRef: DialogRef,\n    private readonly k8sApi: K8sApiService<ResourceType>,\n    private readonly k8sUtil: K8sUtilService,\n    @Inject(DIALOG_DATA)\n    public data: {\n      definition?: K8sResourceDefinition;\n      /**\n       * @deprecated use `definition` instead\n       */\n      type?: ResourceType;\n      cluster?: string;\n      resource: T;\n    },\n  ) {}\n\n  confirm() {\n    this.confirming$$.next(true);\n    this.k8sApi\n      .patchResource<T>({\n        ...(this.data.definition\n          ? {\n              definition: this.data.definition,\n            }\n          : {\n              type:\n                this.data.type ||\n                (snakeCase(\n                  this.data.resource.kind,\n                ).toUpperCase() as ResourceType),\n            }),\n        cluster: this.data.cluster,\n        resource: this.data.resource,\n        part: {\n          metadata: {\n            annotations: {\n              [this.k8sUtil.normalizeType(DESCRIPTION)]: this.description,\n            },\n          },\n        } as DeepPartial<T>,\n      })\n      .pipe(finalize(() => this.confirming$$.next(false)))\n      .subscribe(resource => this.dialogRef.close(resource));\n  }\n}\n","<aui-dialog-header>\n  {{ 'update_description' | translate }}\n</aui-dialog-header>\n<aui-dialog-content>\n  <aui-form-item>\n    <label auiFormItemLabel>\n      {{ 'name' | translate }}\n    </label>\n    {{ data.resource | aclName }}\n  </aui-form-item>\n  <aui-form-item class=\"last-form-item-no-margin\">\n    <label auiFormItemLabel>\n      {{ 'description' | translate }}\n    </label>\n    <textarea\n      aui-input\n      name=\"description\"\n      [(ngModel)]=\"description\"\n    ></textarea>\n  </aui-form-item>\n</aui-dialog-content>\n<aui-dialog-footer>\n  <button\n    aui-button=\"primary\"\n    [loading]=\"confirming$$ | async\"\n    [disabled]=\"confirming$$ | async\"\n    (click)=\"confirm()\"\n  >\n    {{ 'update' | translate }}\n  </button>\n  <button\n    aui-button\n    auiDialogClose\n  >\n    {{ 'cancel' | translate }}\n  </button>\n</aui-dialog-footer>\n"]}