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
JavaScript
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"]}