UNPKG

@alauda-fe/common

Version:

Alauda frontend team common codes.

140 lines 16.4 kB
import { __decorate, __metadata } from "tslib"; import { NotificationService } from '@alauda/ui'; import { Location } from '@angular/common'; import { Directive, Injector, Input, ViewChild } from '@angular/core'; import { FormBuilder, NgForm } from '@angular/forms'; import { identity } from 'lodash-es'; import { dissocPath } from 'ramda'; import { Observable } from 'rxjs'; import { createActions, yamlWriteOptions, } from '../../code/code-editor-configs'; import { InterceptDeactivateService } from '../public-api'; import { isErrorMessage } from '../types/public-api'; import { ObservableInput } from '../utils/decorators'; import { parseAll, stringify } from '../utils/yaml'; import * as i0 from "@angular/core"; const _c0 = ["resourceForm"]; /** * http://confluence.alauda.cn/display/FRON/Issue-Angular+related * 由于formControl存在内存泄漏问题,内部 form 展示-隐藏切换应当采用 hidden 进行控制 */ export class BaseFormContainer { constructor(injector) { this.isUpdate = false; this.hideManagedFields = true; this.codeEditorOptions = yamlWriteOptions; this.actionsConfig = createActions; this.formView = 'UI'; this.submitting = false; this.fillResource = identity; this.notification = injector.get(NotificationService); this.location = injector.get(Location); this.fb = injector.get(FormBuilder); this.interceptDeactivate = injector.get(InterceptDeactivateService); this.form = this.fb.group({ resource: this.fb.control('') }); } ngOnInit() { this.resource = this.initResource; this.form.patchValue({ resource: this.initResource, }); this.originalYaml = this.resourceToYaml(this.initResource); } switchFormView(view) { let resource; if (view === 'UI') { try { resource = this.yamlToResource(this.yaml); this.form.patchValue({ resource, }); } catch (err) { console.error(err); } } else { resource = this.form.get('resource').value; this.yaml = this.resourceToYaml(resource); } this.resource = resource; this.formView = view; } cancel(escape) { this.interceptDeactivate.back(escape); } checkForm() { this.ngForm.onSubmit(null); if (this.formView === 'UI' && this.ngForm.invalid) { return false; } if (this.formView === 'YAML') { try { this.resource = this.yamlToResource(this.yaml); return true; } catch { return false; } } const resource = this.form.get('resource').value; this.resource = this.fillResource(resource); return true; } yamlToResource(yaml) { try { const all = parseAll(yaml); return (Array.isArray(this.resource) ? all : all[0]); } catch (e) { if (isErrorMessage(e)) { this.notification.error(e.message); } throw e; } } resourceToYaml(resource) { try { if (Array.isArray(resource)) { return resource.map(r => this.stringifyResource(r)).join('\n---\r\n\n'); } return this.stringifyResource(resource); } catch (error) { console.error(error); return '{}'; } } updateResource(resource) { this.form.patchValue({ resource }); this.resource = resource; } stringifyResource(resource) { return stringify(this.hideManagedFields ? dissocPath(['metadata', 'managedFields'], resource) : resource, { blockQuote: 'literal' }); } static { this.ɵfac = function BaseFormContainer_Factory(t) { return new (t || BaseFormContainer)(i0.ɵɵdirectiveInject(i0.Injector)); }; } static { this.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: BaseFormContainer, viewQuery: function BaseFormContainer_Query(rf, ctx) { if (rf & 1) { i0.ɵɵviewQuery(_c0, 5); } if (rf & 2) { let _t; i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.ngForm = _t.first); } }, inputs: { isUpdate: "isUpdate", initResource: "initResource", hideManagedFields: "hideManagedFields" } }); } } __decorate([ ObservableInput(), __metadata("design:type", Observable) ], BaseFormContainer.prototype, "initResource$", void 0); (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(BaseFormContainer, [{ type: Directive }], () => [{ type: i0.Injector }], { isUpdate: [{ type: Input }], initResource: [{ type: Input }], initResource$: [], hideManagedFields: [{ type: Input }], ngForm: [{ type: ViewChild, args: ['resourceForm', { static: false }] }] }); })(); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-form-container.js","sourceRoot":"","sources":["../../../../../../libs/common/src/core/abstract/base-form-container.ts"],"names":[],"mappings":"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","sourcesContent":["import { NotificationService } from '@alauda/ui';\nimport { Location } from '@angular/common';\nimport { Directive, Injector, Input, OnInit, ViewChild } from '@angular/core';\nimport { FormBuilder, FormGroup, NgForm } from '@angular/forms';\nimport { identity } from 'lodash-es';\nimport { dissocPath } from 'ramda';\nimport { Observable } from 'rxjs';\n\nimport {\n  createActions,\n  yamlWriteOptions,\n} from '../../code/code-editor-configs';\nimport { InterceptDeactivateService } from '../public-api';\nimport { isErrorMessage } from '../types/public-api';\nimport { ObservableInput } from '../utils/decorators';\nimport { parseAll, stringify } from '../utils/yaml';\n\n/**\n * http://confluence.alauda.cn/display/FRON/Issue-Angular+related\n * 由于formControl存在内存泄漏问题，内部 form 展示-隐藏切换应当采用 hidden 进行控制\n */\n@Directive()\nexport abstract class BaseFormContainer<T = any> implements OnInit {\n  @Input()\n  isUpdate = false;\n\n  @Input()\n  initResource: T;\n\n  @ObservableInput()\n  initResource$: Observable<T>;\n\n  @Input()\n  hideManagedFields = true;\n\n  @ViewChild('resourceForm', { static: false })\n  private readonly ngForm: NgForm;\n\n  codeEditorOptions = yamlWriteOptions;\n  actionsConfig = createActions;\n  formView: 'UI' | 'YAML' = 'UI';\n  submitting = false;\n\n  resource: T;\n  yaml: string;\n  // 支持带 '恢复' 的 codeEditor\n  originalYaml: string;\n  fb: FormBuilder;\n  interceptDeactivate: InterceptDeactivateService;\n\n  form: FormGroup;\n\n  protected notification: NotificationService;\n  protected location: Location;\n  protected fillResource: (resource: T) => T = identity;\n\n  abstract submit(params?: unknown): void;\n\n  constructor(injector: Injector) {\n    this.notification = injector.get(NotificationService);\n    this.location = injector.get(Location);\n    this.fb = injector.get(FormBuilder);\n    this.interceptDeactivate = injector.get(InterceptDeactivateService);\n    this.form = this.fb.group({ resource: this.fb.control('') });\n  }\n\n  ngOnInit() {\n    this.resource = this.initResource;\n    this.form.patchValue({\n      resource: this.initResource,\n    });\n    this.originalYaml = this.resourceToYaml(this.initResource);\n  }\n\n  switchFormView(view: 'YAML' | 'UI') {\n    let resource: T;\n    if (view === 'UI') {\n      try {\n        resource = this.yamlToResource(this.yaml);\n        this.form.patchValue({\n          resource,\n        });\n      } catch (err) {\n        console.error(err);\n      }\n    } else {\n      resource = this.form.get('resource').value;\n      this.yaml = this.resourceToYaml(resource);\n    }\n    this.resource = resource;\n    this.formView = view;\n  }\n\n  cancel(escape?: boolean) {\n    this.interceptDeactivate.back(escape);\n  }\n\n  protected checkForm() {\n    this.ngForm.onSubmit(null);\n    if (this.formView === 'UI' && this.ngForm.invalid) {\n      return false;\n    }\n    if (this.formView === 'YAML') {\n      try {\n        this.resource = this.yamlToResource(this.yaml);\n        return true;\n      } catch {\n        return false;\n      }\n    }\n    const resource = this.form.get('resource').value as T;\n    this.resource = this.fillResource(resource);\n\n    return true;\n  }\n\n  protected yamlToResource(yaml: string): T {\n    try {\n      const all = parseAll(yaml);\n      return (Array.isArray(this.resource) ? all : all[0]) as T;\n    } catch (e) {\n      if (isErrorMessage(e)) {\n        this.notification.error(e.message);\n      }\n      throw e;\n    }\n  }\n\n  protected resourceToYaml(resource: T) {\n    try {\n      if (Array.isArray(resource)) {\n        return resource.map(r => this.stringifyResource(r)).join('\\n---\\r\\n\\n');\n      }\n      return this.stringifyResource(resource);\n    } catch (error) {\n      console.error(error);\n      return '{}';\n    }\n  }\n\n  protected updateResource(resource: T) {\n    this.form.patchValue({ resource });\n    this.resource = resource;\n  }\n\n  protected stringifyResource(resource: T) {\n    return stringify(\n      this.hideManagedFields\n        ? dissocPath(['metadata', 'managedFields'], resource)\n        : resource,\n      { blockQuote: 'literal' },\n    );\n  }\n}\n"]}