@wemake4u/form-player-se 1.0.40 → 1.0.41
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/esm2022/lib/components/setFilter/setFilter.component.mjs +18 -3
- package/esm2022/lib/controls/accordion.mjs +50 -3
- package/esm2022/lib/controls/control.mjs +70 -25
- package/esm2022/lib/controls/factory.mjs +42 -42
- package/esm2022/lib/controls/tab.mjs +47 -25
- package/esm2022/lib/controls/table.mjs +89 -15
- package/esm2022/lib/controls/textfield.mjs +4 -3
- package/esm2022/lib/directives/register.directive.mjs +28 -9
- package/esm2022/lib/directives/tabcontrol.directive.mjs +1 -1
- package/esm2022/lib/dynamic-fields/dynamic-fields.component.mjs +11 -4
- package/esm2022/lib/dynamic-form/dynamic-form.component.mjs +8 -5
- package/esm2022/lib/services/formatter.service.mjs +3 -1
- package/esm2022/lib/services/navigation.service.mjs +35 -0
- package/esm2022/lib/services/register.service.mjs +40 -2
- package/esm2022/lib/services/state.service.mjs +40 -0
- package/esm2022/lib/utils/navigation.mjs +20 -0
- package/esm2022/lib/utils/patch.mjs +17 -0
- package/esm2022/public-api.mjs +3 -1
- package/fesm2022/wemake4u-form-player-se.mjs +510 -157
- package/fesm2022/wemake4u-form-player-se.mjs.map +1 -1
- package/lib/controls/accordion.d.ts +5 -1
- package/lib/controls/control.d.ts +31 -12
- package/lib/controls/factory.d.ts +2 -4
- package/lib/controls/tab.d.ts +9 -6
- package/lib/controls/table.d.ts +16 -5
- package/lib/controls/textfield.d.ts +1 -1
- package/lib/directives/register.directive.d.ts +3 -2
- package/lib/dynamic-fields/dynamic-fields.component.d.ts +3 -1
- package/lib/services/navigation.service.d.ts +11 -0
- package/lib/services/register.service.d.ts +9 -0
- package/lib/services/state.service.d.ts +14 -0
- package/lib/utils/navigation.d.ts +6 -0
- package/lib/utils/patch.d.ts +1 -0
- package/package.json +1 -1
- package/public-api.d.ts +2 -0
|
@@ -1,19 +1,93 @@
|
|
|
1
|
+
import { merge } from 'rxjs';
|
|
2
|
+
import { takeUntilDestroyed } from "@angular/core/rxjs-interop";
|
|
1
3
|
import { Control } from "./control";
|
|
4
|
+
import { AgGridAngular } from 'ag-grid-angular';
|
|
5
|
+
import { subscribeOnce } from '../utils/observable';
|
|
2
6
|
export class TableControl extends Control {
|
|
3
|
-
setFilter
|
|
4
|
-
this.
|
|
5
|
-
}
|
|
6
|
-
|
|
7
|
-
this.
|
|
8
|
-
}
|
|
9
|
-
|
|
10
|
-
this.
|
|
11
|
-
}
|
|
12
|
-
|
|
13
|
-
this.
|
|
14
|
-
}
|
|
15
|
-
|
|
16
|
-
|
|
7
|
+
setFilter(filter) {
|
|
8
|
+
this.grid.api.setFilterModel(filter);
|
|
9
|
+
}
|
|
10
|
+
getFilter() {
|
|
11
|
+
return this.grid.api.getFilterModel();
|
|
12
|
+
}
|
|
13
|
+
clearFilter() {
|
|
14
|
+
this.grid.api.setFilterModel(null);
|
|
15
|
+
}
|
|
16
|
+
refresh() {
|
|
17
|
+
this.grid._refresh();
|
|
18
|
+
}
|
|
19
|
+
redraw() {
|
|
20
|
+
this.grid.api.redrawRows();
|
|
21
|
+
}
|
|
22
|
+
//#region State
|
|
23
|
+
currentState = null;
|
|
24
|
+
onLoadState() {
|
|
25
|
+
const destroyRef = this.getDestroyRef();
|
|
26
|
+
merge(this.grid.filterChanged, this.grid.sortChanged, this.grid.columnResized, this.grid.paginationChanged).pipe(takeUntilDestroyed(destroyRef))
|
|
27
|
+
.subscribe(() => {
|
|
28
|
+
this.currentState = this.createState();
|
|
29
|
+
});
|
|
30
|
+
this.grid.gridReady
|
|
31
|
+
.pipe(takeUntilDestroyed(destroyRef))
|
|
32
|
+
.subscribe(event => {
|
|
33
|
+
this.applyState();
|
|
34
|
+
});
|
|
35
|
+
}
|
|
36
|
+
onSaveState() {
|
|
37
|
+
this.setState(this.currentState);
|
|
38
|
+
}
|
|
39
|
+
createState() {
|
|
40
|
+
return {
|
|
41
|
+
columns: this.grid.api.getColumnState(),
|
|
42
|
+
filter: this.grid.api.getFilterModel(),
|
|
43
|
+
pagination: this.paginationEnabled() ? {
|
|
44
|
+
page: this.grid.api.paginationGetCurrentPage(),
|
|
45
|
+
pageSize: this.grid.api.paginationGetPageSize(),
|
|
46
|
+
} : null
|
|
47
|
+
};
|
|
48
|
+
}
|
|
49
|
+
applyState() {
|
|
50
|
+
const state = this.getState();
|
|
51
|
+
if (state) {
|
|
52
|
+
if (state.columns)
|
|
53
|
+
this.grid.api.applyColumnState({ state: state.columns, applyOrder: true });
|
|
54
|
+
if (state.filter)
|
|
55
|
+
this.grid.api.setFilterModel(state.filter);
|
|
56
|
+
if (state.pagination)
|
|
57
|
+
this.applyPagination(state.pagination);
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
applyPagination(pagination) {
|
|
61
|
+
if (!this.paginationEnabled())
|
|
62
|
+
return;
|
|
63
|
+
this.applyPageSize(pagination.pageSize);
|
|
64
|
+
this.applyPageNumber(pagination.page);
|
|
65
|
+
}
|
|
66
|
+
applyPageSize(pageSize) {
|
|
67
|
+
if (this.grid.api.paginationGetPageSize() != pageSize)
|
|
68
|
+
this.grid.api.setGridOption('paginationPageSize', pageSize);
|
|
69
|
+
}
|
|
70
|
+
applyPageNumber(pageNumber, subscribe = true) {
|
|
71
|
+
if (this.grid.api.paginationGetCurrentPage() != pageNumber) {
|
|
72
|
+
this.grid.api.paginationGoToPage(pageNumber);
|
|
73
|
+
if (subscribe) {
|
|
74
|
+
subscribeOnce(this.grid.firstDataRendered, () => {
|
|
75
|
+
this.applyPageNumber(pageNumber, false);
|
|
76
|
+
});
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
//#endregion
|
|
81
|
+
//#region Private Members
|
|
82
|
+
get grid() {
|
|
83
|
+
const ref = this.getComponentRef();
|
|
84
|
+
if (!(ref instanceof AgGridAngular)) {
|
|
85
|
+
throw new Error('ComponentRef is not a AgGridAngular');
|
|
86
|
+
}
|
|
87
|
+
return ref;
|
|
88
|
+
}
|
|
89
|
+
paginationEnabled() {
|
|
90
|
+
return this.grid.api.getGridOption('pagination') === true;
|
|
17
91
|
}
|
|
18
92
|
}
|
|
19
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
93
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.js","sourceRoot":"","sources":["../../../../../projects/ngx-sirio/src/lib/controls/table.ts"],"names":[],"mappings":"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","sourcesContent":["import { merge } from 'rxjs';\r\nimport { takeUntilDestroyed } from \"@angular/core/rxjs-interop\";\r\nimport { Control } from \"./control\";\r\nimport { AgGridAngular } from 'ag-grid-angular';\r\nimport { FilterModel, ColumnState } from 'ag-grid-community';\r\nimport { subscribeOnce } from '../utils/observable';\r\n\r\nexport class TableControl extends Control {\r\n\r\n  setFilter(filter: FilterModel): void {\r\n    this.grid.api.setFilterModel(filter);\r\n  }\r\n\r\n  getFilter(): FilterModel {\r\n    return this.grid.api.getFilterModel();\r\n  }\r\n\r\n  clearFilter(): void {\r\n    this.grid.api.setFilterModel(null);\r\n  }\r\n\r\n  refresh(): void {\r\n    (this.grid as any)._refresh();\r\n  }\r\n\r\n  redraw(): void {\r\n    this.grid.api.redrawRows();\r\n  }\r\n\r\n  //#region State\r\n\r\n  private currentState: TableControlState | null = null;\r\n\r\n  override onLoadState(): void {\r\n\r\n    const destroyRef = this.getDestroyRef();\r\n\r\n    merge(\r\n      this.grid.filterChanged,\r\n      this.grid.sortChanged,\r\n      this.grid.columnResized,\r\n      this.grid.paginationChanged,\r\n    ).pipe(takeUntilDestroyed(destroyRef))\r\n      .subscribe(() => {\r\n        this.currentState = this.createState();\r\n      });\r\n\r\n    this.grid.gridReady\r\n      .pipe(takeUntilDestroyed(destroyRef))\r\n      .subscribe(event => {\r\n        this.applyState();\r\n      });\r\n  }\r\n\r\n  override onSaveState(): void {\r\n    this.setState(this.currentState);\r\n  }\r\n\r\n  private createState(): TableControlState | null {\r\n    return {\r\n      columns: this.grid.api.getColumnState(),\r\n      filter: this.grid.api.getFilterModel(),\r\n      pagination: this.paginationEnabled() ? {\r\n        page: this.grid.api.paginationGetCurrentPage(),\r\n        pageSize: this.grid.api.paginationGetPageSize(),\r\n      } : null\r\n    }\r\n  }\r\n\r\n  private applyState() {\r\n    const state = this.getState<TableControlState>();\r\n    if (state) {\r\n      if (state.columns)\r\n        this.grid.api.applyColumnState({ state: state.columns, applyOrder: true });\r\n      if (state.filter)\r\n        this.grid.api.setFilterModel(state.filter);\r\n      if (state.pagination)\r\n        this.applyPagination(state.pagination)\r\n    }\r\n  }\r\n\r\n  private applyPagination(pagination: TablePaginationState) {\r\n    if (!this.paginationEnabled()) return;\r\n    this.applyPageSize(pagination.pageSize);\r\n    this.applyPageNumber(pagination.page);\r\n  }\r\n\r\n  private applyPageSize(pageSize: number) {\r\n    if (this.grid.api.paginationGetPageSize() != pageSize)\r\n      this.grid.api.setGridOption('paginationPageSize', pageSize);\r\n  }\r\n\r\n  private applyPageNumber(pageNumber: number, subscribe: boolean = true) {\r\n    if (this.grid.api.paginationGetCurrentPage() != pageNumber) {\r\n      this.grid.api.paginationGoToPage(pageNumber);\r\n      if (subscribe) {\r\n        subscribeOnce(this.grid.firstDataRendered, () => {\r\n          this.applyPageNumber(pageNumber, false);\r\n        });\r\n      }      \r\n    }\r\n  }\r\n\r\n  //#endregion\r\n\r\n  //#region Private Members\r\n\r\n  private get grid(): AgGridAngular {\r\n    const ref = this.getComponentRef();\r\n    if (!(ref instanceof AgGridAngular)) {\r\n      throw new Error(\r\n        'ComponentRef is not a AgGridAngular'\r\n      );\r\n    }\r\n    return ref;\r\n  }\r\n\r\n  private paginationEnabled(): boolean {\r\n    return this.grid.api.getGridOption('pagination') === true;\r\n  }\r\n\r\n  //#endregion\r\n}\r\n\r\ninterface TableControlState {\r\n  columns: ColumnState[] | null\r\n  filter: FilterModel | null\r\n  pagination: TablePaginationState | null\r\n}\r\n\r\ninterface TablePaginationState {\r\n  page: number,\r\n  pageSize: number\r\n}\r\n"]}
|
|
@@ -1,8 +1,9 @@
|
|
|
1
1
|
import { Control } from "./control";
|
|
2
2
|
export class TextFieldControl extends Control {
|
|
3
|
-
setRandomColor
|
|
3
|
+
setRandomColor() {
|
|
4
4
|
this.getInput().sirioInput.nativeElement.style.backgroundColor = this.getRandomColor();
|
|
5
|
-
}
|
|
5
|
+
}
|
|
6
|
+
//#region Private Methods
|
|
6
7
|
getInput() {
|
|
7
8
|
return this.getComponentRef();
|
|
8
9
|
}
|
|
@@ -15,4 +16,4 @@ export class TextFieldControl extends Control {
|
|
|
15
16
|
return color;
|
|
16
17
|
}
|
|
17
18
|
}
|
|
18
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
19
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGV4dGZpZWxkLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LXNpcmlvL3NyYy9saWIvY29udHJvbHMvdGV4dGZpZWxkLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxXQUFXLENBQUM7QUFHcEMsTUFBTSxPQUFPLGdCQUFpQixTQUFRLE9BQU87SUFFM0MsY0FBYztRQUNaLElBQUksQ0FBQyxRQUFRLEVBQUUsQ0FBQyxVQUFVLENBQUMsYUFBYSxDQUFDLEtBQUssQ0FBQyxlQUFlLEdBQUcsSUFBSSxDQUFDLGNBQWMsRUFBRSxDQUFDO0lBQ3pGLENBQUM7SUFFRCx5QkFBeUI7SUFFakIsUUFBUTtRQUNkLE9BQU8sSUFBSSxDQUFDLGVBQWUsRUFBeUIsQ0FBQztJQUN2RCxDQUFDO0lBRU8sY0FBYztRQUNwQixNQUFNLE9BQU8sR0FBRyxrQkFBa0IsQ0FBQztRQUNuQyxJQUFJLEtBQUssR0FBRyxHQUFHLENBQUM7UUFFaEIsS0FBSyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEVBQUUsRUFBRSxDQUFDO1lBQzNCLEtBQUssSUFBSSxPQUFPLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsTUFBTSxFQUFFLEdBQUcsRUFBRSxDQUFDLENBQUMsQ0FBQztRQUNuRCxDQUFDO1FBRUQsT0FBTyxLQUFLLENBQUM7SUFDZixDQUFDO0NBR0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb250cm9sIH0gZnJvbSBcIi4vY29udHJvbFwiO1xyXG5pbXBvcnQgeyBTaXJpb0lucHV0Q29tcG9uZW50IH0gZnJvbSBcIm5neC1zaXJpby1saWJcIjtcclxuXHJcbmV4cG9ydCBjbGFzcyBUZXh0RmllbGRDb250cm9sIGV4dGVuZHMgQ29udHJvbCB7XHJcblxyXG4gIHNldFJhbmRvbUNvbG9yKCk6IHZvaWR7XHJcbiAgICB0aGlzLmdldElucHV0KCkuc2lyaW9JbnB1dC5uYXRpdmVFbGVtZW50LnN0eWxlLmJhY2tncm91bmRDb2xvciA9IHRoaXMuZ2V0UmFuZG9tQ29sb3IoKTtcclxuICB9XHJcblxyXG4gIC8vI3JlZ2lvbiBQcml2YXRlIE1ldGhvZHNcclxuXHJcbiAgcHJpdmF0ZSBnZXRJbnB1dCgpOiBTaXJpb0lucHV0Q29tcG9uZW50IHtcclxuICAgIHJldHVybiB0aGlzLmdldENvbXBvbmVudFJlZigpIGFzIFNpcmlvSW5wdXRDb21wb25lbnQ7XHJcbiAgfVxyXG5cclxuICBwcml2YXRlIGdldFJhbmRvbUNvbG9yKCk6IHN0cmluZyB7XHJcbiAgICBjb25zdCBsZXR0ZXJzID0gJzAxMjM0NTY3ODlBQkNERUYnO1xyXG4gICAgbGV0IGNvbG9yID0gJyMnO1xyXG5cclxuICAgIGZvciAobGV0IGkgPSAwOyBpIDwgNjsgaSsrKSB7XHJcbiAgICAgIGNvbG9yICs9IGxldHRlcnNbTWF0aC5mbG9vcihNYXRoLnJhbmRvbSgpICogMTYpXTtcclxuICAgIH1cclxuXHJcbiAgICByZXR1cm4gY29sb3I7XHJcbiAgfVxyXG5cclxuICAvLyNlbmRyZWdpb25cclxufVxyXG4iXX0=
|
|
@@ -10,14 +10,16 @@ export class RegisterDirective {
|
|
|
10
10
|
el;
|
|
11
11
|
destroyRef;
|
|
12
12
|
registerService;
|
|
13
|
+
injector;
|
|
13
14
|
register = null;
|
|
14
15
|
componentRef;
|
|
15
16
|
dynamicField;
|
|
16
17
|
itemFields;
|
|
17
|
-
constructor(el, destroyRef, registerService) {
|
|
18
|
+
constructor(el, destroyRef, registerService, injector) {
|
|
18
19
|
this.el = el;
|
|
19
20
|
this.destroyRef = destroyRef;
|
|
20
21
|
this.registerService = registerService;
|
|
22
|
+
this.injector = injector;
|
|
21
23
|
}
|
|
22
24
|
ngAfterContentInit() {
|
|
23
25
|
this.registerControl();
|
|
@@ -27,10 +29,22 @@ export class RegisterDirective {
|
|
|
27
29
|
}
|
|
28
30
|
registerControl() {
|
|
29
31
|
const name = this.getName();
|
|
32
|
+
const path = this.registerService.getPath();
|
|
33
|
+
const createContext = (register) => ({
|
|
34
|
+
name: name,
|
|
35
|
+
path: path,
|
|
36
|
+
metadata: this.register,
|
|
37
|
+
componentRef: this.componentRef,
|
|
38
|
+
elementRef: this.el,
|
|
39
|
+
injector: this.injector,
|
|
40
|
+
destroyRef: this.destroyRef,
|
|
41
|
+
register
|
|
42
|
+
});
|
|
30
43
|
const register = (this.register.type === 'dynamiclist')
|
|
31
|
-
? this.createDynamicRegister(
|
|
44
|
+
? this.createDynamicRegister(createContext(), this.itemFields)
|
|
32
45
|
: this.dynamicField?.getRegister();
|
|
33
|
-
const
|
|
46
|
+
const context = createContext(register);
|
|
47
|
+
const control = createControl(context);
|
|
34
48
|
this.registerService.register(name, control);
|
|
35
49
|
}
|
|
36
50
|
unregisterControl() {
|
|
@@ -39,14 +53,19 @@ export class RegisterDirective {
|
|
|
39
53
|
getName() {
|
|
40
54
|
return this.register.name ?? this.register.id;
|
|
41
55
|
}
|
|
42
|
-
createDynamicRegister(
|
|
56
|
+
createDynamicRegister(context, itemFields) {
|
|
43
57
|
const newRegister = new RegisterService(null);
|
|
44
58
|
const registerAll = (itemFields) => {
|
|
45
59
|
newRegister.unregisterAll();
|
|
46
60
|
itemFields.forEach((itemField, index) => {
|
|
47
61
|
const register = itemField.getRegister();
|
|
48
|
-
const newName = `${name}-${index}`;
|
|
49
|
-
const
|
|
62
|
+
const newName = `${context.name}-${index}`;
|
|
63
|
+
const itemContext = {
|
|
64
|
+
...context,
|
|
65
|
+
name: newName,
|
|
66
|
+
register: register
|
|
67
|
+
};
|
|
68
|
+
const control = new ItemControl(itemContext, index);
|
|
50
69
|
newRegister.register(newName, control);
|
|
51
70
|
});
|
|
52
71
|
};
|
|
@@ -58,7 +77,7 @@ export class RegisterDirective {
|
|
|
58
77
|
});
|
|
59
78
|
return newRegister;
|
|
60
79
|
}
|
|
61
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: RegisterDirective, deps: [{ token: i0.ElementRef }, { token: i0.DestroyRef }, { token: i1.RegisterService }], target: i0.ɵɵFactoryTarget.Directive });
|
|
80
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: RegisterDirective, deps: [{ token: i0.ElementRef }, { token: i0.DestroyRef }, { token: i1.RegisterService }, { token: i0.Injector }], target: i0.ɵɵFactoryTarget.Directive });
|
|
62
81
|
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.14", type: RegisterDirective, isStandalone: true, selector: "[register]", inputs: { register: "register", componentRef: "componentRef" }, queries: [{ propertyName: "dynamicField", first: true, predicate: i0.forwardRef(() => DynamicFieldsComponent), descendants: true }, { propertyName: "itemFields", predicate: i0.forwardRef(() => DynamicFieldsComponent), descendants: true }], ngImport: i0 });
|
|
63
82
|
}
|
|
64
83
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: RegisterDirective, decorators: [{
|
|
@@ -67,7 +86,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
|
|
|
67
86
|
selector: '[register]',
|
|
68
87
|
standalone: true
|
|
69
88
|
}]
|
|
70
|
-
}], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.DestroyRef }, { type: i1.RegisterService }], propDecorators: { register: [{
|
|
89
|
+
}], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.DestroyRef }, { type: i1.RegisterService }, { type: i0.Injector }], propDecorators: { register: [{
|
|
71
90
|
type: Input
|
|
72
91
|
}], componentRef: [{
|
|
73
92
|
type: Input
|
|
@@ -78,4 +97,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
|
|
|
78
97
|
type: ContentChildren,
|
|
79
98
|
args: [forwardRef(() => DynamicFieldsComponent), { descendants: true }]
|
|
80
99
|
}] } });
|
|
81
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
100
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"register.directive.js","sourceRoot":"","sources":["../../../../../projects/ngx-sirio/src/lib/directives/register.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Directive, Input, ElementRef, AfterContentInit, OnDestroy\r\n  , ContentChild, ContentChildren, QueryList, forwardRef\r\n  , DestroyRef, Injector\r\n} from '@angular/core';\r\nimport { RegisterService } from '../services/register.service';\r\nimport { createControl } from '../controls/factory';\r\nimport { DynamicFieldsComponent } from '../dynamic-fields/dynamic-fields.component';\r\nimport { IDynamicFieldsComponent } from '../dynamic-fields/dynamic-fields.interface';\r\nimport { ControlContext, ItemControl } from '../controls/control';\r\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\r\n\r\n@Directive({\r\n  selector: '[register]',\r\n  standalone: true\r\n})\r\nexport class RegisterDirective implements AfterContentInit, OnDestroy {\r\n  @Input() register: any = null;\r\n  @Input() componentRef: any;\r\n  @ContentChild(forwardRef(() => DynamicFieldsComponent)) dynamicField?: IDynamicFieldsComponent;\r\n  @ContentChildren(forwardRef(() => DynamicFieldsComponent), { descendants: true }) itemFields!: QueryList<IDynamicFieldsComponent>;\r\n  \r\n  constructor(\r\n    private el: ElementRef,\r\n    private destroyRef: DestroyRef,\r\n    private registerService: RegisterService,\r\n    private injector: Injector\r\n  )\r\n  { }\r\n\r\n  ngAfterContentInit(): void {\r\n    this.registerControl();\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.unregisterControl();\r\n  }\r\n\r\n  private registerControl(): void {\r\n    const name = this.getName();\r\n    const path = this.registerService.getPath();\r\n\r\n    const createContext = (\r\n      register?: RegisterService\r\n    ): ControlContext => ({\r\n      name: name,\r\n      path: path,\r\n      metadata: this.register,\r\n      componentRef: this.componentRef,\r\n      elementRef: this.el,\r\n      injector: this.injector,\r\n      destroyRef: this.destroyRef,\r\n      register\r\n    });\r\n\r\n    const register = (this.register.type === 'dynamiclist')\r\n      ? this.createDynamicRegister(createContext(), this.itemFields)\r\n      : this.dynamicField?.getRegister();\r\n\r\n    const context = createContext(register);\r\n\r\n    const control = createControl(context);\r\n\r\n    this.registerService.register(name, control);\r\n  }\r\n\r\n  private unregisterControl(): void {\r\n    this.registerService.unregister(this.getName());\r\n  }\r\n\r\n  private getName(): string {\r\n    return this.register.name ?? this.register.id;\r\n  }\r\n\r\n  private createDynamicRegister(context: ControlContext\r\n    , itemFields: QueryList<IDynamicFieldsComponent>): RegisterService {\r\n\r\n    const newRegister = new RegisterService(null);\r\n\r\n    const registerAll = (itemFields: QueryList<IDynamicFieldsComponent>) => {\r\n      newRegister.unregisterAll();\r\n      itemFields.forEach((itemField, index) => {\r\n        const register = itemField.getRegister();\r\n        const newName = `${context.name}-${index}`;\r\n        const itemContext = {\r\n          ...context,\r\n          name: newName,\r\n          register: register\r\n        }        \r\n        const control = new ItemControl(itemContext, index);\r\n        newRegister.register(newName, control);\r\n      });\r\n    }\r\n\r\n    registerAll(itemFields);\r\n\r\n    itemFields.changes\r\n      .pipe(takeUntilDestroyed(this.destroyRef))\r\n      .subscribe((itemFields: QueryList<IDynamicFieldsComponent>) => {\r\n        registerAll(itemFields);\r\n      });\r\n\r\n    return newRegister;\r\n  }\r\n}\r\n"]}
|
|
@@ -54,4 +54,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
|
|
|
54
54
|
}], ctorParameters: () => [{ type: i1.SirioTabComponent, decorators: [{
|
|
55
55
|
type: Host
|
|
56
56
|
}] }, { type: i0.DestroyRef }] });
|
|
57
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
57
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFiY29udHJvbC5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtc2lyaW8vc3JjL2xpYi9kaXJlY3RpdmVzL3RhYmNvbnRyb2wuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsSUFBSSxFQUF3QyxNQUFNLGVBQWUsQ0FBQztBQUV0RixPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFFOUMsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sNEJBQTRCLENBQUM7OztBQU1oRSxNQUFNLE9BQU8sbUJBQW1CO0lBR1o7SUFDUjtJQUZWLFlBQ2tCLFFBQTJCLEVBQ25DLFVBQXNCO1FBRGQsYUFBUSxHQUFSLFFBQVEsQ0FBbUI7UUFDbkMsZUFBVSxHQUFWLFVBQVUsQ0FBWTtJQUM1QixDQUFDO0lBRUwsUUFBUTtRQUNOLElBQUksQ0FBQyxRQUFRLENBQUMsU0FBUzthQUNwQixJQUFJLENBQUMsa0JBQWtCLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUFDO2FBQ3pDLFNBQVMsQ0FBQyxJQUFJLENBQUMsaUJBQWlCLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUM7SUFDbEQsQ0FBQztJQUVPLGlCQUFpQixDQUFDLEtBQXVDO1FBQy9ELE1BQU0sR0FBRyxHQUFHLEtBQUssQ0FBQyxTQUFnQixDQUFDO1FBQ25DLElBQUksS0FBSyxDQUFDLElBQUksQ0FBQyxRQUFRLEtBQUssU0FBUyxFQUFFLENBQUM7WUFDdEMsR0FBRyxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDLEdBQUcsQ0FBQyxXQUFXLENBQUMsRUFBRSxJQUFJLENBQUMsQ0FBQztRQUNoRSxDQUFDO2FBQ0ksQ0FBQztZQUNKLEdBQUcsQ0FBQyxXQUFXLEdBQUcsS0FBSyxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUM7UUFDeEMsQ0FBQztRQUNELElBQUksQ0FBQyxRQUFRLEVBQUUsQ0FBQztJQUNsQixDQUFDO0lBRU8sYUFBYSxDQUFDLEtBQWE7UUFDakMsSUFBSSxLQUFLLElBQUksSUFBSSxDQUFDLFFBQVEsQ0FBQyxRQUFRLENBQUMsTUFBTSxFQUFFLENBQUM7WUFDM0MsSUFBSSxRQUFRLEdBQUcsSUFBSSxDQUFDLFFBQVEsQ0FBQyxlQUFlLENBQUM7WUFDN0MsSUFBSSxRQUFRLEVBQUUsQ0FBQztnQkFDYixLQUFLLEdBQUcsUUFBUSxDQUFDLEtBQUssQ0FBQztZQUN6QixDQUFDO1FBQ0gsQ0FBQztRQUNELE9BQU8sS0FBSyxDQUFDO0lBQ2YsQ0FBQztJQUVPLFFBQVE7UUFFZCxVQUFVLENBQUMsR0FBRyxFQUFFO1lBQ2QsTUFBTSxPQUFPLEdBQVEsSUFBSSxDQUFDLFFBQVEsQ0FBQyxhQUFhLENBQUM7WUFDakQsTUFBTSxZQUFZLEdBQUcsT0FBTyxFQUFFLGdCQUFvQyxDQUFDO1lBQ25FLElBQUksWUFBWTtnQkFDZCxRQUFRLENBQUMsWUFBWSxDQUFDLE9BQU8sQ0FBQyxhQUE0QixDQUFDLENBQUM7UUFDaEUsQ0FBQyxFQUFFLEdBQUcsQ0FBQyxDQUFDO0lBQ1YsQ0FBQzt3R0ExQ1UsbUJBQW1COzRGQUFuQixtQkFBbUI7OzRGQUFuQixtQkFBbUI7a0JBSi9CLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLGNBQWM7b0JBQ3hCLFVBQVUsRUFBRSxJQUFJO2lCQUNqQjs7MEJBSUksSUFBSSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgSG9zdCwgT25Jbml0LCBWaWV3Q29udGFpbmVyUmVmLCBEZXN0cm95UmVmIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IFNpcmlvVGFiQ29tcG9uZW50LCBOZ3hTaXJpb0V2ZW50IH0gZnJvbSAnbmd4LXNpcmlvLWxpYic7XHJcbmltcG9ydCB7IHNldEZvY3VzIH0gZnJvbSAnLi4vdXRpbHMvZm9jdXNhYmxlJztcclxuaW1wb3J0IHsgcGF0Y2hGdW5jdGlvbiB9IGZyb20gXCIuLi91dGlscy9wYXRjaFwiO1xyXG5pbXBvcnQgeyB0YWtlVW50aWxEZXN0cm95ZWQgfSBmcm9tICdAYW5ndWxhci9jb3JlL3J4anMtaW50ZXJvcCc7XHJcblxyXG5ARGlyZWN0aXZlKHtcclxuICBzZWxlY3RvcjogJ1t0YWJDb250cm9sXScsXHJcbiAgc3RhbmRhbG9uZTogdHJ1ZVxyXG59KVxyXG5leHBvcnQgY2xhc3MgVGFiQ29udHJvbERpcmVjdGl2ZSBpbXBsZW1lbnRzIE9uSW5pdCB7XHJcbiAgXHJcbiAgY29uc3RydWN0b3IoXHJcbiAgICBASG9zdCgpIHByaXZhdGUgc2lyaW9UYWI6IFNpcmlvVGFiQ29tcG9uZW50LFxyXG4gICAgcHJpdmF0ZSBkZXN0cm95UmVmOiBEZXN0cm95UmVmXHJcbiAgKSB7IH1cclxuXHJcbiAgbmdPbkluaXQoKSB7XHJcbiAgICB0aGlzLnNpcmlvVGFiLnRhYkNoYW5nZVxyXG4gICAgICAucGlwZSh0YWtlVW50aWxEZXN0cm95ZWQodGhpcy5kZXN0cm95UmVmKSlcclxuICAgICAgLnN1YnNjcmliZSh0aGlzLkhhbmRsZUluZGV4Q2hhbmdlLmJpbmQodGhpcykpO1xyXG4gIH1cclxuXHJcbiAgcHJpdmF0ZSBIYW5kbGVJbmRleENoYW5nZShldmVudDogTmd4U2lyaW9FdmVudDxTaXJpb1RhYkNvbXBvbmVudD4pIHtcclxuICAgIGNvbnN0IHRhYiA9IGV2ZW50LmNvbXBvbmVudCBhcyBhbnk7XHJcbiAgICBpZiAoZXZlbnQuZGF0YS5uZXdJbmRleCA9PT0gdW5kZWZpbmVkKSB7XHJcbiAgICAgIHRhYi5zZXRBY3RpdmVJbmRleCh0aGlzLnZhbGlkYXRlSW5kZXgodGFiLl9zYXZlZEluZGV4KSwgdHJ1ZSk7XHJcbiAgICB9XHJcbiAgICBlbHNlIHtcclxuICAgICAgdGFiLl9zYXZlZEluZGV4ID0gZXZlbnQuZGF0YS5uZXdJbmRleDtcclxuICAgIH1cclxuICAgIHRoaXMuc2V0Rm9jdXMoKTtcclxuICB9XHJcblxyXG4gIHByaXZhdGUgdmFsaWRhdGVJbmRleChpbmRleDogbnVtYmVyKTogbnVtYmVyIHtcclxuICAgIGlmIChpbmRleCA+PSB0aGlzLnNpcmlvVGFiLnRhYkl0ZW1zLmxlbmd0aCkge1xyXG4gICAgICB2YXIgZmlyc3RUYWIgPSB0aGlzLnNpcmlvVGFiLmZpcnN0VGFiRW5hYmxlZDtcclxuICAgICAgaWYgKGZpcnN0VGFiKSB7XHJcbiAgICAgICAgaW5kZXggPSBmaXJzdFRhYi5pbmRleDtcclxuICAgICAgfVxyXG4gICAgfVxyXG4gICAgcmV0dXJuIGluZGV4O1xyXG4gIH1cclxuXHJcbiAgcHJpdmF0ZSBzZXRGb2N1cygpXHJcbiAge1xyXG4gICAgc2V0VGltZW91dCgoKSA9PiB7XHJcbiAgICAgIGNvbnN0IHRhYkl0ZW06IGFueSA9IHRoaXMuc2lyaW9UYWIuYWN0aXZlVGFiSXRlbTtcclxuICAgICAgY29uc3QgY29udGFpbmVyUmVmID0gdGFiSXRlbT8udmlld0NvbnRhaW5lclJlZiBhcyBWaWV3Q29udGFpbmVyUmVmO1xyXG4gICAgICBpZiAoY29udGFpbmVyUmVmKVxyXG4gICAgICAgIHNldEZvY3VzKGNvbnRhaW5lclJlZi5lbGVtZW50Lm5hdGl2ZUVsZW1lbnQgYXMgSFRNTEVsZW1lbnQpO1xyXG4gICAgfSwgMTAwKTtcclxuICB9XHJcbn1cclxuIl19
|