@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.
Files changed (98) hide show
  1. package/fesm2022/stemy-ngx-dynamic-form-ui-nebular.mjs +4 -4
  2. package/fesm2022/stemy-ngx-dynamic-form-ui-nebular.mjs.map +1 -1
  3. package/fesm2022/stemy-ngx-dynamic-form.mjs +859 -1662
  4. package/fesm2022/stemy-ngx-dynamic-form.mjs.map +1 -1
  5. package/ngx-dynamic-form/common-types.d.ts +109 -26
  6. package/ngx-dynamic-form/components/dynamic-form/dynamic-form.component.d.ts +21 -0
  7. package/ngx-dynamic-form/components/dynamic-form-array/dynamic-form-array.component.d.ts +9 -0
  8. package/ngx-dynamic-form/components/dynamic-form-chips/dynamic-form-chips.component.d.ts +7 -0
  9. package/ngx-dynamic-form/components/dynamic-form-field/dynamic-form-field.component.d.ts +6 -0
  10. package/ngx-dynamic-form/components/dynamic-form-fieldset/dynamic-form-fieldset.component.d.ts +7 -0
  11. package/ngx-dynamic-form/components/dynamic-form-group/dynamic-form-group.component.d.ts +6 -0
  12. package/ngx-dynamic-form/components/dynamic-form-upload/dynamic-form-upload.component.d.ts +7 -0
  13. package/ngx-dynamic-form/directives/async-submit.directive.d.ts +17 -23
  14. package/ngx-dynamic-form/ngx-dynamic-form.imports.d.ts +5 -9
  15. package/ngx-dynamic-form/ngx-dynamic-form.module.d.ts +13 -11
  16. package/ngx-dynamic-form/services/dynamic-form-builder.service.d.ts +27 -0
  17. package/ngx-dynamic-form/services/dynamic-form.service.d.ts +28 -46
  18. package/ngx-dynamic-form/utils/customizer.d.ts +5 -12
  19. package/ngx-dynamic-form/utils/decorators.d.ts +10 -0
  20. package/ngx-dynamic-form/utils/misc.d.ts +2 -4
  21. package/ngx-dynamic-form/utils/validation.d.ts +13 -0
  22. package/package.json +21 -16
  23. package/public_api.d.ts +13 -18
  24. package/ui-nebular/index.d.ts +1 -5
  25. package/common-types.d.ts +0 -37
  26. package/components/base/dynamic-base-form-array.component.d.ts +0 -38
  27. package/components/base/dynamic-base-form-control-container.component.d.ts +0 -39
  28. package/components/base/dynamic-base-form-control.component.d.ts +0 -26
  29. package/components/base/dynamic-base-form-group.component.d.ts +0 -25
  30. package/components/base/dynamic-base-form.component.d.ts +0 -46
  31. package/components/base/dynamic-base-select.component.d.ts +0 -15
  32. package/directives/async-submit.directive.d.ts +0 -31
  33. package/esm2020/ngx-dynamic-form/common-types.mjs +0 -2
  34. package/esm2020/ngx-dynamic-form/components/base/dynamic-base-form-array.component.mjs +0 -104
  35. package/esm2020/ngx-dynamic-form/components/base/dynamic-base-form-control-container.component.mjs +0 -127
  36. package/esm2020/ngx-dynamic-form/components/base/dynamic-base-form-control.component.mjs +0 -57
  37. package/esm2020/ngx-dynamic-form/components/base/dynamic-base-form-group.component.mjs +0 -75
  38. package/esm2020/ngx-dynamic-form/components/base/dynamic-base-form.component.mjs +0 -182
  39. package/esm2020/ngx-dynamic-form/components/base/dynamic-base-select.component.mjs +0 -66
  40. package/esm2020/ngx-dynamic-form/directives/async-submit.directive.mjs +0 -116
  41. package/esm2020/ngx-dynamic-form/ngx-dynamic-form.imports.mjs +0 -26
  42. package/esm2020/ngx-dynamic-form/ngx-dynamic-form.module.mjs +0 -116
  43. package/esm2020/ngx-dynamic-form/services/dynamic-form.service.mjs +0 -615
  44. package/esm2020/ngx-dynamic-form/utils/creators.mjs +0 -67
  45. package/esm2020/ngx-dynamic-form/utils/customizer.mjs +0 -28
  46. package/esm2020/ngx-dynamic-form/utils/dynamic-editor.model.mjs +0 -14
  47. package/esm2020/ngx-dynamic-form/utils/dynamic-form-array.model.mjs +0 -128
  48. package/esm2020/ngx-dynamic-form/utils/dynamic-form-group.model.mjs +0 -26
  49. package/esm2020/ngx-dynamic-form/utils/dynamic-select.model.mjs +0 -59
  50. package/esm2020/ngx-dynamic-form/utils/form-select-subject.mjs +0 -26
  51. package/esm2020/ngx-dynamic-form/utils/form-subject.mjs +0 -29
  52. package/esm2020/ngx-dynamic-form/utils/misc.mjs +0 -47
  53. package/esm2020/ngx-dynamic-form/utils/validation-errors.mjs +0 -22
  54. package/esm2020/ngx-dynamic-form/utils/validators.mjs +0 -56
  55. package/esm2020/public_api.mjs +0 -21
  56. package/esm2020/stemy-ngx-dynamic-form.mjs +0 -5
  57. package/fesm2015/stemy-ngx-dynamic-form.mjs +0 -1927
  58. package/fesm2015/stemy-ngx-dynamic-form.mjs.map +0 -1
  59. package/fesm2020/stemy-ngx-dynamic-form.mjs +0 -1893
  60. package/fesm2020/stemy-ngx-dynamic-form.mjs.map +0 -1
  61. package/fesm2022/stemy-ngx-dynamic-form-src-ngx-dynamic-form-nebular.mjs +0 -50
  62. package/fesm2022/stemy-ngx-dynamic-form-src-ngx-dynamic-form-nebular.mjs.map +0 -1
  63. package/imports.d.ts +0 -12
  64. package/ngx-dynamic-form/components/base/dynamic-base-form-array.component.d.ts +0 -38
  65. package/ngx-dynamic-form/components/base/dynamic-base-form-control-container.component.d.ts +0 -39
  66. package/ngx-dynamic-form/components/base/dynamic-base-form-control.component.d.ts +0 -26
  67. package/ngx-dynamic-form/components/base/dynamic-base-form-group.component.d.ts +0 -25
  68. package/ngx-dynamic-form/components/base/dynamic-base-form.component.d.ts +0 -46
  69. package/ngx-dynamic-form/components/base/dynamic-base-select.component.d.ts +0 -15
  70. package/ngx-dynamic-form/services/dynamic-form-layout.service.d.ts +0 -7
  71. package/ngx-dynamic-form/utils/creators.d.ts +0 -18
  72. package/ngx-dynamic-form/utils/dynamic-editor.model.d.ts +0 -11
  73. package/ngx-dynamic-form/utils/dynamic-form-array.model.d.ts +0 -69
  74. package/ngx-dynamic-form/utils/dynamic-form-group.model.d.ts +0 -14
  75. package/ngx-dynamic-form/utils/dynamic-select.model.d.ts +0 -39
  76. package/ngx-dynamic-form/utils/form-select-subject.d.ts +0 -6
  77. package/ngx-dynamic-form/utils/form-subject.d.ts +0 -10
  78. package/ngx-dynamic-form/utils/validators.d.ts +0 -8
  79. package/ngx-dynamic-form.imports.d.ts +0 -12
  80. package/ngx-dynamic-form.module.d.ts +0 -21
  81. package/services/dynamic-form.service.d.ts +0 -61
  82. package/src/ngx-dynamic-form/nebular/imports.d.ts +0 -4
  83. package/src/ngx-dynamic-form/nebular/index.d.ts +0 -5
  84. package/src/ngx-dynamic-form/nebular/ngx-dynamic-form.nebular.module.d.ts +0 -9
  85. package/src/ngx-dynamic-form/nebular/public_api.d.ts +0 -1
  86. package/stemy-ngx-dynamic-form.d.ts +0 -5
  87. package/ui-nebular/public_api.d.ts +0 -1
  88. package/utils/creators.d.ts +0 -18
  89. package/utils/customizer.d.ts +0 -14
  90. package/utils/dynamic-editor.model.d.ts +0 -11
  91. package/utils/dynamic-form-array.model.d.ts +0 -69
  92. package/utils/dynamic-form-group.model.d.ts +0 -14
  93. package/utils/dynamic-select.model.d.ts +0 -39
  94. package/utils/form-select-subject.d.ts +0 -6
  95. package/utils/form-subject.d.ts +0 -10
  96. package/utils/misc.d.ts +0 -11
  97. package/utils/validation-errors.d.ts +0 -11
  98. package/utils/validators.d.ts +0 -8
package/public_api.d.ts CHANGED
@@ -1,21 +1,16 @@
1
- export { IDynamicFormEvent, IDynamicForm, FormControlSerializer, FormModelCustomizer, ModelForSchemaOptions, DynamicFormState, DynamicFormUpdateOn, DynamicFormInitControl, AsyncSubmitMethod, GetFormControlComponentType, IDynamicFormModuleConfig, } from "./ngx-dynamic-form/common-types";
2
- export { createFormCheckbox, createFormDate, createFormEditor, createFormArray, createFormGroup, createFormInput, createFormSelect, createFormTextarea, createFormFile, } from "./ngx-dynamic-form/utils/creators";
3
- export { IFormComponentCustomizer, getFormComponent, IFormModelCustomizer, customizeFormModel } from "./ngx-dynamic-form/utils/customizer";
4
- export { replaceSpecialChars, mergeFormModels, collectPathAble, getDynamicPath, MIN_INPUT_NUM, MAX_INPUT_NUM, EDITOR_FORMATS } from "./ngx-dynamic-form/utils/misc";
5
- export { validateJSON, validateRequiredTranslation, validatePhone, validateItemsMinLength, validateItemsMaxLength, validateItemsMinValue, validateItemsMaxValue } from "./ngx-dynamic-form/utils/validators";
6
- export { DynamicEditorModelConfig, DynamicEditorModel } from "./ngx-dynamic-form/utils/dynamic-editor.model";
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 { DynamicBaseFormComponent } from "./ngx-dynamic-form/components/base/dynamic-base-form.component";
15
- export { DynamicBaseFormArrayComponent } from "./ngx-dynamic-form/components/base/dynamic-base-form-array.component";
16
- export { DynamicBaseFormControlComponent } from "./ngx-dynamic-form/components/base/dynamic-base-form-control.component";
17
- export { DynamicBaseFormControlContainerComponent } from "./ngx-dynamic-form/components/base/dynamic-base-form-control-container.component";
18
- export { DynamicBaseFormGroupComponent } from "./ngx-dynamic-form/components/base/dynamic-base-form-group.component";
19
- export { DynamicBaseSelectComponent } from "./ngx-dynamic-form/components/base/dynamic-base-select.component";
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";
@@ -1,5 +1 @@
1
- /**
2
- * Generated bundle index. Do not edit.
3
- */
4
- /// <amd-module name="@stemy/ngx-dynamic-form/ui-nebular" />
5
- export * from './public_api';
1
+ export { NgxDynamicFormNebularModule } from "./ngx-dynamic-form.nebular.module";
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"]}
@@ -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"]}