@alauda-fe/common
Version:
Alauda frontend team common codes.
141 lines • 18.8 kB
JavaScript
import { DialogRef, DIALOG_DATA, ButtonModule, DialogModule, InputModule, FormModule, } from '@alauda/ui';
import { AsyncPipe, NgIf } 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/public-api';
import { DISPLAY_NAME, K8sUtilService, K8S_UTIL_PIPES_MODULE, } 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/public-api";
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";
function UpdateDisplayNameDialogComponent_input_14_Template(rf, ctx) { if (rf & 1) {
const _r2 = i0.ɵɵgetCurrentView();
i0.ɵɵelementStart(0, "input", 6);
i0.ɵɵtwoWayListener("ngModelChange", function UpdateDisplayNameDialogComponent_input_14_Template_input_ngModelChange_0_listener($event) { i0.ɵɵrestoreView(_r2); const ctx_r2 = i0.ɵɵnextContext(); i0.ɵɵtwoWayBindingSet(ctx_r2.displayName, $event) || (ctx_r2.displayName = $event); return i0.ɵɵresetView($event); });
i0.ɵɵelementEnd();
} if (rf & 2) {
const ctx_r2 = i0.ɵɵnextContext();
i0.ɵɵtwoWayProperty("ngModel", ctx_r2.displayName);
} }
function UpdateDisplayNameDialogComponent_ng_template_15_Template(rf, ctx) { if (rf & 1) {
const _r4 = i0.ɵɵgetCurrentView();
i0.ɵɵelementStart(0, "input", 7);
i0.ɵɵtwoWayListener("ngModelChange", function UpdateDisplayNameDialogComponent_ng_template_15_Template_input_ngModelChange_0_listener($event) { i0.ɵɵrestoreView(_r4); const ctx_r2 = i0.ɵɵnextContext(); i0.ɵɵtwoWayBindingSet(ctx_r2.displayName, $event) || (ctx_r2.displayName = $event); return i0.ɵɵresetView($event); });
i0.ɵɵelementEnd();
} if (rf & 2) {
const ctx_r2 = i0.ɵɵnextContext();
i0.ɵɵtwoWayProperty("ngModel", ctx_r2.displayName);
i0.ɵɵproperty("maxlength", 64);
} }
export class UpdateDisplayNameDialogComponent {
constructor(dialogRef, k8sApi, k8sUtil, data) {
this.dialogRef = dialogRef;
this.k8sApi = k8sApi;
this.k8sUtil = k8sUtil;
this.data = data;
this.displayName = this.k8sUtil.getDisplayName(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(DISPLAY_NAME)]: this.displayName,
},
},
},
})
.pipe(finalize(() => this.confirming$$.next(false)))
.subscribe(resource => this.dialogRef.close(resource));
}
static { this.ɵfac = function UpdateDisplayNameDialogComponent_Factory(t) { return new (t || UpdateDisplayNameDialogComponent)(i0.ɵɵdirectiveInject(i1.DialogRef), i0.ɵɵdirectiveInject(i2.K8sApiService), i0.ɵɵdirectiveInject(i3.K8sUtilService), i0.ɵɵdirectiveInject(DIALOG_DATA)); }; }
static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: UpdateDisplayNameDialogComponent, selectors: [["ng-component"]], standalone: true, features: [i0.ɵɵStandaloneFeature], decls: 26, vars: 26, consts: [["validateMaxLength", ""], ["auiFormItemLabel", ""], [1, "last-form-item-no-margin"], ["aui-input", "", "name", "displayName", "autocomplete", "off", 3, "ngModel", "ngModelChange", 4, "ngIf", "ngIfElse"], ["aui-button", "primary", 3, "click", "loading", "disabled"], ["aui-button", "", "auiDialogClose", ""], ["aui-input", "", "name", "displayName", "autocomplete", "off", 3, "ngModelChange", "ngModel"], ["aui-input", "", "name", "displayName", "autocomplete", "off", 3, "ngModelChange", "ngModel", "maxlength"]], template: function UpdateDisplayNameDialogComponent_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, "aui-form-item")(5, "label", 1);
i0.ɵɵtext(6);
i0.ɵɵpipe(7, "translate");
i0.ɵɵelementEnd();
i0.ɵɵtext(8);
i0.ɵɵpipe(9, "aclName");
i0.ɵɵelementEnd();
i0.ɵɵelementStart(10, "aui-form-item", 2)(11, "label", 1);
i0.ɵɵtext(12);
i0.ɵɵpipe(13, "translate");
i0.ɵɵelementEnd();
i0.ɵɵtemplate(14, UpdateDisplayNameDialogComponent_input_14_Template, 1, 1, "input", 3)(15, UpdateDisplayNameDialogComponent_ng_template_15_Template, 1, 2, "ng-template", null, 0, i0.ɵɵtemplateRefExtractor);
i0.ɵɵelementEnd()();
i0.ɵɵelementStart(17, "aui-dialog-footer")(18, "button", 4);
i0.ɵɵpipe(19, "async");
i0.ɵɵpipe(20, "async");
i0.ɵɵlistener("click", function UpdateDisplayNameDialogComponent_Template_button_click_18_listener() { i0.ɵɵrestoreView(_r1); return i0.ɵɵresetView(ctx.confirm()); });
i0.ɵɵtext(21);
i0.ɵɵpipe(22, "translate");
i0.ɵɵelementEnd();
i0.ɵɵelementStart(23, "button", 5);
i0.ɵɵtext(24);
i0.ɵɵpipe(25, "translate");
i0.ɵɵelementEnd()();
} if (rf & 2) {
const validateMaxLength_r5 = i0.ɵɵreference(16);
i0.ɵɵadvance();
i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(2, 10, "update_display_name"), "\n");
i0.ɵɵadvance(5);
i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(7, 12, "name"), " ");
i0.ɵɵadvance(2);
i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(9, 14, ctx.data.resource), " ");
i0.ɵɵadvance(4);
i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(13, 16, "display_name"), " ");
i0.ɵɵadvance(2);
i0.ɵɵproperty("ngIf", !ctx.data.validateMaxLength)("ngIfElse", validateMaxLength_r5);
i0.ɵɵadvance(4);
i0.ɵɵproperty("loading", i0.ɵɵpipeBind1(19, 18, ctx.confirming$$))("disabled", i0.ɵɵpipeBind1(20, 20, ctx.confirming$$));
i0.ɵɵadvance(3);
i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(22, 22, "update"), " ");
i0.ɵɵadvance(3);
i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(25, 24, "cancel"), " ");
} }, dependencies: [AsyncPipe,
ButtonModule, i1.ButtonComponent, DialogModule, i1.DialogHeaderComponent, i1.DialogContentComponent, i1.DialogFooterComponent, i1.DialogCloseDirective, NgIf,
InputModule, i1.InputComponent, FormModule, i1.FormItemComponent, i1.FormItemLabelDirective, FormsModule, i4.DefaultValueAccessor, i4.NgControlStatus, i4.MaxLengthValidator, i4.NgModel, i5.TranslatePipe, i6.K8sNamePipe], encapsulation: 2, changeDetection: 0 }); }
}
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(UpdateDisplayNameDialogComponent, [{
type: Component,
args: [{ standalone: true, preserveWhitespaces: false, changeDetection: ChangeDetectionStrategy.OnPush, imports: [
AsyncPipe,
ButtonModule,
DialogModule,
NgIf,
InputModule,
FormModule,
FormsModule,
TRANSLATE_MODULE,
K8S_UTIL_PIPES_MODULE,
], template: "<aui-dialog-header>\n {{ 'update_display_name' | 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 {{ 'display_name' | translate }}\n </label>\n <input\n *ngIf=\"!data.validateMaxLength; else validateMaxLength\"\n aui-input\n name=\"displayName\"\n autocomplete=\"off\"\n [(ngModel)]=\"displayName\"\n />\n <ng-template #validateMaxLength>\n <input\n aui-input\n name=\"displayName\"\n autocomplete=\"off\"\n [(ngModel)]=\"displayName\"\n [maxlength]=\"64\"\n />\n </ng-template>\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(UpdateDisplayNameDialogComponent, { className: "UpdateDisplayNameDialogComponent" }); })();
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"component.js","sourceRoot":"","sources":["../../../../../../libs/common/src/k8s-shared/update-display-name-dialog/component.ts","../../../../../../libs/common/src/k8s-shared/update-display-name-dialog/template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  DialogRef,\n  DIALOG_DATA,\n  ButtonModule,\n  DialogModule,\n  InputModule,\n  FormModule,\n} from '@alauda/ui';\nimport { AsyncPipe, NgIf } 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, K8sResourceDefinition } from '../../api/public-api';\nimport {\n  DISPLAY_NAME,\n  K8sUtilService,\n  KubernetesResource,\n  ResourceType,\n  K8S_UTIL_PIPES_MODULE,\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    NgIf,\n    InputModule,\n    FormModule,\n    FormsModule,\n    TRANSLATE_MODULE,\n    K8S_UTIL_PIPES_MODULE,\n  ],\n})\nexport class UpdateDisplayNameDialogComponent<T extends KubernetesResource> {\n  displayName = this.k8sUtil.getDisplayName(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      validateMaxLength?: boolean;\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(DISPLAY_NAME)]: this.displayName,\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_display_name' | 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      {{ 'display_name' | translate }}\n    </label>\n    <input\n      *ngIf=\"!data.validateMaxLength; else validateMaxLength\"\n      aui-input\n      name=\"displayName\"\n      autocomplete=\"off\"\n      [(ngModel)]=\"displayName\"\n    />\n    <ng-template #validateMaxLength>\n      <input\n        aui-input\n        name=\"displayName\"\n        autocomplete=\"off\"\n        [(ngModel)]=\"displayName\"\n        [maxlength]=\"64\"\n      />\n    </ng-template>\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"]}