@stemy/ngx-dynamic-form 19.1.13 → 19.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/fesm2022/stemy-ngx-dynamic-form-ui-nebular.mjs +4 -4
- package/fesm2022/stemy-ngx-dynamic-form-ui-nebular.mjs.map +1 -1
- package/fesm2022/stemy-ngx-dynamic-form.mjs +859 -1662
- package/fesm2022/stemy-ngx-dynamic-form.mjs.map +1 -1
- package/ngx-dynamic-form/common-types.d.ts +109 -26
- package/ngx-dynamic-form/components/dynamic-form/dynamic-form.component.d.ts +21 -0
- package/ngx-dynamic-form/components/dynamic-form-array/dynamic-form-array.component.d.ts +9 -0
- package/ngx-dynamic-form/components/dynamic-form-chips/dynamic-form-chips.component.d.ts +7 -0
- package/ngx-dynamic-form/components/dynamic-form-field/dynamic-form-field.component.d.ts +6 -0
- package/ngx-dynamic-form/components/dynamic-form-fieldset/dynamic-form-fieldset.component.d.ts +7 -0
- package/ngx-dynamic-form/components/dynamic-form-group/dynamic-form-group.component.d.ts +6 -0
- package/ngx-dynamic-form/components/dynamic-form-upload/dynamic-form-upload.component.d.ts +7 -0
- package/ngx-dynamic-form/directives/async-submit.directive.d.ts +17 -23
- package/ngx-dynamic-form/ngx-dynamic-form.imports.d.ts +5 -9
- package/ngx-dynamic-form/ngx-dynamic-form.module.d.ts +13 -11
- package/ngx-dynamic-form/services/dynamic-form-builder.service.d.ts +27 -0
- package/ngx-dynamic-form/services/dynamic-form.service.d.ts +28 -46
- package/ngx-dynamic-form/utils/customizer.d.ts +5 -12
- package/ngx-dynamic-form/utils/decorators.d.ts +10 -0
- package/ngx-dynamic-form/utils/misc.d.ts +2 -4
- package/ngx-dynamic-form/utils/validation.d.ts +13 -0
- package/package.json +21 -16
- package/public_api.d.ts +13 -18
- package/ui-nebular/index.d.ts +1 -5
- package/common-types.d.ts +0 -37
- package/components/base/dynamic-base-form-array.component.d.ts +0 -38
- package/components/base/dynamic-base-form-control-container.component.d.ts +0 -39
- package/components/base/dynamic-base-form-control.component.d.ts +0 -26
- package/components/base/dynamic-base-form-group.component.d.ts +0 -25
- package/components/base/dynamic-base-form.component.d.ts +0 -46
- package/components/base/dynamic-base-select.component.d.ts +0 -15
- package/directives/async-submit.directive.d.ts +0 -31
- package/esm2020/ngx-dynamic-form/common-types.mjs +0 -2
- package/esm2020/ngx-dynamic-form/components/base/dynamic-base-form-array.component.mjs +0 -104
- package/esm2020/ngx-dynamic-form/components/base/dynamic-base-form-control-container.component.mjs +0 -127
- package/esm2020/ngx-dynamic-form/components/base/dynamic-base-form-control.component.mjs +0 -57
- package/esm2020/ngx-dynamic-form/components/base/dynamic-base-form-group.component.mjs +0 -75
- package/esm2020/ngx-dynamic-form/components/base/dynamic-base-form.component.mjs +0 -182
- package/esm2020/ngx-dynamic-form/components/base/dynamic-base-select.component.mjs +0 -66
- package/esm2020/ngx-dynamic-form/directives/async-submit.directive.mjs +0 -116
- package/esm2020/ngx-dynamic-form/ngx-dynamic-form.imports.mjs +0 -26
- package/esm2020/ngx-dynamic-form/ngx-dynamic-form.module.mjs +0 -116
- package/esm2020/ngx-dynamic-form/services/dynamic-form.service.mjs +0 -615
- package/esm2020/ngx-dynamic-form/utils/creators.mjs +0 -67
- package/esm2020/ngx-dynamic-form/utils/customizer.mjs +0 -28
- package/esm2020/ngx-dynamic-form/utils/dynamic-editor.model.mjs +0 -14
- package/esm2020/ngx-dynamic-form/utils/dynamic-form-array.model.mjs +0 -128
- package/esm2020/ngx-dynamic-form/utils/dynamic-form-group.model.mjs +0 -26
- package/esm2020/ngx-dynamic-form/utils/dynamic-select.model.mjs +0 -59
- package/esm2020/ngx-dynamic-form/utils/form-select-subject.mjs +0 -26
- package/esm2020/ngx-dynamic-form/utils/form-subject.mjs +0 -29
- package/esm2020/ngx-dynamic-form/utils/misc.mjs +0 -47
- package/esm2020/ngx-dynamic-form/utils/validation-errors.mjs +0 -22
- package/esm2020/ngx-dynamic-form/utils/validators.mjs +0 -56
- package/esm2020/public_api.mjs +0 -21
- package/esm2020/stemy-ngx-dynamic-form.mjs +0 -5
- package/fesm2015/stemy-ngx-dynamic-form.mjs +0 -1927
- package/fesm2015/stemy-ngx-dynamic-form.mjs.map +0 -1
- package/fesm2020/stemy-ngx-dynamic-form.mjs +0 -1893
- package/fesm2020/stemy-ngx-dynamic-form.mjs.map +0 -1
- package/fesm2022/stemy-ngx-dynamic-form-src-ngx-dynamic-form-nebular.mjs +0 -50
- package/fesm2022/stemy-ngx-dynamic-form-src-ngx-dynamic-form-nebular.mjs.map +0 -1
- package/imports.d.ts +0 -12
- package/ngx-dynamic-form/components/base/dynamic-base-form-array.component.d.ts +0 -38
- package/ngx-dynamic-form/components/base/dynamic-base-form-control-container.component.d.ts +0 -39
- package/ngx-dynamic-form/components/base/dynamic-base-form-control.component.d.ts +0 -26
- package/ngx-dynamic-form/components/base/dynamic-base-form-group.component.d.ts +0 -25
- package/ngx-dynamic-form/components/base/dynamic-base-form.component.d.ts +0 -46
- package/ngx-dynamic-form/components/base/dynamic-base-select.component.d.ts +0 -15
- package/ngx-dynamic-form/services/dynamic-form-layout.service.d.ts +0 -7
- package/ngx-dynamic-form/utils/creators.d.ts +0 -18
- package/ngx-dynamic-form/utils/dynamic-editor.model.d.ts +0 -11
- package/ngx-dynamic-form/utils/dynamic-form-array.model.d.ts +0 -69
- package/ngx-dynamic-form/utils/dynamic-form-group.model.d.ts +0 -14
- package/ngx-dynamic-form/utils/dynamic-select.model.d.ts +0 -39
- package/ngx-dynamic-form/utils/form-select-subject.d.ts +0 -6
- package/ngx-dynamic-form/utils/form-subject.d.ts +0 -10
- package/ngx-dynamic-form/utils/validators.d.ts +0 -8
- package/ngx-dynamic-form.imports.d.ts +0 -12
- package/ngx-dynamic-form.module.d.ts +0 -21
- package/services/dynamic-form.service.d.ts +0 -61
- package/src/ngx-dynamic-form/nebular/imports.d.ts +0 -4
- package/src/ngx-dynamic-form/nebular/index.d.ts +0 -5
- package/src/ngx-dynamic-form/nebular/ngx-dynamic-form.nebular.module.d.ts +0 -9
- package/src/ngx-dynamic-form/nebular/public_api.d.ts +0 -1
- package/stemy-ngx-dynamic-form.d.ts +0 -5
- package/ui-nebular/public_api.d.ts +0 -1
- package/utils/creators.d.ts +0 -18
- package/utils/customizer.d.ts +0 -14
- package/utils/dynamic-editor.model.d.ts +0 -11
- package/utils/dynamic-form-array.model.d.ts +0 -69
- package/utils/dynamic-form-group.model.d.ts +0 -14
- package/utils/dynamic-select.model.d.ts +0 -39
- package/utils/form-select-subject.d.ts +0 -6
- package/utils/form-subject.d.ts +0 -10
- package/utils/misc.d.ts +0 -11
- package/utils/validation-errors.d.ts +0 -11
- package/utils/validators.d.ts +0 -8
package/public_api.d.ts
CHANGED
|
@@ -1,21 +1,16 @@
|
|
|
1
|
-
export {
|
|
2
|
-
export {
|
|
3
|
-
export {
|
|
4
|
-
export {
|
|
5
|
-
export {
|
|
6
|
-
export {
|
|
7
|
-
export { SaveTabFunc, RestoreTabFunc, TabLabelFunc, DynamicFormArrayGroupModel, DynamicFormArrayModelConfig, DynamicFormArrayModel } from "./ngx-dynamic-form/utils/dynamic-form-array.model";
|
|
8
|
-
export { DynamicFormFieldSet, DynamicFormFieldSets, DynamicFormGroupModelConfig, DynamicFormGroupModel } from "./ngx-dynamic-form/utils/dynamic-form-group.model";
|
|
9
|
-
export { DynamicFormOptionConfig, DynamicFormOption, DynamicFormOptionGroup, OptionClassesFunc, DynamicSelectModelConfig, DynamicSelectModel } from "./ngx-dynamic-form/utils/dynamic-select.model";
|
|
10
|
-
export { FormSelectSubject } from "./ngx-dynamic-form/utils/form-select-subject";
|
|
11
|
-
export { FormSubject } from "./ngx-dynamic-form/utils/form-subject";
|
|
1
|
+
export { FORM_ROOT_KEY, FormBuilderOptions, FormFieldProps, FormBaseFieldConfig, FormFieldSerializer, FormHookFn, FormHookConfig, FormFieldConfig, FormFieldType, FormSerializeResult, FormSelectOption, FormSelectOptions, IDynamicForm, ValidationMessageFn, ValidatorFn, ValidatorExpression, Validators, AsyncValidatorFn, AsyncValidatorExpression, AsyncValidators, FormFieldCustom, FormFieldData, FormInputData, FormSelectData, FormUploadData, FormGroupData, FormArrayData, FormFieldCustomizer, ConfigForSchemaOptions, DynamicFormState, DynamicFormUpdateOn, AsyncSubmitMethod, IDynamicFormModuleConfig, } from "./ngx-dynamic-form/common-types";
|
|
2
|
+
export { IFormFieldCustomizer, customizeFormField } from "./ngx-dynamic-form/utils/customizer";
|
|
3
|
+
export { FormSerializable, FormInput, FormSelect, FormUpload, FormFile, FormGroup, FormModel } from "./ngx-dynamic-form/utils/decorators";
|
|
4
|
+
export { validationMessage, jsonValidation, requiredValidation, translationValidation, phoneValidation, emailValidation, minLengthValidation, maxLengthValidation, minValueValidation, maxValueValidation } from "./ngx-dynamic-form/utils/validation";
|
|
5
|
+
export { replaceSpecialChars, mergeFormFields, MIN_INPUT_NUM, MAX_INPUT_NUM, EDITOR_FORMATS } from "./ngx-dynamic-form/utils/misc";
|
|
6
|
+
export { DynamicFormBuilderService } from "./ngx-dynamic-form/services/dynamic-form-builder.service";
|
|
12
7
|
export { DynamicFormService } from "./ngx-dynamic-form/services/dynamic-form.service";
|
|
13
8
|
export { AsyncSubmitDirective } from "./ngx-dynamic-form/directives/async-submit.directive";
|
|
14
|
-
export {
|
|
15
|
-
export {
|
|
16
|
-
export {
|
|
17
|
-
export {
|
|
18
|
-
export {
|
|
19
|
-
export {
|
|
9
|
+
export { DynamicFormComponent } from "./ngx-dynamic-form/components/dynamic-form/dynamic-form.component";
|
|
10
|
+
export { DynamicFormArrayComponent } from "./ngx-dynamic-form/components/dynamic-form-array/dynamic-form-array.component";
|
|
11
|
+
export { DynamicFormChipsComponent } from "./ngx-dynamic-form/components/dynamic-form-chips/dynamic-form-chips.component";
|
|
12
|
+
export { DynamicFormFieldComponent } from "./ngx-dynamic-form/components/dynamic-form-field/dynamic-form-field.component";
|
|
13
|
+
export { DynamicFormFieldsetComponent } from "./ngx-dynamic-form/components/dynamic-form-fieldset/dynamic-form-fieldset.component";
|
|
14
|
+
export { DynamicFormGroupComponent } from "./ngx-dynamic-form/components/dynamic-form-group/dynamic-form-group.component";
|
|
15
|
+
export { DynamicFormUploadComponent } from "./ngx-dynamic-form/components/dynamic-form-upload/dynamic-form-upload.component";
|
|
20
16
|
export { NgxDynamicFormModule } from "./ngx-dynamic-form/ngx-dynamic-form.module";
|
|
21
|
-
export { DYNAMIC_FORM_CONTROL_TYPE_ARRAY, DYNAMIC_FORM_CONTROL_TYPE_CHECKBOX, DYNAMIC_FORM_CONTROL_TYPE_CHECKBOX_GROUP, DYNAMIC_FORM_CONTROL_TYPE_FILE_UPLOAD, DYNAMIC_FORM_CONTROL_TYPE_GROUP, DYNAMIC_FORM_CONTROL_TYPE_INPUT, DYNAMIC_FORM_CONTROL_TYPE_DATEPICKER, DYNAMIC_FORM_CONTROL_TYPE_RADIO_GROUP, DYNAMIC_FORM_CONTROL_TYPE_SELECT, DYNAMIC_FORM_CONTROL_TYPE_TEXTAREA, DYNAMIC_FORM_CONTROL_TYPE_EDITOR, DynamicTemplateDirective, DynamicListDirective, DynamicFormModel, DynamicFormControlMapFn, DynamicFormsCoreModule, DynamicCheckboxModelConfig, DynamicCheckboxModel, DynamicCheckboxGroupModel, DynamicFileUploadModelConfig, DynamicFileUploadModel, DynamicInputModelConfig, DynamicInputModel, DynamicDatePickerModelConfig, DynamicDatePickerModel, DynamicRadioGroupModelConfig, DynamicRadioGroupModel, DynamicTextAreaModelConfig, DynamicTextAreaModel, DynamicFormControlComponent, DynamicFormControlModelConfig, DynamicFormControlModel, } from "@ng-dynamic-forms/core";
|
package/ui-nebular/index.d.ts
CHANGED
package/common-types.d.ts
DELETED
|
@@ -1,37 +0,0 @@
|
|
|
1
|
-
import { ChangeDetectorRef, EventEmitter, Injector, Type } from "@angular/core";
|
|
2
|
-
import { AbstractControl } from "@angular/forms";
|
|
3
|
-
import { DynamicFormControl, DynamicFormControlComponent, DynamicFormControlEvent, DynamicFormControlMapFn, DynamicFormControlModel, DynamicFormControlModelConfig, DynamicFormValueControlModel, DynamicFormComponent } from "@ng-dynamic-forms/core";
|
|
4
|
-
import { IAsyncMessage, IOpenApiSchema, IOpenApiSchemaProperty } from "@stemy/ngx-utils";
|
|
5
|
-
export type DynamicFormState = "VALID" | "INVALID" | "PENDING" | "DISABLED" | "LOADING";
|
|
6
|
-
export type DynamicFormUpdateOn = "change" | "blur" | "submit";
|
|
7
|
-
export interface IDynamicFormEvent extends DynamicFormControlEvent {
|
|
8
|
-
form: IDynamicForm;
|
|
9
|
-
}
|
|
10
|
-
export interface IDynamicForm extends DynamicFormComponent {
|
|
11
|
-
status?: DynamicFormState;
|
|
12
|
-
onValueChange?: EventEmitter<IDynamicFormEvent>;
|
|
13
|
-
onStatusChange?: EventEmitter<IDynamicForm>;
|
|
14
|
-
onSubmit?: EventEmitter<IDynamicForm>;
|
|
15
|
-
}
|
|
16
|
-
export declare interface ModelType extends Function {
|
|
17
|
-
new (config: DynamicFormControlModelConfig): DynamicFormControlModel;
|
|
18
|
-
}
|
|
19
|
-
export type PromiseOrNot<T> = Promise<T> | T;
|
|
20
|
-
export type FormControlSerializer = (model: DynamicFormValueControlModel<any>, control: AbstractControl) => Promise<any>;
|
|
21
|
-
export type FormModelCustomizer = (property: IOpenApiSchemaProperty, schema: IOpenApiSchema, model: DynamicFormControlModel, config: DynamicFormControlModelConfig, injector: Injector) => PromiseOrNot<DynamicFormControlModel | DynamicFormControlModel[]>;
|
|
22
|
-
export interface ModelForSchemaOptions {
|
|
23
|
-
labelPrefix?: string;
|
|
24
|
-
customizer?: FormModelCustomizer;
|
|
25
|
-
}
|
|
26
|
-
export interface ModelForSchemaWrapOptions extends Omit<ModelForSchemaOptions, "customizer"> {
|
|
27
|
-
schema: IOpenApiSchema;
|
|
28
|
-
customizer?: (property: IOpenApiSchemaProperty, options: ModelForSchemaWrapOptions, modelType: ModelType, config: DynamicFormControlModelConfig, path: string) => Promise<DynamicFormControlModel[]>;
|
|
29
|
-
}
|
|
30
|
-
export interface DynamicFormInitControl extends DynamicFormControl {
|
|
31
|
-
initialize(cdr?: ChangeDetectorRef): void;
|
|
32
|
-
}
|
|
33
|
-
export declare type AsyncSubmitMethod = (form: IDynamicForm, context?: any) => Promise<IAsyncMessage>;
|
|
34
|
-
export type GetFormControlComponentType = (model: DynamicFormControlModel, injector: Injector) => Type<DynamicFormControlComponent>;
|
|
35
|
-
export interface IDynamicFormModuleConfig {
|
|
36
|
-
controlProvider?: (injector: Injector) => DynamicFormControlMapFn;
|
|
37
|
-
}
|
|
@@ -1,38 +0,0 @@
|
|
|
1
|
-
import { ChangeDetectorRef, EventEmitter, Injector, OnDestroy, QueryList } from "@angular/core";
|
|
2
|
-
import { FormGroup } from "@angular/forms";
|
|
3
|
-
import { Subscription } from "rxjs";
|
|
4
|
-
import { DynamicFormArrayComponent, DynamicFormControlCustomEvent, DynamicFormControlLayout, DynamicFormControlLayoutContext, DynamicFormControlLayoutPlace, DynamicFormControlModel, DynamicFormLayout, DynamicFormLayoutService, DynamicFormValidationService, DynamicTemplateDirective } from "@ng-dynamic-forms/core";
|
|
5
|
-
import { DynamicFormArrayGroupModel, DynamicFormArrayModel } from "../../utils/dynamic-form-array.model";
|
|
6
|
-
import { DynamicFormInitControl } from "../../common-types";
|
|
7
|
-
import { DynamicBaseFormComponent } from "./dynamic-base-form.component";
|
|
8
|
-
import { DynamicBaseFormControlContainerComponent } from "./dynamic-base-form-control-container.component";
|
|
9
|
-
import * as i0 from "@angular/core";
|
|
10
|
-
export declare class DynamicBaseFormArrayComponent extends DynamicFormArrayComponent implements DynamicFormInitControl, OnDestroy {
|
|
11
|
-
readonly form: DynamicBaseFormComponent;
|
|
12
|
-
readonly injector: Injector;
|
|
13
|
-
readonly cdr: ChangeDetectorRef;
|
|
14
|
-
formLayout: DynamicFormLayout;
|
|
15
|
-
group: FormGroup;
|
|
16
|
-
layout: DynamicFormControlLayout;
|
|
17
|
-
model: DynamicFormArrayModel;
|
|
18
|
-
templates: QueryList<DynamicTemplateDirective> | undefined;
|
|
19
|
-
blur: EventEmitter<any>;
|
|
20
|
-
change: EventEmitter<any>;
|
|
21
|
-
customEvent: EventEmitter<DynamicFormControlCustomEvent>;
|
|
22
|
-
focus: EventEmitter<any>;
|
|
23
|
-
components: QueryList<DynamicBaseFormControlContainerComponent>;
|
|
24
|
-
get useTabs(): boolean;
|
|
25
|
-
protected subscription: Subscription;
|
|
26
|
-
constructor(layoutService: DynamicFormLayoutService, validationService: DynamicFormValidationService, form: DynamicBaseFormComponent, injector: Injector, cdr: ChangeDetectorRef);
|
|
27
|
-
initialize(cdr: ChangeDetectorRef): void;
|
|
28
|
-
ngOnDestroy(): void;
|
|
29
|
-
saveTab(index: number): void;
|
|
30
|
-
restoreTab(): number;
|
|
31
|
-
getTabLabel(index: number, model: DynamicFormArrayGroupModel): string;
|
|
32
|
-
getClass(context: DynamicFormControlLayoutContext, place: DynamicFormControlLayoutPlace, model?: DynamicFormControlModel): string;
|
|
33
|
-
protected getModelClass(model?: DynamicFormControlModel): string;
|
|
34
|
-
protected getAdditionalClass(model?: DynamicFormControlModel): string;
|
|
35
|
-
protected updateGroups(filteredGroups: ReadonlyArray<DynamicFormArrayGroupModel>): void;
|
|
36
|
-
static ɵfac: i0.ɵɵFactoryDeclaration<DynamicBaseFormArrayComponent, never>;
|
|
37
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<DynamicBaseFormArrayComponent, "dynamic-base-form-array", never, { "formLayout": { "alias": "formLayout"; "required": false; }; "group": { "alias": "group"; "required": false; }; "layout": { "alias": "layout"; "required": false; }; "model": { "alias": "model"; "required": false; }; "templates": { "alias": "templates"; "required": false; }; }, { "blur": "blur"; "change": "change"; "customEvent": "customEvent"; "focus": "focus"; }, never, never, false, never>;
|
|
38
|
-
}
|
|
@@ -1,39 +0,0 @@
|
|
|
1
|
-
import { ChangeDetectorRef, ComponentFactoryResolver, EventEmitter, Injector, QueryList, Type, ViewContainerRef } from "@angular/core";
|
|
2
|
-
import { FormGroup } from "@angular/forms";
|
|
3
|
-
import { Subscription } from "rxjs";
|
|
4
|
-
import { DynamicFormComponentService, DynamicFormControl, DynamicFormControlContainerComponent, DynamicFormControlEvent, DynamicFormControlModel, DynamicFormLayout, DynamicFormLayoutService, DynamicFormRelationService, DynamicFormValidationService, DynamicTemplateDirective } from "@ng-dynamic-forms/core";
|
|
5
|
-
import { DynamicFormArrayGroupModel } from "../../utils/dynamic-form-array.model";
|
|
6
|
-
import { DynamicFormService } from "../../services/dynamic-form.service";
|
|
7
|
-
import { DynamicBaseFormComponent } from "./dynamic-base-form.component";
|
|
8
|
-
import * as i0 from "@angular/core";
|
|
9
|
-
export declare class DynamicBaseFormControlContainerComponent extends DynamicFormControlContainerComponent {
|
|
10
|
-
readonly form: DynamicBaseFormComponent;
|
|
11
|
-
readonly cdr: ChangeDetectorRef;
|
|
12
|
-
readonly injector: Injector;
|
|
13
|
-
contentTemplateList: QueryList<DynamicTemplateDirective>;
|
|
14
|
-
klass: any;
|
|
15
|
-
context: DynamicFormArrayGroupModel | null;
|
|
16
|
-
group: FormGroup;
|
|
17
|
-
hostClass: string[];
|
|
18
|
-
inputTemplateList: QueryList<DynamicTemplateDirective>;
|
|
19
|
-
layout: DynamicFormLayout;
|
|
20
|
-
model: DynamicFormControlModel;
|
|
21
|
-
blur: EventEmitter<DynamicFormControlEvent>;
|
|
22
|
-
change: EventEmitter<DynamicFormControlEvent>;
|
|
23
|
-
focus: EventEmitter<DynamicFormControlEvent>;
|
|
24
|
-
componentViewContainerRef: ViewContainerRef;
|
|
25
|
-
get componentType(): Type<DynamicFormControl> | null;
|
|
26
|
-
get startTemplate(): DynamicTemplateDirective;
|
|
27
|
-
get endTemplate(): DynamicTemplateDirective;
|
|
28
|
-
get formService(): DynamicFormService;
|
|
29
|
-
protected onDetectChanges: Subscription;
|
|
30
|
-
constructor(form: DynamicBaseFormComponent, cdr: ChangeDetectorRef, injector: Injector, cfr: ComponentFactoryResolver, layoutService: DynamicFormLayoutService, validationService: DynamicFormValidationService, componentService: DynamicFormComponentService, relationService: DynamicFormRelationService);
|
|
31
|
-
ngOnInit(): void;
|
|
32
|
-
ngOnDestroy(): void;
|
|
33
|
-
getLabel(): string;
|
|
34
|
-
getLabelIcon(): string;
|
|
35
|
-
clickLabel(): void;
|
|
36
|
-
protected createFormControlComponent(): void;
|
|
37
|
-
static ɵfac: i0.ɵɵFactoryDeclaration<DynamicBaseFormControlContainerComponent, never>;
|
|
38
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<DynamicBaseFormControlContainerComponent, "dynamic-base-form-control", never, { "context": { "alias": "context"; "required": false; }; "group": { "alias": "group"; "required": false; }; "hostClass": { "alias": "hostClass"; "required": false; }; "inputTemplateList": { "alias": "templates"; "required": false; }; "layout": { "alias": "layout"; "required": false; }; "model": { "alias": "model"; "required": false; }; }, { "blur": "blur"; "change": "change"; "focus": "focus"; }, ["contentTemplateList"], never, false, never>;
|
|
39
|
-
}
|
|
@@ -1,26 +0,0 @@
|
|
|
1
|
-
import { AfterViewInit, ChangeDetectorRef, EventEmitter, Injector, OnDestroy } from "@angular/core";
|
|
2
|
-
import { FormGroup } from "@angular/forms";
|
|
3
|
-
import { Subscription } from "rxjs";
|
|
4
|
-
import { DynamicFormControlComponent, DynamicFormControlLayout, DynamicFormControlModel, DynamicFormLayout, DynamicFormLayoutService, DynamicFormValidationService } from "@ng-dynamic-forms/core";
|
|
5
|
-
import { DynamicBaseFormComponent } from "./dynamic-base-form.component";
|
|
6
|
-
import * as i0 from "@angular/core";
|
|
7
|
-
export declare class DynamicBaseFormControlComponent<T extends DynamicFormControlModel> extends DynamicFormControlComponent implements AfterViewInit, OnDestroy {
|
|
8
|
-
readonly form: DynamicBaseFormComponent;
|
|
9
|
-
readonly injector: Injector;
|
|
10
|
-
readonly cdr: ChangeDetectorRef;
|
|
11
|
-
formLayout: DynamicFormLayout;
|
|
12
|
-
group: FormGroup;
|
|
13
|
-
layout: DynamicFormControlLayout;
|
|
14
|
-
model: T;
|
|
15
|
-
blur: EventEmitter<any>;
|
|
16
|
-
change: EventEmitter<any>;
|
|
17
|
-
focus: EventEmitter<any>;
|
|
18
|
-
protected subscription: Subscription;
|
|
19
|
-
constructor(layoutService: DynamicFormLayoutService, validationService: DynamicFormValidationService, form: DynamicBaseFormComponent, injector: Injector, cdr: ChangeDetectorRef);
|
|
20
|
-
ngAfterViewInit(): void;
|
|
21
|
-
ngOnDestroy(): void;
|
|
22
|
-
submit(): void;
|
|
23
|
-
protected onValueChanged(value: any): void;
|
|
24
|
-
static ɵfac: i0.ɵɵFactoryDeclaration<DynamicBaseFormControlComponent<any>, [null, null, { optional: true; }, null, null]>;
|
|
25
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<DynamicBaseFormControlComponent<any>, "dynamic-base-form-control", never, { "formLayout": { "alias": "formLayout"; "required": false; }; "group": { "alias": "group"; "required": false; }; "layout": { "alias": "layout"; "required": false; }; "model": { "alias": "model"; "required": false; }; }, { "blur": "blur"; "change": "change"; "focus": "focus"; }, never, never, false, never>;
|
|
26
|
-
}
|
|
@@ -1,25 +0,0 @@
|
|
|
1
|
-
import { EventEmitter, QueryList } from "@angular/core";
|
|
2
|
-
import { FormGroup } from "@angular/forms";
|
|
3
|
-
import { DynamicFormControlContainerComponent, DynamicFormControlCustomEvent, DynamicFormControlLayout, DynamicFormControlLayoutContext, DynamicFormControlLayoutPlace, DynamicFormControlModel, DynamicFormGroupComponent, DynamicFormLayout, DynamicFormLayoutService, DynamicFormValidationService, DynamicTemplateDirective } from "@ng-dynamic-forms/core";
|
|
4
|
-
import { DynamicFormGroupModel } from "../../utils/dynamic-form-group.model";
|
|
5
|
-
import * as i0 from "@angular/core";
|
|
6
|
-
export declare class DynamicBaseFormGroupComponent extends DynamicFormGroupComponent {
|
|
7
|
-
protected layoutService: DynamicFormLayoutService;
|
|
8
|
-
protected validationService: DynamicFormValidationService;
|
|
9
|
-
formLayout: DynamicFormLayout;
|
|
10
|
-
group: FormGroup;
|
|
11
|
-
layout: DynamicFormControlLayout;
|
|
12
|
-
model: DynamicFormGroupModel;
|
|
13
|
-
templates: QueryList<DynamicTemplateDirective> | DynamicTemplateDirective[] | undefined;
|
|
14
|
-
blur: EventEmitter<any>;
|
|
15
|
-
change: EventEmitter<any>;
|
|
16
|
-
customEvent: EventEmitter<DynamicFormControlCustomEvent>;
|
|
17
|
-
focus: EventEmitter<any>;
|
|
18
|
-
components: QueryList<DynamicFormControlContainerComponent>;
|
|
19
|
-
constructor(layoutService: DynamicFormLayoutService, validationService: DynamicFormValidationService);
|
|
20
|
-
getClass(context: DynamicFormControlLayoutContext, place: DynamicFormControlLayoutPlace, model?: DynamicFormControlModel): string;
|
|
21
|
-
protected getModelClass(model?: DynamicFormControlModel): string;
|
|
22
|
-
protected getAdditionalClass(model?: DynamicFormControlModel): string;
|
|
23
|
-
static ɵfac: i0.ɵɵFactoryDeclaration<DynamicBaseFormGroupComponent, never>;
|
|
24
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<DynamicBaseFormGroupComponent, "dynamic-base-form-group", never, { "formLayout": { "alias": "formLayout"; "required": false; }; "group": { "alias": "group"; "required": false; }; "layout": { "alias": "layout"; "required": false; }; "model": { "alias": "model"; "required": false; }; "templates": { "alias": "templates"; "required": false; }; }, { "blur": "blur"; "change": "change"; "customEvent": "customEvent"; "focus": "focus"; }, never, never, false, never>;
|
|
25
|
-
}
|
|
@@ -1,46 +0,0 @@
|
|
|
1
|
-
import { AfterViewInit, ChangeDetectorRef, EventEmitter, OnChanges, QueryList, SimpleChanges } from "@angular/core";
|
|
2
|
-
import { FormArray, FormGroup } from "@angular/forms";
|
|
3
|
-
import { Subscription } from "rxjs";
|
|
4
|
-
import { DynamicFormComponent, DynamicFormComponentService, DynamicFormControlEvent, DynamicFormControlModel, DynamicFormLayout, DynamicFormModel, DynamicTemplateDirective } from "@ng-dynamic-forms/core";
|
|
5
|
-
import { EventsService } from "@stemy/ngx-utils";
|
|
6
|
-
import { DynamicFormState, GetFormControlComponentType, IDynamicForm, IDynamicFormEvent } from "../../common-types";
|
|
7
|
-
import { DynamicFormGroupModel } from "../../utils/dynamic-form-group.model";
|
|
8
|
-
import { DynamicFormArrayModel } from "../../utils/dynamic-form-array.model";
|
|
9
|
-
import { DynamicFormService } from "../../services/dynamic-form.service";
|
|
10
|
-
import * as i0 from "@angular/core";
|
|
11
|
-
export declare class DynamicBaseFormComponent extends DynamicFormComponent implements OnChanges, AfterViewInit, IDynamicForm {
|
|
12
|
-
readonly formService: DynamicFormService;
|
|
13
|
-
readonly events: EventsService;
|
|
14
|
-
group: FormGroup;
|
|
15
|
-
model: DynamicFormModel;
|
|
16
|
-
layout: DynamicFormLayout;
|
|
17
|
-
blur: EventEmitter<DynamicFormControlEvent>;
|
|
18
|
-
change: EventEmitter<DynamicFormControlEvent>;
|
|
19
|
-
focus: EventEmitter<DynamicFormControlEvent>;
|
|
20
|
-
groupModel: DynamicFormGroupModel;
|
|
21
|
-
labelPrefix: string;
|
|
22
|
-
getComponentType: GetFormControlComponentType;
|
|
23
|
-
contentTemplates: QueryList<DynamicTemplateDirective>;
|
|
24
|
-
viewTemplates: QueryList<DynamicTemplateDirective>;
|
|
25
|
-
get status(): DynamicFormState;
|
|
26
|
-
readonly onValueChange: EventEmitter<IDynamicFormEvent>;
|
|
27
|
-
readonly onStatusChange: EventEmitter<IDynamicForm>;
|
|
28
|
-
readonly onSubmit: EventEmitter<IDynamicForm>;
|
|
29
|
-
readonly onDetectChanges: EventEmitter<IDynamicForm>;
|
|
30
|
-
protected subscription: Subscription;
|
|
31
|
-
protected groupSubscription: Subscription;
|
|
32
|
-
constructor(formService: DynamicFormService, events: EventsService, changeDetectorRef: ChangeDetectorRef, componentService: DynamicFormComponentService);
|
|
33
|
-
submit(): void;
|
|
34
|
-
ngOnChanges(changes: SimpleChanges): void;
|
|
35
|
-
ngAfterViewInit(): void;
|
|
36
|
-
ngOnDestroy(): void;
|
|
37
|
-
detectChanges(): void;
|
|
38
|
-
insertFormArrayGroup(index: number, formArray: FormArray, formArrayModel: DynamicFormArrayModel): void;
|
|
39
|
-
cloneFormArrayGroup(index: number, formArray: FormArray, formArrayModel: DynamicFormArrayModel): void;
|
|
40
|
-
removeFormArrayGroup(index: number, formArray: FormArray, formArrayModel: DynamicFormArrayModel): void;
|
|
41
|
-
moveFormArrayGroup(index: number, step: number, formArray: FormArray, formArrayModel: DynamicFormArrayModel): void;
|
|
42
|
-
clearFormArray(formArray: FormArray, formArrayModel: DynamicFormArrayModel): void;
|
|
43
|
-
getClass(model?: DynamicFormControlModel): string;
|
|
44
|
-
static ɵfac: i0.ɵɵFactoryDeclaration<DynamicBaseFormComponent, never>;
|
|
45
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<DynamicBaseFormComponent, "dynamic-base-form", never, { "group": { "alias": "group"; "required": false; }; "model": { "alias": "model"; "required": false; }; "layout": { "alias": "layout"; "required": false; }; "groupModel": { "alias": "groupModel"; "required": false; }; "labelPrefix": { "alias": "labelPrefix"; "required": false; }; "getComponentType": { "alias": "getComponentType"; "required": false; }; }, { "blur": "blur"; "change": "change"; "focus": "focus"; "onValueChange": "onValueChange"; "onStatusChange": "onStatusChange"; "onSubmit": "onSubmit"; "onDetectChanges": "onDetectChanges"; }, ["contentTemplates"], never, false, never>;
|
|
46
|
-
}
|
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
import { OnDestroy, OnInit } from "@angular/core";
|
|
2
|
-
import { BehaviorSubject } from "rxjs";
|
|
3
|
-
import { DynamicBaseFormControlComponent } from "./dynamic-base-form-control.component";
|
|
4
|
-
import { DynamicFormOption, DynamicFormOptionGroup, DynamicSelectModel } from "../../utils/dynamic-select.model";
|
|
5
|
-
import * as i0 from "@angular/core";
|
|
6
|
-
export declare class DynamicBaseSelectComponent extends DynamicBaseFormControlComponent<DynamicSelectModel<any>> implements OnInit, OnDestroy {
|
|
7
|
-
groups$: BehaviorSubject<DynamicFormOptionGroup<any>[]>;
|
|
8
|
-
hasOptions: boolean;
|
|
9
|
-
ngOnInit(): void;
|
|
10
|
-
ngOnDestroy(): void;
|
|
11
|
-
isSelected(option: DynamicFormOption<any>): boolean;
|
|
12
|
-
selectToggle(option: DynamicFormOption<any>, state: boolean): void;
|
|
13
|
-
static ɵfac: i0.ɵɵFactoryDeclaration<DynamicBaseSelectComponent, never>;
|
|
14
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<DynamicBaseSelectComponent, "dynamic-base-select", never, {}, {}, never, never, false, never>;
|
|
15
|
-
}
|
|
@@ -1,31 +0,0 @@
|
|
|
1
|
-
import { ChangeDetectorRef, ElementRef, EventEmitter, NgZone, OnChanges, OnDestroy, Renderer2, SimpleChanges } from "@angular/core";
|
|
2
|
-
import { Subscription } from "rxjs";
|
|
3
|
-
import { IAsyncMessage, IToasterService } from "@stemy/ngx-utils";
|
|
4
|
-
import { AsyncSubmitMethod, IDynamicForm } from "../common-types";
|
|
5
|
-
import * as i0 from "@angular/core";
|
|
6
|
-
export declare class AsyncSubmitDirective implements OnChanges, OnDestroy {
|
|
7
|
-
private toaster;
|
|
8
|
-
readonly cdr: ChangeDetectorRef;
|
|
9
|
-
readonly zone: NgZone;
|
|
10
|
-
readonly elem: ElementRef<HTMLElement>;
|
|
11
|
-
readonly renderer: Renderer2;
|
|
12
|
-
method: AsyncSubmitMethod;
|
|
13
|
-
form: IDynamicForm;
|
|
14
|
-
context: any;
|
|
15
|
-
onSuccess: EventEmitter<IAsyncMessage>;
|
|
16
|
-
onError: EventEmitter<IAsyncMessage>;
|
|
17
|
-
protected loading: boolean;
|
|
18
|
-
protected disabled: boolean;
|
|
19
|
-
protected callback: Function;
|
|
20
|
-
protected subscription: Subscription;
|
|
21
|
-
get isDisabled(): boolean;
|
|
22
|
-
set isDisabled(value: boolean);
|
|
23
|
-
get isLoading(): boolean;
|
|
24
|
-
constructor(toaster: IToasterService, cdr: ChangeDetectorRef, zone: NgZone, elem: ElementRef<HTMLElement>, renderer: Renderer2);
|
|
25
|
-
ngOnChanges(changes: SimpleChanges): void;
|
|
26
|
-
ngOnDestroy(): void;
|
|
27
|
-
click(): void;
|
|
28
|
-
callMethod(): void;
|
|
29
|
-
static ɵfac: i0.ɵɵFactoryDeclaration<AsyncSubmitDirective, never>;
|
|
30
|
-
static ɵdir: i0.ɵɵDirectiveDeclaration<AsyncSubmitDirective, "[async-submit]", ["async-submit"], { "method": { "alias": "async-submit"; "required": false; }; "form": { "alias": "form"; "required": false; }; "context": { "alias": "context"; "required": false; }; }, { "onSuccess": "onSuccess"; "onError": "onError"; }, never, never, false, never>;
|
|
31
|
-
}
|
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tbW9uLXR5cGVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL25neC1keW5hbWljLWZvcm0vY29tbW9uLXR5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NoYW5nZURldGVjdG9yUmVmLCBFdmVudEVtaXR0ZXIsIEluamVjdG9yLCBUeXBlfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5pbXBvcnQge0Fic3RyYWN0Q29udHJvbCwgRm9ybUdyb3VwfSBmcm9tIFwiQGFuZ3VsYXIvZm9ybXNcIjtcclxuaW1wb3J0IHtcclxuICAgIER5bmFtaWNGb3JtQ29udHJvbCxcclxuICAgIER5bmFtaWNGb3JtQ29udHJvbENvbXBvbmVudCxcclxuICAgIER5bmFtaWNGb3JtQ29udHJvbEV2ZW50LFxyXG4gICAgRHluYW1pY0Zvcm1Db250cm9sTWFwRm4sXHJcbiAgICBEeW5hbWljRm9ybUNvbnRyb2xNb2RlbCxcclxuICAgIER5bmFtaWNGb3JtQ29udHJvbE1vZGVsQ29uZmlnLFxyXG4gICAgRHluYW1pY0Zvcm1WYWx1ZUNvbnRyb2xNb2RlbFxyXG59IGZyb20gXCJAbmctZHluYW1pYy1mb3Jtcy9jb3JlXCI7XHJcbmltcG9ydCB7SUFzeW5jTWVzc2FnZSwgSU9wZW5BcGlTY2hlbWEsIElPcGVuQXBpU2NoZW1hUHJvcGVydHl9IGZyb20gXCJAc3RlbXkvbmd4LXV0aWxzXCI7XHJcblxyXG4vLyAtLS0gQmFzaWMgZm9ybSBjb250cm9sIGludGVyZmFjZXMgLS0tXHJcblxyXG5leHBvcnQgdHlwZSBEeW5hbWljRm9ybVN0YXRlID0gXCJWQUxJRFwiIHwgXCJJTlZBTElEXCIgfCBcIlBFTkRJTkdcIiB8IFwiRElTQUJMRURcIiB8IFwiTE9BRElOR1wiO1xyXG5leHBvcnQgdHlwZSBEeW5hbWljRm9ybVVwZGF0ZU9uID0gXCJjaGFuZ2VcIiB8IFwiYmx1clwiIHwgXCJzdWJtaXRcIjtcclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgSUR5bmFtaWNGb3JtRXZlbnQgZXh0ZW5kcyBEeW5hbWljRm9ybUNvbnRyb2xFdmVudCB7XHJcbiAgICBmb3JtOiBJRHluYW1pY0Zvcm07XHJcbn1cclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgSUR5bmFtaWNGb3JtIHtcclxuXHJcbiAgICByZWFkb25seSBncm91cDogRm9ybUdyb3VwO1xyXG5cclxuICAgIHN0YXR1czogRHluYW1pY0Zvcm1TdGF0ZTtcclxuXHJcbiAgICBvblZhbHVlQ2hhbmdlOiBFdmVudEVtaXR0ZXI8SUR5bmFtaWNGb3JtRXZlbnQ+O1xyXG4gICAgb25TdGF0dXNDaGFuZ2U6IEV2ZW50RW1pdHRlcjxJRHluYW1pY0Zvcm0+O1xyXG4gICAgb25TdWJtaXQ6IEV2ZW50RW1pdHRlcjxJRHluYW1pY0Zvcm0+O1xyXG5cclxuICAgIHZhbGlkYXRlKCk6IFByb21pc2U8YW55PjtcclxuICAgIHNlcmlhbGl6ZSh2YWxpZGF0ZT86IGJvb2xlYW4pOiBQcm9taXNlPGFueT47XHJcbn1cclxuXHJcbmV4cG9ydCBkZWNsYXJlIGludGVyZmFjZSBNb2RlbFR5cGUgZXh0ZW5kcyBGdW5jdGlvbiB7XHJcbiAgICBuZXcgKGNvbmZpZzogRHluYW1pY0Zvcm1Db250cm9sTW9kZWxDb25maWcpOiBEeW5hbWljRm9ybUNvbnRyb2xNb2RlbDtcclxufVxyXG5cclxuZXhwb3J0IHR5cGUgUHJvbWlzZU9yTm90PFQ+ID0gUHJvbWlzZTxUPiB8IFQ7XHJcbmV4cG9ydCB0eXBlIEZvcm1Db250cm9sU2VyaWFsaXplciA9IChtb2RlbDogRHluYW1pY0Zvcm1WYWx1ZUNvbnRyb2xNb2RlbDxhbnk+LCBjb250cm9sOiBBYnN0cmFjdENvbnRyb2wpID0+IFByb21pc2U8YW55PjtcclxuZXhwb3J0IHR5cGUgRm9ybU1vZGVsQ3VzdG9taXplciA9IChcclxuICAgIHByb3BlcnR5OiBJT3BlbkFwaVNjaGVtYVByb3BlcnR5LCBzY2hlbWE6IElPcGVuQXBpU2NoZW1hLFxyXG4gICAgbW9kZWw6IER5bmFtaWNGb3JtQ29udHJvbE1vZGVsLCBjb25maWc6IER5bmFtaWNGb3JtQ29udHJvbE1vZGVsQ29uZmlnLCBpbmplY3RvcjogSW5qZWN0b3JcclxuKSA9PiBQcm9taXNlT3JOb3Q8RHluYW1pY0Zvcm1Db250cm9sTW9kZWwgfCBEeW5hbWljRm9ybUNvbnRyb2xNb2RlbFtdPjtcclxuZXhwb3J0IHR5cGUgRm9ybU1vZGVsQ3VzdG9taXplcldyYXAgPSAoXHJcbiAgICBwcm9wZXJ0eTogSU9wZW5BcGlTY2hlbWFQcm9wZXJ0eSwgc2NoZW1hOiBJT3BlbkFwaVNjaGVtYSxcclxuICAgIG1vZGVsVHlwZTogTW9kZWxUeXBlLCBjb25maWc6IER5bmFtaWNGb3JtQ29udHJvbE1vZGVsQ29uZmlnXHJcbikgPT4gUHJvbWlzZTxEeW5hbWljRm9ybUNvbnRyb2xNb2RlbFtdPjtcclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgSUZvcm1Db250cm9sIHtcclxuICAgIGlkOiBzdHJpbmc7XHJcbiAgICB0eXBlOiBzdHJpbmc7XHJcbiAgICBjb25maWc/OiBEeW5hbWljRm9ybUNvbnRyb2xNb2RlbENvbmZpZztcclxufVxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBEeW5hbWljRm9ybUluaXRDb250cm9sIGV4dGVuZHMgRHluYW1pY0Zvcm1Db250cm9sIHtcclxuICAgIGluaXRpYWxpemUoY2RyPzogQ2hhbmdlRGV0ZWN0b3JSZWYpOiB2b2lkO1xyXG59XHJcblxyXG5leHBvcnQgZGVjbGFyZSB0eXBlIEFzeW5jU3VibWl0TWV0aG9kID0gKGZvcm06IElEeW5hbWljRm9ybSwgY29udGV4dD86IGFueSkgPT4gUHJvbWlzZTxJQXN5bmNNZXNzYWdlPjtcclxuXHJcbmV4cG9ydCB0eXBlIEdldEZvcm1Db250cm9sQ29tcG9uZW50VHlwZSA9IChtb2RlbDogRHluYW1pY0Zvcm1Db250cm9sTW9kZWwsIGluamVjdG9yOiBJbmplY3RvcikgPT4gVHlwZTxEeW5hbWljRm9ybUNvbnRyb2xDb21wb25lbnQ+O1xyXG5cclxuZXhwb3J0IGludGVyZmFjZSBJRHluYW1pY0Zvcm1Nb2R1bGVDb25maWcge1xyXG4gICAgY29udHJvbFByb3ZpZGVyPzogKGluamVjdG9yOiBJbmplY3RvcikgPT4gRHluYW1pY0Zvcm1Db250cm9sTWFwRm47XHJcbn1cclxuIl19
|
|
@@ -1,104 +0,0 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, Component, EventEmitter, forwardRef, Input, Output, ViewChildren } from "@angular/core";
|
|
2
|
-
import { DynamicFormArrayComponent, DynamicFormGroupModel, DynamicFormValueControlModel } from "@ng-dynamic-forms/core";
|
|
3
|
-
import { DynamicFormArrayModel } from "../../utils/dynamic-form-array.model";
|
|
4
|
-
import { collectPathAble } from "../../utils/misc";
|
|
5
|
-
import { DynamicBaseFormControlContainerComponent } from "./dynamic-base-form-control-container.component";
|
|
6
|
-
import * as i0 from "@angular/core";
|
|
7
|
-
import * as i1 from "@ng-dynamic-forms/core";
|
|
8
|
-
import * as i2 from "./dynamic-base-form.component";
|
|
9
|
-
export class DynamicBaseFormArrayComponent extends DynamicFormArrayComponent {
|
|
10
|
-
constructor(layoutService, validationService, form, injector, cdr) {
|
|
11
|
-
super(layoutService, validationService);
|
|
12
|
-
this.form = form;
|
|
13
|
-
this.injector = injector;
|
|
14
|
-
this.cdr = cdr;
|
|
15
|
-
this.blur = new EventEmitter();
|
|
16
|
-
this.change = new EventEmitter();
|
|
17
|
-
this.customEvent = new EventEmitter();
|
|
18
|
-
this.focus = new EventEmitter();
|
|
19
|
-
}
|
|
20
|
-
get useTabs() {
|
|
21
|
-
return this.model?.useTabs;
|
|
22
|
-
}
|
|
23
|
-
initialize(cdr) {
|
|
24
|
-
this.subscription = this.model.filteredGroups.subscribe(filteredGroups => {
|
|
25
|
-
this.updateGroups(filteredGroups);
|
|
26
|
-
});
|
|
27
|
-
this.model.initialize(this.array);
|
|
28
|
-
}
|
|
29
|
-
ngOnDestroy() {
|
|
30
|
-
if (this.subscription)
|
|
31
|
-
this.subscription.unsubscribe();
|
|
32
|
-
}
|
|
33
|
-
saveTab(index) {
|
|
34
|
-
this.model.saveTab(index, this.model.getFiltered(index), this.model, this.injector);
|
|
35
|
-
}
|
|
36
|
-
restoreTab() {
|
|
37
|
-
return this.model.restoreTab(this.model, this.injector);
|
|
38
|
-
}
|
|
39
|
-
getTabLabel(index, model) {
|
|
40
|
-
return this.model.getTabLabel(index, model, this.model, this.array, this.injector);
|
|
41
|
-
}
|
|
42
|
-
getClass(context, place, model) {
|
|
43
|
-
return [
|
|
44
|
-
context == "element" ? this.getModelClass(model) : null,
|
|
45
|
-
context == "element" ? this.getAdditionalClass(model) : null,
|
|
46
|
-
super.getClass(context, place, model),
|
|
47
|
-
model instanceof DynamicFormValueControlModel ? model.additional?.classes : null
|
|
48
|
-
].filter(cls => !!cls).join(" ");
|
|
49
|
-
}
|
|
50
|
-
getModelClass(model) {
|
|
51
|
-
const parts = collectPathAble(model, p => p.id);
|
|
52
|
-
if (parts.length == 0)
|
|
53
|
-
return "";
|
|
54
|
-
if (model instanceof DynamicFormGroupModel) {
|
|
55
|
-
return `form-group-${parts.join("-")}`;
|
|
56
|
-
}
|
|
57
|
-
return `form-control-${parts.join("-")}`;
|
|
58
|
-
}
|
|
59
|
-
getAdditionalClass(model) {
|
|
60
|
-
if (model instanceof DynamicFormArrayModel) {
|
|
61
|
-
return model.additional?.classes;
|
|
62
|
-
}
|
|
63
|
-
if (model instanceof DynamicFormValueControlModel) {
|
|
64
|
-
return model.additional?.classes;
|
|
65
|
-
}
|
|
66
|
-
return null;
|
|
67
|
-
}
|
|
68
|
-
updateGroups(filteredGroups) {
|
|
69
|
-
this.cdr.detectChanges();
|
|
70
|
-
this.components.forEach(t => t.cdr.detectChanges());
|
|
71
|
-
}
|
|
72
|
-
}
|
|
73
|
-
DynamicBaseFormArrayComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: DynamicBaseFormArrayComponent, deps: [{ token: i1.DynamicFormLayoutService }, { token: i1.DynamicFormValidationService }, { token: i2.DynamicBaseFormComponent }, { token: i0.Injector }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
74
|
-
DynamicBaseFormArrayComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.8", type: DynamicBaseFormArrayComponent, selector: "dynamic-base-form-array", inputs: { formLayout: "formLayout", group: "group", layout: "layout", model: "model", templates: "templates" }, outputs: { blur: "blur", change: "change", customEvent: "customEvent", focus: "focus" }, viewQueries: [{ propertyName: "components", predicate: i0.forwardRef(function () { return DynamicBaseFormControlContainerComponent; }), descendants: true }], usesInheritance: true, ngImport: i0, template: "", isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
75
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: DynamicBaseFormArrayComponent, decorators: [{
|
|
76
|
-
type: Component,
|
|
77
|
-
args: [{
|
|
78
|
-
selector: "dynamic-base-form-array",
|
|
79
|
-
template: "",
|
|
80
|
-
changeDetection: ChangeDetectionStrategy.OnPush
|
|
81
|
-
}]
|
|
82
|
-
}], ctorParameters: function () { return [{ type: i1.DynamicFormLayoutService }, { type: i1.DynamicFormValidationService }, { type: i2.DynamicBaseFormComponent }, { type: i0.Injector }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { formLayout: [{
|
|
83
|
-
type: Input
|
|
84
|
-
}], group: [{
|
|
85
|
-
type: Input
|
|
86
|
-
}], layout: [{
|
|
87
|
-
type: Input
|
|
88
|
-
}], model: [{
|
|
89
|
-
type: Input
|
|
90
|
-
}], templates: [{
|
|
91
|
-
type: Input
|
|
92
|
-
}], blur: [{
|
|
93
|
-
type: Output
|
|
94
|
-
}], change: [{
|
|
95
|
-
type: Output
|
|
96
|
-
}], customEvent: [{
|
|
97
|
-
type: Output
|
|
98
|
-
}], focus: [{
|
|
99
|
-
type: Output
|
|
100
|
-
}], components: [{
|
|
101
|
-
type: ViewChildren,
|
|
102
|
-
args: [forwardRef(() => DynamicBaseFormControlContainerComponent)]
|
|
103
|
-
}] } });
|
|
104
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-base-form-array.component.js","sourceRoot":"","sources":["../../../../../src/ngx-dynamic-form/components/base/dynamic-base-form-array.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    ChangeDetectionStrategy,\r\n    ChangeDetectorRef,\r\n    Component,\r\n    EventEmitter,\r\n    forwardRef,\r\n    Injector,\r\n    Input,\r\n    OnDestroy,\r\n    Output,\r\n    QueryList,\r\n    ViewChildren\r\n} from \"@angular/core\";\r\nimport {FormGroup} from \"@angular/forms\";\r\nimport {Subscription} from \"rxjs\";\r\nimport {\r\n    DynamicFormArrayComponent,\r\n    DynamicFormControlCustomEvent,\r\n    DynamicFormControlLayout,\r\n    DynamicFormControlLayoutContext,\r\n    DynamicFormControlLayoutPlace,\r\n    DynamicFormControlModel,\r\n    DynamicFormGroupModel,\r\n    DynamicFormLayout,\r\n    DynamicFormLayoutService,\r\n    DynamicFormValidationService,\r\n    DynamicFormValueControlModel,\r\n    DynamicTemplateDirective\r\n} from \"@ng-dynamic-forms/core\";\r\nimport {DynamicFormArrayGroupModel, DynamicFormArrayModel} from \"../../utils/dynamic-form-array.model\";\r\nimport {collectPathAble} from \"../../utils/misc\";\r\nimport {DynamicFormInitControl} from \"../../common-types\";\r\nimport {DynamicBaseFormComponent} from \"./dynamic-base-form.component\";\r\nimport {DynamicBaseFormControlContainerComponent} from \"./dynamic-base-form-control-container.component\";\r\n\r\n@Component({\r\n    selector: \"dynamic-base-form-array\",\r\n    template: \"\",\r\n    changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class DynamicBaseFormArrayComponent extends DynamicFormArrayComponent implements DynamicFormInitControl, OnDestroy {\r\n\r\n    @Input() formLayout: DynamicFormLayout;\r\n    @Input() group: FormGroup;\r\n    @Input() layout: DynamicFormControlLayout;\r\n    @Input() model: DynamicFormArrayModel;\r\n    @Input() templates: QueryList<DynamicTemplateDirective> | undefined;\r\n\r\n    @Output() blur: EventEmitter<any> = new EventEmitter();\r\n    @Output() change: EventEmitter<any> = new EventEmitter();\r\n    @Output() customEvent: EventEmitter<DynamicFormControlCustomEvent> = new EventEmitter();\r\n    @Output() focus: EventEmitter<any> = new EventEmitter();\r\n\r\n    @ViewChildren(forwardRef(() => DynamicBaseFormControlContainerComponent))\r\n    components: QueryList<DynamicBaseFormControlContainerComponent>;\r\n\r\n    get useTabs(): boolean {\r\n        return this.model?.useTabs;\r\n    }\r\n\r\n    protected subscription: Subscription;\r\n\r\n    constructor(layoutService: DynamicFormLayoutService, validationService: DynamicFormValidationService,\r\n                readonly form: DynamicBaseFormComponent, readonly injector: Injector, readonly cdr: ChangeDetectorRef) {\r\n        super(layoutService, validationService);\r\n    }\r\n\r\n    initialize(cdr: ChangeDetectorRef): void {\r\n        this.subscription = this.model.filteredGroups.subscribe(filteredGroups => {\r\n            this.updateGroups(filteredGroups);\r\n        });\r\n        this.model.initialize(this.array);\r\n    }\r\n\r\n    ngOnDestroy(): void {\r\n        if (this.subscription)\r\n            this.subscription.unsubscribe();\r\n    }\r\n\r\n    saveTab(index: number): void {\r\n        this.model.saveTab(index, this.model.getFiltered(index), this.model, this.injector);\r\n    }\r\n\r\n    restoreTab(): number {\r\n        return this.model.restoreTab(this.model, this.injector);\r\n    }\r\n\r\n    getTabLabel(index: number, model: DynamicFormArrayGroupModel): string {\r\n        return this.model.getTabLabel(index, model, this.model, this.array, this.injector);\r\n    }\r\n\r\n    getClass(context: DynamicFormControlLayoutContext, place: DynamicFormControlLayoutPlace, model?: DynamicFormControlModel): string {\r\n        return [\r\n            context == \"element\" ? this.getModelClass(model) : null,\r\n            context == \"element\" ? this.getAdditionalClass(model) : null,\r\n            super.getClass(context, place, model),\r\n            model instanceof DynamicFormValueControlModel ? model.additional?.classes : null\r\n        ].filter(cls => !!cls).join(\" \");\r\n    }\r\n\r\n    protected getModelClass(model?: DynamicFormControlModel): string {\r\n        const parts = collectPathAble(model, p => p.id);\r\n        if (parts.length == 0) return \"\";\r\n        if (model instanceof DynamicFormGroupModel) {\r\n            return `form-group-${parts.join(\"-\")}`;\r\n        }\r\n        return `form-control-${parts.join(\"-\")}`;\r\n    }\r\n\r\n    protected getAdditionalClass(model?: DynamicFormControlModel): string {\r\n        if (model instanceof DynamicFormArrayModel) {\r\n            return model.additional?.classes;\r\n        }\r\n        if (model instanceof DynamicFormValueControlModel) {\r\n            return model.additional?.classes;\r\n        }\r\n        return null;\r\n    }\r\n\r\n    protected updateGroups(filteredGroups: ReadonlyArray<DynamicFormArrayGroupModel>): void {\r\n        this.cdr.detectChanges();\r\n        this.components.forEach(t => t.cdr.detectChanges());\r\n    }\r\n}\r\n"]}
|
package/esm2020/ngx-dynamic-form/components/base/dynamic-base-form-control-container.component.mjs
DELETED
|
@@ -1,127 +0,0 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, Component, ContentChildren, EventEmitter, HostBinding, Input, Output, ViewChild, ViewContainerRef } from "@angular/core";
|
|
2
|
-
import { DYNAMIC_FORM_CONTROL_TYPE_ARRAY, DynamicFormControlContainerComponent, DynamicTemplateDirective } from "@ng-dynamic-forms/core";
|
|
3
|
-
import { ObjectUtils } from "@stemy/ngx-utils";
|
|
4
|
-
import { collectPathAble } from "../../utils/misc";
|
|
5
|
-
import { DynamicFormArrayGroupModel } from "../../utils/dynamic-form-array.model";
|
|
6
|
-
import * as i0 from "@angular/core";
|
|
7
|
-
import * as i1 from "./dynamic-base-form.component";
|
|
8
|
-
import * as i2 from "@ng-dynamic-forms/core";
|
|
9
|
-
export class DynamicBaseFormControlContainerComponent extends DynamicFormControlContainerComponent {
|
|
10
|
-
constructor(form, cdr, injector, cfr, layoutService, validationService, componentService, relationService) {
|
|
11
|
-
super(cdr, cfr, layoutService, validationService, componentService, relationService);
|
|
12
|
-
this.form = form;
|
|
13
|
-
this.cdr = cdr;
|
|
14
|
-
this.injector = injector;
|
|
15
|
-
this.context = null;
|
|
16
|
-
this.blur = new EventEmitter();
|
|
17
|
-
this.change = new EventEmitter();
|
|
18
|
-
this.focus = new EventEmitter();
|
|
19
|
-
}
|
|
20
|
-
get componentType() {
|
|
21
|
-
return this.form.getComponentType?.(this.model, this.injector)
|
|
22
|
-
?? this.componentService.getCustomComponentType(this.model);
|
|
23
|
-
}
|
|
24
|
-
get startTemplate() {
|
|
25
|
-
return (this.model.type == DYNAMIC_FORM_CONTROL_TYPE_ARRAY)
|
|
26
|
-
? this.layoutService.getAlignedTemplate(this.model, this.templates, "ARRAY_START")
|
|
27
|
-
: this.layoutService.getStartTemplate(this.model, this.templates);
|
|
28
|
-
}
|
|
29
|
-
get endTemplate() {
|
|
30
|
-
return (this.model.type == DYNAMIC_FORM_CONTROL_TYPE_ARRAY)
|
|
31
|
-
? this.layoutService.getAlignedTemplate(this.model, this.templates, "ARRAY_END")
|
|
32
|
-
: this.layoutService.getEndTemplate(this.model, this.templates);
|
|
33
|
-
}
|
|
34
|
-
get formService() {
|
|
35
|
-
return this.form.formService;
|
|
36
|
-
}
|
|
37
|
-
ngOnInit() {
|
|
38
|
-
super.ngOnInit();
|
|
39
|
-
this.onDetectChanges = this.form.onDetectChanges.subscribe(() => {
|
|
40
|
-
this.changeDetectorRef.detectChanges();
|
|
41
|
-
});
|
|
42
|
-
}
|
|
43
|
-
ngOnDestroy() {
|
|
44
|
-
super.ngOnDestroy();
|
|
45
|
-
this.onDetectChanges.unsubscribe();
|
|
46
|
-
}
|
|
47
|
-
getLabel() {
|
|
48
|
-
const label = collectPathAble(this.model, p => p.label);
|
|
49
|
-
if (label.length == 0)
|
|
50
|
-
return "";
|
|
51
|
-
if (this.form?.labelPrefix) {
|
|
52
|
-
label.unshift(this.form.labelPrefix);
|
|
53
|
-
}
|
|
54
|
-
return label.join(".");
|
|
55
|
-
}
|
|
56
|
-
getLabelIcon() {
|
|
57
|
-
if (this.context instanceof DynamicFormArrayGroupModel) {
|
|
58
|
-
const arrayModel = this.context.context;
|
|
59
|
-
if (arrayModel && arrayModel.sortBy == this.model.id) {
|
|
60
|
-
return arrayModel.sortOrder;
|
|
61
|
-
}
|
|
62
|
-
}
|
|
63
|
-
return null;
|
|
64
|
-
}
|
|
65
|
-
clickLabel() {
|
|
66
|
-
if (this.context instanceof DynamicFormArrayGroupModel) {
|
|
67
|
-
const arrayModel = this.context.context;
|
|
68
|
-
if (arrayModel) {
|
|
69
|
-
arrayModel.sortBy = this.model.id;
|
|
70
|
-
}
|
|
71
|
-
}
|
|
72
|
-
}
|
|
73
|
-
createFormControlComponent() {
|
|
74
|
-
super.createFormControlComponent();
|
|
75
|
-
const component = this.componentRef?.instance;
|
|
76
|
-
if (!component || !ObjectUtils.isFunction(component.initialize))
|
|
77
|
-
return;
|
|
78
|
-
component.initialize(this.changeDetectorRef);
|
|
79
|
-
}
|
|
80
|
-
}
|
|
81
|
-
DynamicBaseFormControlContainerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: DynamicBaseFormControlContainerComponent, deps: [{ token: i1.DynamicBaseFormComponent }, { token: i0.ChangeDetectorRef }, { token: i0.Injector }, { token: i0.ComponentFactoryResolver }, { token: i2.DynamicFormLayoutService }, { token: i2.DynamicFormValidationService }, { token: i2.DynamicFormComponentService }, { token: i2.DynamicFormRelationService }], target: i0.ɵɵFactoryTarget.Component });
|
|
82
|
-
DynamicBaseFormControlContainerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.8", type: DynamicBaseFormControlContainerComponent, selector: "dynamic-base-form-control", inputs: { context: "context", group: "group", hostClass: "hostClass", inputTemplateList: ["templates", "inputTemplateList"], layout: "layout", model: "model" }, outputs: { blur: "blur", change: "change", focus: "focus" }, host: { properties: { "class": "this.klass" } }, providers: [
|
|
83
|
-
{ provide: DynamicFormControlContainerComponent, useExisting: DynamicBaseFormControlContainerComponent }
|
|
84
|
-
], queries: [{ propertyName: "contentTemplateList", predicate: DynamicTemplateDirective }], viewQueries: [{ propertyName: "componentViewContainerRef", first: true, predicate: ["componentViewContainer"], descendants: true, read: ViewContainerRef, static: true }], usesInheritance: true, ngImport: i0, template: "", isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
85
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: DynamicBaseFormControlContainerComponent, decorators: [{
|
|
86
|
-
type: Component,
|
|
87
|
-
args: [{
|
|
88
|
-
selector: "dynamic-base-form-control",
|
|
89
|
-
template: "",
|
|
90
|
-
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
91
|
-
providers: [
|
|
92
|
-
{ provide: DynamicFormControlContainerComponent, useExisting: DynamicBaseFormControlContainerComponent }
|
|
93
|
-
]
|
|
94
|
-
}]
|
|
95
|
-
}], ctorParameters: function () { return [{ type: i1.DynamicBaseFormComponent }, { type: i0.ChangeDetectorRef }, { type: i0.Injector }, { type: i0.ComponentFactoryResolver }, { type: i2.DynamicFormLayoutService }, { type: i2.DynamicFormValidationService }, { type: i2.DynamicFormComponentService }, { type: i2.DynamicFormRelationService }]; }, propDecorators: { contentTemplateList: [{
|
|
96
|
-
type: ContentChildren,
|
|
97
|
-
args: [DynamicTemplateDirective]
|
|
98
|
-
}], klass: [{
|
|
99
|
-
type: HostBinding,
|
|
100
|
-
args: ["class"]
|
|
101
|
-
}], context: [{
|
|
102
|
-
type: Input
|
|
103
|
-
}], group: [{
|
|
104
|
-
type: Input
|
|
105
|
-
}], hostClass: [{
|
|
106
|
-
type: Input
|
|
107
|
-
}], inputTemplateList: [{
|
|
108
|
-
type: Input,
|
|
109
|
-
args: ["templates"]
|
|
110
|
-
}], layout: [{
|
|
111
|
-
type: Input
|
|
112
|
-
}], model: [{
|
|
113
|
-
type: Input
|
|
114
|
-
}], blur: [{
|
|
115
|
-
type: Output
|
|
116
|
-
}], change: [{
|
|
117
|
-
type: Output
|
|
118
|
-
}], focus: [{
|
|
119
|
-
type: Output
|
|
120
|
-
}], componentViewContainerRef: [{
|
|
121
|
-
type: ViewChild,
|
|
122
|
-
args: ["componentViewContainer", {
|
|
123
|
-
read: ViewContainerRef,
|
|
124
|
-
static: true
|
|
125
|
-
}]
|
|
126
|
-
}] } });
|
|
127
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-base-form-control-container.component.js","sourceRoot":"","sources":["../../../../../src/ngx-dynamic-form/components/base/dynamic-base-form-control-container.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    ChangeDetectionStrategy,\r\n    ChangeDetectorRef,\r\n    Component,\r\n    ComponentFactoryResolver,\r\n    ContentChildren,\r\n    EventEmitter,\r\n    HostBinding,\r\n    Injector,\r\n    Input,\r\n    Output,\r\n    QueryList,\r\n    Type,\r\n    ViewChild,\r\n    ViewContainerRef\r\n} from \"@angular/core\";\r\nimport {FormGroup} from \"@angular/forms\";\r\nimport {Subscription} from \"rxjs\";\r\nimport {\r\n    DYNAMIC_FORM_CONTROL_TYPE_ARRAY,\r\n    DynamicFormComponentService,\r\n    DynamicFormControl,\r\n    DynamicFormControlContainerComponent,\r\n    DynamicFormControlEvent,\r\n    DynamicFormControlModel,\r\n    DynamicFormLayout,\r\n    DynamicFormLayoutService,\r\n    DynamicFormRelationService,\r\n    DynamicFormValidationService,\r\n    DynamicTemplateDirective\r\n} from \"@ng-dynamic-forms/core\";\r\nimport {ObjectUtils} from \"@stemy/ngx-utils\";\r\n\r\nimport {DynamicFormInitControl} from \"../../common-types\";\r\nimport {collectPathAble} from \"../../utils/misc\";\r\nimport {DynamicFormArrayGroupModel} from \"../../utils/dynamic-form-array.model\";\r\nimport {DynamicFormService} from \"../../services/dynamic-form.service\";\r\nimport {DynamicBaseFormComponent} from \"./dynamic-base-form.component\";\r\n\r\n@Component({\r\n    selector: \"dynamic-base-form-control\",\r\n    template: \"\",\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    providers: [\r\n        {provide: DynamicFormControlContainerComponent, useExisting: DynamicBaseFormControlContainerComponent}\r\n    ]\r\n})\r\nexport class DynamicBaseFormControlContainerComponent extends DynamicFormControlContainerComponent {\r\n\r\n    @ContentChildren(DynamicTemplateDirective) contentTemplateList: QueryList<DynamicTemplateDirective>;\r\n\r\n    @HostBinding(\"class\") klass;\r\n\r\n    @Input() context: DynamicFormArrayGroupModel | null = null;\r\n    @Input() group: FormGroup;\r\n    @Input() hostClass: string[];\r\n    @Input(\"templates\") inputTemplateList: QueryList<DynamicTemplateDirective>;\r\n    @Input() layout: DynamicFormLayout;\r\n    @Input() model: DynamicFormControlModel;\r\n\r\n    @Output() blur: EventEmitter<DynamicFormControlEvent> = new EventEmitter<DynamicFormControlEvent>();\r\n    @Output() change: EventEmitter<DynamicFormControlEvent> = new EventEmitter<DynamicFormControlEvent>();\r\n    @Output() focus: EventEmitter<DynamicFormControlEvent> = new EventEmitter<DynamicFormControlEvent>();\r\n\r\n    @ViewChild(\"componentViewContainer\", {\r\n        read: ViewContainerRef,\r\n        static: true\r\n    }) componentViewContainerRef: ViewContainerRef;\r\n\r\n    get componentType(): Type<DynamicFormControl> | null {\r\n        return this.form.getComponentType?.(this.model, this.injector)\r\n            ?? this.componentService.getCustomComponentType(this.model);\r\n    }\r\n\r\n    get startTemplate(): DynamicTemplateDirective {\r\n        return (this.model.type == DYNAMIC_FORM_CONTROL_TYPE_ARRAY)\r\n            ? this.layoutService.getAlignedTemplate(this.model, this.templates, \"ARRAY_START\" as any)\r\n            : this.layoutService.getStartTemplate(this.model, this.templates);\r\n    }\r\n\r\n    get endTemplate(): DynamicTemplateDirective {\r\n        return (this.model.type == DYNAMIC_FORM_CONTROL_TYPE_ARRAY)\r\n            ? this.layoutService.getAlignedTemplate(this.model, this.templates, \"ARRAY_END\" as any)\r\n            : this.layoutService.getEndTemplate(this.model, this.templates);\r\n    }\r\n\r\n    get formService(): DynamicFormService {\r\n        return this.form.formService;\r\n    }\r\n\r\n    protected onDetectChanges: Subscription;\r\n\r\n    constructor(readonly form: DynamicBaseFormComponent,\r\n                readonly cdr: ChangeDetectorRef,\r\n                readonly injector: Injector,\r\n                cfr: ComponentFactoryResolver,\r\n                layoutService: DynamicFormLayoutService,\r\n                validationService: DynamicFormValidationService,\r\n                componentService: DynamicFormComponentService,\r\n                relationService: DynamicFormRelationService) {\r\n        super(cdr, cfr, layoutService, validationService, componentService, relationService);\r\n    }\r\n\r\n    ngOnInit(): void {\r\n        super.ngOnInit();\r\n        this.onDetectChanges = this.form.onDetectChanges.subscribe(() => {\r\n            this.changeDetectorRef.detectChanges();\r\n        });\r\n    }\r\n\r\n    ngOnDestroy(): void {\r\n        super.ngOnDestroy();\r\n        this.onDetectChanges.unsubscribe();\r\n    }\r\n\r\n    getLabel(): string {\r\n        const label = collectPathAble(this.model, p => p.label);\r\n        if (label.length == 0) return \"\";\r\n        if (this.form?.labelPrefix) {\r\n            label.unshift(this.form.labelPrefix);\r\n        }\r\n        return label.join(\".\");\r\n    }\r\n\r\n    getLabelIcon(): string {\r\n        if (this.context instanceof DynamicFormArrayGroupModel) {\r\n            const arrayModel = this.context.context;\r\n            if (arrayModel && arrayModel.sortBy == this.model.id) {\r\n                return arrayModel.sortOrder;\r\n            }\r\n        }\r\n        return null;\r\n    }\r\n\r\n    clickLabel(): void {\r\n        if (this.context instanceof DynamicFormArrayGroupModel) {\r\n            const arrayModel = this.context.context;\r\n            if (arrayModel) {\r\n                arrayModel.sortBy = this.model.id;\r\n            }\r\n        }\r\n    }\r\n\r\n    protected createFormControlComponent() {\r\n        super.createFormControlComponent();\r\n        const component = this.componentRef?.instance as DynamicFormInitControl;\r\n        if (!component || !ObjectUtils.isFunction(component.initialize)) return;\r\n        component.initialize(this.changeDetectorRef);\r\n    }\r\n}\r\n"]}
|