UNPKG

geminis-ng

Version:

This library was generated with [Angular CLI](https://github.com/angular/angular-cli) version 8.2.14.

149 lines 17.4 kB
import { ChangeDetectorRef, Directive, ElementRef, Input, Optional, Renderer2 } from '@angular/core'; import { ControlContainer, FormGroup, FormGroupDirective } from '@angular/forms'; import { HttpClient } from '@angular/common/http'; import { NzModalRef } from 'ng-zorro-antd/modal'; import { GnJsonUtils, GnObjectUtils } from 'geminis-ng-core'; export function controlContainerFactory() { const formGroupDirective = new FormGroupDirective([], []); formGroupDirective.form = new FormGroup({}); return formGroupDirective; } export class GnFormDirective { constructor(controlContainer, elementRef, renderer, http, changeDetectorRef, modalRef) { this.controlContainer = controlContainer; this.elementRef = elementRef; this.renderer = renderer; this.http = http; this.changeDetectorRef = changeDetectorRef; this.binded = false; this.labelWidth = 6; this.controlWidth = 18; this.autoLoadData = true; this.submitMethod = 'put'; this.loadMethod = 'post'; this.format = 'json'; this.formGroup = controlContainer.control; this.formGroup.valueChanges.subscribe(newValue => { if (modalRef) { modalRef.updateConfig({ nzOkDisabled: this.formGroup.invalid }); } if (this.innerBindValue && this.binded) { Object.assign(this.innerBindValue, newValue); } }); } set cols(value) { this.colsValue = value; if (!this.colsValue || this.colsValue < 1) { return; } this.renderer.setStyle(this.elementRef.nativeElement, 'display', 'grid'); this.renderer.setStyle(this.elementRef.nativeElement, 'grid-template-columns', 'repeat(' + this.colsValue + ', 1fr)'); } get cols() { return this.colsValue; } set bindValue(value) { this.binded = false; this.innerBindValue = value; this.formGroup.patchValue(value); this.binded = true; } setValue(value) { this.defaultValue = value; this.formGroup.patchValue(value); } get submitValue() { let submitValue; if (this.defaultValue) { submitValue = Object.assign(GnObjectUtils.deepCopy(this.defaultValue), this.formGroup.value); } else { submitValue = this.formGroup.value; } if (this.format === 'form') { submitValue = GnJsonUtils.obj2FormData(submitValue); } return submitValue; } submit() { if (!this.url) { return Promise.resolve(this.submitValue); } else { const options = Object.assign({ body: this.submitValue }, this.submitOptions); return this.http.request(this.submitMethod, this.url, options).toPromise(); } } loadData() { if (!this.url || !this.dataId) { if (this.defaultValue) { this.formGroup.patchValue(this.defaultValue); } return Promise.resolve(null); } const queryParameter = { pageSize: 1, pageIndex: 0, includes: this.dataIncludes, filterGroup: { type: 'and', filters: [{ field: this.dataKey, compareType: '=', value: this.dataId }] } }; const options = Object.assign({ body: queryParameter }, this.loadOptions); return this.http.request(this.loadMethod, this.url, options) .toPromise() .then((resp) => { if (resp.content.length === 0) { throw new Error(`未找到数据[${this.dataId}]`); } this.defaultValue = this.defaultValue || {}; Object.assign(this.defaultValue, resp.content[0]); this.formGroup.patchValue(this.defaultValue); return this.defaultValue; }); } ngOnInit() { if (this.autoLoadData) { this.loadData(); } } ngAfterViewInit() { this.changeDetectorRef.detectChanges(); } } GnFormDirective.decorators = [ { type: Directive, args: [{ selector: '[gn-form]', providers: [ { provide: ControlContainer, useFactory: controlContainerFactory } ] },] } ]; GnFormDirective.ctorParameters = () => [ { type: ControlContainer }, { type: ElementRef }, { type: Renderer2 }, { type: HttpClient }, { type: ChangeDetectorRef }, { type: NzModalRef, decorators: [{ type: Optional }] } ]; GnFormDirective.propDecorators = { url: [{ type: Input }], labelWidth: [{ type: Input }], controlWidth: [{ type: Input }], dataId: [{ type: Input }], dataKey: [{ type: Input }], dataIncludes: [{ type: Input }], autoLoadData: [{ type: Input }], submitMethod: [{ type: Input }], loadMethod: [{ type: Input }], format: [{ type: Input }], submitOptions: [{ type: Input }], loadOptions: [{ type: Input }], defaultValue: [{ type: Input }], cols: [{ type: Input }], bindValue: [{ type: Input }] }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form.directive.js","sourceRoot":"","sources":["../../../../projects/geminis-ng/src/form/form.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectorRef,\n  Directive,\n  ElementRef,\n  Input,\n  OnInit,\n  Optional,\n  Renderer2\n} from '@angular/core';\nimport {ControlContainer, FormGroup, FormGroupDirective} from '@angular/forms';\nimport {HttpClient} from '@angular/common/http';\nimport {NzModalRef} from 'ng-zorro-antd/modal';\nimport {GnJsonUtils, GnObjectUtils} from 'geminis-ng-core';\n\nexport function controlContainerFactory(): FormGroupDirective {\n  const formGroupDirective = new FormGroupDirective([], []);\n  formGroupDirective.form = new FormGroup({});\n  return formGroupDirective;\n}\n\n@Directive({\n  selector: '[gn-form]',\n  providers: [\n    {provide: ControlContainer, useFactory: controlContainerFactory}\n  ]\n})\nexport class GnFormDirective implements OnInit, AfterViewInit {\n\n  private colsValue: number;\n  private innerBindValue: any;\n  private binded = false;\n\n  formGroup: FormGroup;\n\n  @Input() url: string;\n  @Input() labelWidth = 6;\n  @Input() controlWidth = 18;\n  @Input() dataId: string;\n  @Input() dataKey: string;\n  @Input() dataIncludes: string[];\n  @Input() autoLoadData = true;\n  @Input() submitMethod: 'post' | 'put' = 'put';\n  @Input() loadMethod: 'post' | 'put' | 'get' = 'post';\n  @Input() format: 'json' | 'form' = 'json';\n  @Input() submitOptions: any;\n  @Input() loadOptions: any;\n  @Input() defaultValue: any;\n\n  @Input() set cols(value: number) {\n    this.colsValue = value;\n    if (!this.colsValue || this.colsValue < 1) {\n      return;\n    }\n    this.renderer.setStyle(this.elementRef.nativeElement, 'display', 'grid');\n    this.renderer.setStyle(this.elementRef.nativeElement, 'grid-template-columns', 'repeat(' + this.colsValue + ', 1fr)');\n  }\n\n  get cols(): number {\n    return this.colsValue;\n  }\n\n  @Input() set bindValue(value: any) {\n    this.binded = false;\n    this.innerBindValue = value;\n    this.formGroup.patchValue(value);\n    this.binded = true;\n  }\n\n  constructor(private controlContainer: ControlContainer,\n              private elementRef: ElementRef,\n              private renderer: Renderer2,\n              private http: HttpClient,\n              private changeDetectorRef: ChangeDetectorRef,\n              @Optional() modalRef: NzModalRef) {\n    this.formGroup = controlContainer.control as FormGroup;\n    this.formGroup.valueChanges.subscribe(newValue => {\n      if (modalRef) {\n        modalRef.updateConfig({nzOkDisabled: this.formGroup.invalid});\n      }\n      if (this.innerBindValue && this.binded) {\n        Object.assign(this.innerBindValue, newValue);\n      }\n    });\n  }\n\n  setValue(value: any): void {\n    this.defaultValue = value;\n    this.formGroup.patchValue(value);\n  }\n\n  get submitValue(): any {\n    let submitValue: any;\n\n    if (this.defaultValue) {\n      submitValue = Object.assign(GnObjectUtils.deepCopy(this.defaultValue), this.formGroup.value);\n    } else {\n      submitValue = this.formGroup.value;\n    }\n\n    if (this.format === 'form') {\n      submitValue = GnJsonUtils.obj2FormData(submitValue);\n    }\n\n    return submitValue;\n  }\n\n  submit(): Promise<any> {\n    if (!this.url) {\n      return Promise.resolve(this.submitValue);\n    } else {\n      const options = Object.assign({body: this.submitValue}, this.submitOptions);\n      return this.http.request(this.submitMethod, this.url, options).toPromise();\n    }\n  }\n\n  loadData(): Promise<any> {\n    if (!this.url || !this.dataId) {\n      if (this.defaultValue) {\n        this.formGroup.patchValue(this.defaultValue);\n      }\n      return Promise.resolve(null);\n    }\n\n    const queryParameter = {\n      pageSize: 1,\n      pageIndex: 0,\n      includes: this.dataIncludes,\n      filterGroup: {\n        type: 'and',\n        filters: [{field: this.dataKey, compareType: '=', value: this.dataId}]\n      }\n    };\n\n    const options = Object.assign({body: queryParameter}, this.loadOptions);\n\n    return this.http.request(this.loadMethod, this.url, options)\n      .toPromise()\n      .then((resp: any) => {\n        if (resp.content.length === 0) {\n          throw new Error(`未找到数据[${this.dataId}]`);\n        }\n        this.defaultValue = this.defaultValue || {};\n        Object.assign(this.defaultValue, resp.content[0]);\n        this.formGroup.patchValue(this.defaultValue);\n        return this.defaultValue;\n      });\n  }\n\n  ngOnInit(): void {\n    if (this.autoLoadData) {\n      this.loadData();\n    }\n  }\n\n  ngAfterViewInit(): void {\n    this.changeDetectorRef.detectChanges();\n  }\n\n}\n"]}