@c-standard/angular-devui-extension
Version:
an extensional components lib for devui
163 lines • 26.5 kB
JavaScript
import { Component, ContentChildren, EventEmitter, Input, Output, ViewChild, } from '@angular/core';
import { forEach, isEmpty, isNull, isObject, mergeWith } from 'lodash-es';
import { FormDirective, FormLayout } from 'ng-devui/form';
import { FormField } from './form-field';
import { TemplateDirective } from '@c-standard/angular-devui-extension/template';
import * as i0 from "@angular/core";
import * as i1 from "@angular/forms";
import * as i2 from "./form-plus-item.component";
import * as i3 from "ng-devui";
import * as i4 from "@angular/cdk/scrolling";
import * as i5 from "@angular/common";
export class FormPlusComponent {
constructor(fb, ref, _cdr) {
this.fb = fb;
this.ref = ref;
this._cdr = _cdr;
this.loading = false;
this.readonly = false;
this.initialized = new EventEmitter();
this.fieldDataChanged = new EventEmitter();
this.formSubmit = new EventEmitter();
this.layoutDirection = FormLayout.Horizontal;
this.formGroup = this.fb.group({});
}
set data(value) {
this._data = value;
if (this._data) {
this.formGroup.patchValue(this._data);
}
}
get layout() {
return (this._layout = 'horizontal');
}
set layout(value) {
this._layout = value;
if (this._layout) {
this._layout == 'vertical'
? (this.layoutDirection = FormLayout.Vertical)
: (this.layoutDirection = FormLayout.Horizontal);
}
}
ngOnInit() {
this.initialized.emit({
element: this.ref.nativeElement,
component: this,
});
}
ngAfterContentInit() {
this.addFormControls(this.fields);
this.fields?.changes.subscribe((f) => {
this.addFormControls(f);
});
// this.formGroup.patchValue(this._data);
this.formGroup.valueChanges.subscribe((value) => {
this.fieldDataChanged.emit(value);
});
}
addFormControls(fields) {
if (!fields)
return;
// dynamic add、set or remove control
const changedNames = [];
forEach(fields.toArray(), (t) => {
if (this.formGroup.contains(t.field)) {
this.formGroup.setControl(t.field, t.control);
}
else {
this.formGroup.addControl(t.field, t.control);
}
changedNames.push(t.field);
});
// Note 表单field发生改变时,移除对应的control以保证校验通过
const controlNames = Object.keys(this.formGroup.controls);
controlNames.forEach((name) => {
if (!changedNames.find((t) => t == name)) {
this.formGroup.removeControl(name);
}
});
// Note: 当表单field改变时,其对应的默认值再次填充
this.formGroup.patchValue(mergeWith(this.formGroup.value, this._data, (o, s) => (isEmpty(o) ? s : o)));
}
get templates() {
if (this.itemDefinitions != null) {
const itemTemplates = {};
for (const definition of this.itemDefinitions.toArray()) {
itemTemplates[definition.template] = definition.templateRef;
}
return itemTemplates;
}
else {
return {};
}
}
setValue(value) {
if (isObject(value) && !isNull(value)) {
this.formGroup.patchValue(value);
}
}
submit(e) {
this.formSubmit.emit({
valid: e.valid,
});
}
check() {
this.devuiForm?.updateOnSubmit();
}
get valid() {
this.check();
return this.formGroup.valid;
}
get value() {
return {
...this._data,
...this.formGroup.value,
};
}
}
FormPlusComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: FormPlusComponent, deps: [{ token: i1.FormBuilder }, { token: i0.ElementRef }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
FormPlusComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.7", type: FormPlusComponent, selector: "d-form-plus", inputs: { data: "data", layout: "layout", items: "items", loading: "loading", readonly: "readonly", validateRules: "validateRules", height: "height", maxHeight: "maxHeight" }, outputs: { initialized: "initialized", fieldDataChanged: "fieldDataChanged", formSubmit: "formSubmit" }, queries: [{ propertyName: "itemDefinitions", predicate: TemplateDirective }, { propertyName: "fields", predicate: FormField }], viewQueries: [{ propertyName: "devuiForm", first: true, predicate: FormDirective, descendants: true }], ngImport: i0, template: "<form\r\n dForm\r\n ngForm\r\n cdkScrollable\r\n labelAlign=\"start\"\r\n labelSize=\"sm\"\r\n dLoading\r\n [formGroup]=\"formGroup\"\r\n [dValidateRules]=\"validateRules\"\r\n [showLoading]=\"loading\"\r\n [layout]=\"layoutDirection\"\r\n [style.height]=\"height\"\r\n [style.max-height]=\"maxHeight\"\r\n (dSubmit)=\"submit($event)\"\r\n>\r\n <d-form-plus-item\r\n *ngFor=\"let item of items\"\r\n [field]=\"item.field\"\r\n [helpText]=\"item.helpText || ''\"\r\n [label]=\"item.label\"\r\n [option]=\"item.options\"\r\n [dataType]=\"item.dataType\"\r\n [required]=\"item.required || false\"\r\n [validateRules]=\"item.validateRules || []\"\r\n [showLabel]=\"item.showLabel || true\"\r\n [template]=\"item.template\"\r\n [disabled]=\"item.disabled\"\r\n >\r\n <ng-container *ngIf=\"item.template\">\r\n <ng-container\r\n [ngTemplateOutletContext]=\"{ $implicit: { item: item } }\"\r\n [ngTemplateOutlet]=\"templates[item.template || ''] || defaultItemTemplate\"\r\n >\r\n </ng-container>\r\n <ng-template #defaultItemTemplate>\r\n <span>formTmpl:{{ item.template }}</span>\r\n </ng-template>\r\n </ng-container>\r\n </d-form-plus-item>\r\n <ng-content></ng-content>\r\n</form>\r\n", styles: ["form{padding:0 1rem;overflow:auto;max-height:60vh}\n"], components: [{ type: i2.FormPlusItemComponent, selector: "d-form-plus-item", inputs: ["showLabel", "label", "field", "dataType", "helpText", "option", "required", "disabled", "template", "validateRules"] }], directives: [{ type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i3.DFormGroupRuleDirective, selector: "[dValidateRules][formGroupName],[dValidateRules][formArrayName],[dValidateRules][ngModelGroup], [dValidateRules][formGroup],[dValidateRules]form:not([ngNoForm]),[dValidateRules][ngForm]", inputs: ["dValidateRules"], outputs: ["dRulesStatusChange"], exportAs: ["dValidateRules"] }, { type: i3.FormDirective, selector: "[dForm]", inputs: ["layout", "labelSize", "labelAlign", "dFeedbackType", "dHasFeedback"], outputs: ["dSubmit"], exportAs: ["dForm"] }, { type: i1.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i4.CdkScrollable, selector: "[cdk-scrollable], [cdkScrollable]" }, { type: i3.LoadingDirective, selector: "[dLoading]", inputs: ["message", "backdrop", "loadingTemplateRef", "positionType", "view", "showLoading", "loading", "zIndex"], exportAs: ["dLoading"] }, { type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i5.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }] });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: FormPlusComponent, decorators: [{
type: Component,
args: [{ selector: 'd-form-plus', styles: [
`
form {
padding: 0 1rem;
overflow: auto;
max-height: 60vh;
}
`,
], template: "<form\r\n dForm\r\n ngForm\r\n cdkScrollable\r\n labelAlign=\"start\"\r\n labelSize=\"sm\"\r\n dLoading\r\n [formGroup]=\"formGroup\"\r\n [dValidateRules]=\"validateRules\"\r\n [showLoading]=\"loading\"\r\n [layout]=\"layoutDirection\"\r\n [style.height]=\"height\"\r\n [style.max-height]=\"maxHeight\"\r\n (dSubmit)=\"submit($event)\"\r\n>\r\n <d-form-plus-item\r\n *ngFor=\"let item of items\"\r\n [field]=\"item.field\"\r\n [helpText]=\"item.helpText || ''\"\r\n [label]=\"item.label\"\r\n [option]=\"item.options\"\r\n [dataType]=\"item.dataType\"\r\n [required]=\"item.required || false\"\r\n [validateRules]=\"item.validateRules || []\"\r\n [showLabel]=\"item.showLabel || true\"\r\n [template]=\"item.template\"\r\n [disabled]=\"item.disabled\"\r\n >\r\n <ng-container *ngIf=\"item.template\">\r\n <ng-container\r\n [ngTemplateOutletContext]=\"{ $implicit: { item: item } }\"\r\n [ngTemplateOutlet]=\"templates[item.template || ''] || defaultItemTemplate\"\r\n >\r\n </ng-container>\r\n <ng-template #defaultItemTemplate>\r\n <span>formTmpl:{{ item.template }}</span>\r\n </ng-template>\r\n </ng-container>\r\n </d-form-plus-item>\r\n <ng-content></ng-content>\r\n</form>\r\n" }]
}], ctorParameters: function () { return [{ type: i1.FormBuilder }, { type: i0.ElementRef }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { data: [{
type: Input
}], layout: [{
type: Input
}], items: [{
type: Input
}], loading: [{
type: Input
}], readonly: [{
type: Input
}], validateRules: [{
type: Input
}], height: [{
type: Input
}], maxHeight: [{
type: Input
}], initialized: [{
type: Output
}], fieldDataChanged: [{
type: Output
}], formSubmit: [{
type: Output
}], devuiForm: [{
type: ViewChild,
args: [FormDirective]
}], itemDefinitions: [{
type: ContentChildren,
args: [TemplateDirective]
}], fields: [{
type: ContentChildren,
args: [FormField]
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-plus.component.js","sourceRoot":"","sources":["../../../../projects/components/form/form-plus.component.ts","../../../../projects/components/form/form-plus.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    AfterContentInit,\r\n    ChangeDetectorRef,\r\n    Component,\r\n    ContentChildren,\r\n    ElementRef,\r\n    EventEmitter,\r\n    Input,\r\n    OnInit,\r\n    Output,\r\n    QueryList,\r\n    TemplateRef,\r\n    ViewChild,\r\n} from '@angular/core';\r\nimport { forEach, isEmpty, isNull, isObject, mergeWith } from 'lodash-es';\r\nimport { DFormGroupRuleDirective, DValidateRules, FormDirective, FormLayout } from 'ng-devui/form';\r\nimport { FormField } from './form-field';\r\nimport { DFormItem, DFormLayout, DFormValidator } from './form';\r\nimport { AbstractControlDirective, FormBuilder, FormGroup } from '@angular/forms';\r\nimport { TemplateDirective } from '@c-standard/angular-devui-extension/template'\r\n\r\n@Component({\r\n    selector: 'd-form-plus',\r\n    templateUrl: './form-plus.component.html',\r\n    // encapsulation: ViewEncapsulation.None,\r\n    styles: [\r\n        `\r\n            form {\r\n                padding: 0 1rem;\r\n                overflow: auto;\r\n                max-height: 60vh;\r\n            }\r\n        `,\r\n    ],\r\n    // changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class FormPlusComponent implements OnInit, AfterContentInit {\r\n    private _data: any;\r\n\r\n    @Input()\r\n    set data(value: any) {\r\n        this._data = value;\r\n        if (this._data) {\r\n            this.formGroup.patchValue(this._data);\r\n        }\r\n    }\r\n\r\n    private _layout?: DFormLayout;\r\n    get layout(): DFormLayout {\r\n        return (this._layout = 'horizontal');\r\n    }\r\n\r\n    @Input()\r\n    set layout(value: DFormLayout) {\r\n        this._layout = value;\r\n        if (this._layout) {\r\n            this._layout == 'vertical'\r\n                ? (this.layoutDirection = FormLayout.Vertical)\r\n                : (this.layoutDirection = FormLayout.Horizontal);\r\n        }\r\n    }\r\n\r\n    @Input() items?: DFormItem[];\r\n    @Input() loading: boolean = false;\r\n    @Input() readonly: boolean = false;\r\n    @Input() validateRules!: DValidateRules;\r\n    @Input() height?: string;\r\n    @Input() maxHeight?: string;\r\n    @Output() initialized: EventEmitter<any> = new EventEmitter<any>();\r\n    @Output() fieldDataChanged: EventEmitter<any> = new EventEmitter<any>();\r\n    @Output() formSubmit: EventEmitter<DFormValidator> = new EventEmitter<DFormValidator>();\r\n\r\n    @ViewChild(FormDirective) devuiForm?: FormDirective;\r\n    @ContentChildren(TemplateDirective) itemDefinitions!: QueryList<TemplateDirective>;\r\n    @ContentChildren(FormField) fields?: QueryList<FormField>;\r\n\r\n    formGroup: FormGroup;\r\n    layoutDirection: FormLayout = FormLayout.Horizontal;\r\n\r\n    constructor(private fb: FormBuilder, private ref: ElementRef, private _cdr: ChangeDetectorRef) {\r\n        this.formGroup = this.fb.group({});\r\n    }\r\n\r\n    ngOnInit(): void {\r\n        this.initialized.emit({\r\n            element: this.ref.nativeElement,\r\n            component: this,\r\n        });\r\n    }\r\n\r\n    ngAfterContentInit(): void {\r\n        this.addFormControls(this.fields);\r\n        this.fields?.changes.subscribe((f) => {\r\n            this.addFormControls(f);\r\n        });\r\n        // this.formGroup.patchValue(this._data);\r\n        this.formGroup.valueChanges.subscribe((value) => {\r\n            this.fieldDataChanged.emit(value);\r\n        });\r\n    }\r\n\r\n    private addFormControls(fields?: QueryList<FormField>) {\r\n        if (!fields) return;\r\n        // dynamic add、set or remove control\r\n        const changedNames: string[] = [];\r\n        forEach(fields.toArray(), (t) => {\r\n            if (this.formGroup.contains(t.field)) {\r\n                this.formGroup.setControl(t.field, t.control);\r\n            } else {\r\n                this.formGroup.addControl(t.field, t.control);\r\n            }\r\n            changedNames.push(t.field);\r\n        });\r\n        // Note 表单field发生改变时，移除对应的control以保证校验通过\r\n        const controlNames = Object.keys(this.formGroup.controls);\r\n        controlNames.forEach((name) => {\r\n            if (!changedNames.find((t) => t == name)) {\r\n                this.formGroup.removeControl(name);\r\n            }\r\n        });\r\n        // Note: 当表单field改变时，其对应的默认值再次填充\r\n        this.formGroup.patchValue(\r\n            mergeWith(this.formGroup.value, this._data, (o, s) => (isEmpty(o) ? s : o))\r\n        );\r\n    }\r\n\r\n    public get templates(): { [key: string]: TemplateRef<any> } {\r\n        if (this.itemDefinitions != null) {\r\n            const itemTemplates: { [key: string]: TemplateRef<any> } = {};\r\n            for (const definition of this.itemDefinitions.toArray()) {\r\n                itemTemplates[definition.template] = definition.templateRef;\r\n            }\r\n            return itemTemplates;\r\n        } else {\r\n            return {};\r\n        }\r\n    }\r\n\r\n    setValue(value: any) {\r\n        if (isObject(value) && !isNull(value)) {\r\n            this.formGroup.patchValue(value);\r\n        }\r\n    }\r\n\r\n    submit(e: { valid: boolean; directive: DFormGroupRuleDirective | AbstractControlDirective }) {\r\n        this.formSubmit.emit({\r\n            valid: e.valid,\r\n        });\r\n    }\r\n\r\n    check() {\r\n        this.devuiForm?.updateOnSubmit();\r\n    }\r\n\r\n    get valid() {\r\n        this.check();\r\n        return this.formGroup.valid;\r\n    }\r\n\r\n    get value() {\r\n        return {\r\n            ...this._data,\r\n            ...this.formGroup.value,\r\n        };\r\n    }\r\n}\r\n","<form\r\n    dForm\r\n    ngForm\r\n    cdkScrollable\r\n    labelAlign=\"start\"\r\n    labelSize=\"sm\"\r\n    dLoading\r\n    [formGroup]=\"formGroup\"\r\n    [dValidateRules]=\"validateRules\"\r\n    [showLoading]=\"loading\"\r\n    [layout]=\"layoutDirection\"\r\n    [style.height]=\"height\"\r\n    [style.max-height]=\"maxHeight\"\r\n    (dSubmit)=\"submit($event)\"\r\n>\r\n    <d-form-plus-item\r\n        *ngFor=\"let item of items\"\r\n        [field]=\"item.field\"\r\n        [helpText]=\"item.helpText || ''\"\r\n        [label]=\"item.label\"\r\n        [option]=\"item.options\"\r\n        [dataType]=\"item.dataType\"\r\n        [required]=\"item.required || false\"\r\n        [validateRules]=\"item.validateRules || []\"\r\n        [showLabel]=\"item.showLabel || true\"\r\n        [template]=\"item.template\"\r\n        [disabled]=\"item.disabled\"\r\n    >\r\n        <ng-container *ngIf=\"item.template\">\r\n            <ng-container\r\n                [ngTemplateOutletContext]=\"{ $implicit: { item: item } }\"\r\n                [ngTemplateOutlet]=\"templates[item.template || ''] || defaultItemTemplate\"\r\n            >\r\n            </ng-container>\r\n            <ng-template #defaultItemTemplate>\r\n                <span>formTmpl:{{ item.template }}</span>\r\n            </ng-template>\r\n        </ng-container>\r\n    </d-form-plus-item>\r\n    <ng-content></ng-content>\r\n</form>\r\n"]}