Press n or j to go to the next uncovered block, b, p or k for the previous block.
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 | 225x 225x 227x 106x 107x 22x 2x 2x 2x 1x 1x 1x 1x | import { Observable, Subject } from 'rxjs';
import { DynamicFormGroup } from '../dynamic-form-group/dynamic-form-group';
import { extractFiles } from '../dynamic-form-input/dynamic-form-file/dynamic-form-file-helpers';
import { DynamicFormDefinition } from './dynamic-form-definition';
import { DynamicFormTemplate } from './dynamic-form-template';
import { DynamicFormBuilder } from './dynamic-form.builder';
export class DynamicForm<
Value extends { [key: string]: any } = any, Model extends Value = Value,
> extends DynamicFormGroup<Value, Model, DynamicFormTemplate, DynamicFormDefinition> {
private readonly _submit = new Subject<boolean>();
private readonly _submit$ = this._submit.asObservable();
constructor(builder: DynamicFormBuilder, definition: DynamicFormDefinition, model: Model) {
super(builder, definition, model);
}
override get hidden(): boolean { return this.template.hidden || false; }
override get readonly(): boolean { return this.template.readonly || false; }
get submit$(): Observable<boolean> { return this._submit$; }
submit(): void {
this._submit.next(true);
}
getFiles(): FormData {
const files = extractFiles(this.value);
if (!files.length) {
return undefined;
}
const formData = new FormData();
files.forEach(({ key, file }) => formData.append(key, file));
return formData;
}
protected override initId(): void {}
}
|