@verisoft/store 18.6.0 → 18.7.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/.eslintrc.json +43 -0
- package/README.md +52 -3
- package/jest.config.ts +22 -0
- package/ng-package.json +7 -0
- package/package.json +13 -28
- package/project.json +36 -0
- package/{index.d.ts → src/index.ts} +12 -10
- package/src/lib/binding-state/binding.actions.ts +76 -0
- package/src/lib/binding-state/binding.effects.ts +472 -0
- package/src/lib/detail-state/detail.actions.ts +89 -0
- package/src/lib/detail-state/detail.effects.ts +283 -0
- package/src/lib/detail-state/detail.models.ts +42 -0
- package/src/lib/detail-state/detail.reducer.ts +147 -0
- package/src/lib/table-state/actions.ts +93 -0
- package/src/lib/table-state/effects.ts +99 -0
- package/src/lib/table-state/models.ts +20 -0
- package/src/lib/table-state/reducers.ts +126 -0
- package/src/test-setup.ts +8 -0
- package/tsconfig.json +29 -0
- package/tsconfig.lib.json +17 -0
- package/tsconfig.lib.prod.json +9 -0
- package/tsconfig.spec.json +16 -0
- package/esm2022/index.mjs +0 -11
- package/esm2022/lib/binding-state/binding.actions.mjs +0 -35
- package/esm2022/lib/binding-state/binding.effects.mjs +0 -124
- package/esm2022/lib/detail-state/detail.actions.mjs +0 -47
- package/esm2022/lib/detail-state/detail.effects.mjs +0 -116
- package/esm2022/lib/detail-state/detail.models.mjs +0 -12
- package/esm2022/lib/detail-state/detail.reducer.mjs +0 -87
- package/esm2022/lib/table-state/actions.mjs +0 -50
- package/esm2022/lib/table-state/effects.mjs +0 -49
- package/esm2022/lib/table-state/models.mjs +0 -12
- package/esm2022/lib/table-state/reducers.mjs +0 -80
- package/esm2022/verisoft-store.mjs +0 -5
- package/fesm2022/verisoft-store.mjs +0 -602
- package/fesm2022/verisoft-store.mjs.map +0 -1
- package/lib/binding-state/binding.actions.d.ts +0 -43
- package/lib/binding-state/binding.effects.d.ts +0 -45
- package/lib/detail-state/detail.actions.d.ts +0 -52
- package/lib/detail-state/detail.effects.d.ts +0 -52
- package/lib/detail-state/detail.models.d.ts +0 -27
- package/lib/detail-state/detail.reducer.d.ts +0 -4
- package/lib/table-state/actions.d.ts +0 -48
- package/lib/table-state/effects.d.ts +0 -25
- package/lib/table-state/models.d.ts +0 -9
- package/lib/table-state/reducers.d.ts +0 -3
|
@@ -0,0 +1,126 @@
|
|
|
1
|
+
/* eslint-disable @typescript-eslint/no-explicit-any */
|
|
2
|
+
import { ActionCreator, ReducerTypes, createReducer, on } from '@ngrx/store';
|
|
3
|
+
import {
|
|
4
|
+
createGetPageTableAction,
|
|
5
|
+
createStaticFilterTableAction,
|
|
6
|
+
createDataLoadSuccessTableAction,
|
|
7
|
+
createDataLoadErrorTableAction,
|
|
8
|
+
createFilterPageTableAction,
|
|
9
|
+
createDestroyTableAction,
|
|
10
|
+
createSelectItemsTableAction,
|
|
11
|
+
createChangePageSizeTableAction,
|
|
12
|
+
createResetTableFilterAction,
|
|
13
|
+
} from './actions';
|
|
14
|
+
import { INITIAL_TABLE_STATE, TableState } from './models';
|
|
15
|
+
|
|
16
|
+
export function createTablePageReducers<
|
|
17
|
+
T = any,
|
|
18
|
+
TState extends TableState<T> = TableState<T>
|
|
19
|
+
>(
|
|
20
|
+
tableRepository: string,
|
|
21
|
+
initialState: TState = INITIAL_TABLE_STATE as unknown as TState,
|
|
22
|
+
...ons: ReducerTypes<TState, readonly ActionCreator[]>[]
|
|
23
|
+
) {
|
|
24
|
+
return createReducer(
|
|
25
|
+
initialState,
|
|
26
|
+
on(
|
|
27
|
+
createGetPageTableAction(tableRepository),
|
|
28
|
+
(state, { page, id, filter, sort }) => {
|
|
29
|
+
return {
|
|
30
|
+
...state,
|
|
31
|
+
requestParams: {
|
|
32
|
+
...state.requestParams,
|
|
33
|
+
filter: filter ?? state.requestParams.filter,
|
|
34
|
+
sort: sort ?? state.requestParams.sort,
|
|
35
|
+
id: id ?? state.requestParams.id,
|
|
36
|
+
page,
|
|
37
|
+
},
|
|
38
|
+
dataLoading: true,
|
|
39
|
+
submitted: true,
|
|
40
|
+
};
|
|
41
|
+
}
|
|
42
|
+
),
|
|
43
|
+
|
|
44
|
+
on(createStaticFilterTableAction(tableRepository), (state, { filter }) => {
|
|
45
|
+
return {
|
|
46
|
+
...state,
|
|
47
|
+
requestParams: {
|
|
48
|
+
...state.requestParams,
|
|
49
|
+
filter: {
|
|
50
|
+
...state.requestParams?.filter,
|
|
51
|
+
filter,
|
|
52
|
+
},
|
|
53
|
+
},
|
|
54
|
+
};
|
|
55
|
+
}),
|
|
56
|
+
|
|
57
|
+
on(createResetTableFilterAction(tableRepository), (state) => {
|
|
58
|
+
return {
|
|
59
|
+
...state,
|
|
60
|
+
requestParams: {
|
|
61
|
+
...state.requestParams,
|
|
62
|
+
filter: undefined,
|
|
63
|
+
page: 1
|
|
64
|
+
},
|
|
65
|
+
}
|
|
66
|
+
}),
|
|
67
|
+
|
|
68
|
+
on(
|
|
69
|
+
createDataLoadSuccessTableAction(tableRepository),
|
|
70
|
+
(state, { gPage }) => {
|
|
71
|
+
return {
|
|
72
|
+
...state,
|
|
73
|
+
gPage,
|
|
74
|
+
dataLoading: false,
|
|
75
|
+
};
|
|
76
|
+
}
|
|
77
|
+
),
|
|
78
|
+
|
|
79
|
+
on(createDataLoadErrorTableAction(tableRepository), (state, { error }) => {
|
|
80
|
+
return {
|
|
81
|
+
...state,
|
|
82
|
+
error,
|
|
83
|
+
dataLoading: false,
|
|
84
|
+
};
|
|
85
|
+
}),
|
|
86
|
+
|
|
87
|
+
on(createFilterPageTableAction(tableRepository), (state, { filter }) => {
|
|
88
|
+
return {
|
|
89
|
+
...state,
|
|
90
|
+
requestParams: {
|
|
91
|
+
...state.requestParams,
|
|
92
|
+
filter: filter,
|
|
93
|
+
page: 1,
|
|
94
|
+
},
|
|
95
|
+
dataLoading: true,
|
|
96
|
+
};
|
|
97
|
+
}),
|
|
98
|
+
|
|
99
|
+
on(createDestroyTableAction(tableRepository), () => {
|
|
100
|
+
return {
|
|
101
|
+
...(initialState as any),
|
|
102
|
+
};
|
|
103
|
+
}),
|
|
104
|
+
|
|
105
|
+
on(
|
|
106
|
+
createSelectItemsTableAction(tableRepository),
|
|
107
|
+
(state, { selectedItems }) => {
|
|
108
|
+
return {
|
|
109
|
+
...state,
|
|
110
|
+
selectedItems,
|
|
111
|
+
};
|
|
112
|
+
}
|
|
113
|
+
),
|
|
114
|
+
|
|
115
|
+
on(createChangePageSizeTableAction(tableRepository), (state, { size }) => {
|
|
116
|
+
return {
|
|
117
|
+
...state,
|
|
118
|
+
requestParams: {
|
|
119
|
+
...state.requestParams,
|
|
120
|
+
size,
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
}),
|
|
124
|
+
...ons
|
|
125
|
+
);
|
|
126
|
+
}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
// @ts-expect-error https://thymikee.github.io/jest-preset-angular/docs/getting-started/test-environment
|
|
2
|
+
globalThis.ngJest = {
|
|
3
|
+
testEnvironmentOptions: {
|
|
4
|
+
errorOnUnknownElements: true,
|
|
5
|
+
errorOnUnknownProperties: true,
|
|
6
|
+
},
|
|
7
|
+
};
|
|
8
|
+
import 'jest-preset-angular/setup-jest';
|
package/tsconfig.json
ADDED
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
{
|
|
2
|
+
"compilerOptions": {
|
|
3
|
+
"target": "es2022",
|
|
4
|
+
"useDefineForClassFields": false,
|
|
5
|
+
"forceConsistentCasingInFileNames": true,
|
|
6
|
+
"strict": true,
|
|
7
|
+
"noImplicitOverride": true,
|
|
8
|
+
"noPropertyAccessFromIndexSignature": true,
|
|
9
|
+
"noImplicitReturns": true,
|
|
10
|
+
"noFallthroughCasesInSwitch": true
|
|
11
|
+
},
|
|
12
|
+
"files": [],
|
|
13
|
+
"include": [],
|
|
14
|
+
"references": [
|
|
15
|
+
{
|
|
16
|
+
"path": "./tsconfig.lib.json"
|
|
17
|
+
},
|
|
18
|
+
{
|
|
19
|
+
"path": "./tsconfig.spec.json"
|
|
20
|
+
}
|
|
21
|
+
],
|
|
22
|
+
"extends": "../../../tsconfig.base.json",
|
|
23
|
+
"angularCompilerOptions": {
|
|
24
|
+
"enableI18nLegacyMessageIdFormat": false,
|
|
25
|
+
"strictInjectionParameters": true,
|
|
26
|
+
"strictInputAccessModifiers": true,
|
|
27
|
+
"strictTemplates": true
|
|
28
|
+
}
|
|
29
|
+
}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
{
|
|
2
|
+
"extends": "./tsconfig.json",
|
|
3
|
+
"compilerOptions": {
|
|
4
|
+
"outDir": "../../../dist/out-tsc",
|
|
5
|
+
"declaration": true,
|
|
6
|
+
"declarationMap": true,
|
|
7
|
+
"inlineSources": true,
|
|
8
|
+
"types": []
|
|
9
|
+
},
|
|
10
|
+
"exclude": [
|
|
11
|
+
"src/**/*.spec.ts",
|
|
12
|
+
"src/test-setup.ts",
|
|
13
|
+
"jest.config.ts",
|
|
14
|
+
"src/**/*.test.ts"
|
|
15
|
+
],
|
|
16
|
+
"include": ["src/**/*.ts"]
|
|
17
|
+
}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
{
|
|
2
|
+
"extends": "./tsconfig.json",
|
|
3
|
+
"compilerOptions": {
|
|
4
|
+
"outDir": "../../../dist/out-tsc",
|
|
5
|
+
"module": "commonjs",
|
|
6
|
+
"target": "es2016",
|
|
7
|
+
"types": ["jest", "node"]
|
|
8
|
+
},
|
|
9
|
+
"files": ["src/test-setup.ts"],
|
|
10
|
+
"include": [
|
|
11
|
+
"jest.config.ts",
|
|
12
|
+
"src/**/*.test.ts",
|
|
13
|
+
"src/**/*.spec.ts",
|
|
14
|
+
"src/**/*.d.ts"
|
|
15
|
+
]
|
|
16
|
+
}
|
package/esm2022/index.mjs
DELETED
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
export * from './lib/detail-state/detail.actions';
|
|
2
|
-
export * from './lib/detail-state/detail.reducer';
|
|
3
|
-
export * from './lib/detail-state/detail.effects';
|
|
4
|
-
export * from './lib/detail-state/detail.models';
|
|
5
|
-
export * from './lib/table-state/actions';
|
|
6
|
-
export * from './lib/table-state/reducers';
|
|
7
|
-
export * from './lib/table-state/effects';
|
|
8
|
-
export * from './lib/table-state/models';
|
|
9
|
-
export * from './lib/binding-state/binding.actions';
|
|
10
|
-
export * from './lib/binding-state/binding.effects';
|
|
11
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvbGlicy9zdG9yZS9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxtQ0FBbUMsQ0FBQztBQUNsRCxjQUFjLG1DQUFtQyxDQUFDO0FBQ2xELGNBQWMsbUNBQW1DLENBQUM7QUFDbEQsY0FBYyxrQ0FBa0MsQ0FBQztBQUVqRCxjQUFjLDJCQUEyQixDQUFDO0FBQzFDLGNBQWMsNEJBQTRCLENBQUM7QUFDM0MsY0FBYywyQkFBMkIsQ0FBQztBQUMxQyxjQUFjLDBCQUEwQixDQUFDO0FBRXpDLGNBQWMscUNBQXFDLENBQUM7QUFDcEQsY0FBYyxxQ0FBcUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vbGliL2RldGFpbC1zdGF0ZS9kZXRhaWwuYWN0aW9ucyc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2RldGFpbC1zdGF0ZS9kZXRhaWwucmVkdWNlcic7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2RldGFpbC1zdGF0ZS9kZXRhaWwuZWZmZWN0cyc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2RldGFpbC1zdGF0ZS9kZXRhaWwubW9kZWxzJztcclxuXHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3RhYmxlLXN0YXRlL2FjdGlvbnMnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi90YWJsZS1zdGF0ZS9yZWR1Y2Vycyc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3RhYmxlLXN0YXRlL2VmZmVjdHMnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi90YWJsZS1zdGF0ZS9tb2RlbHMnO1xyXG5cclxuZXhwb3J0ICogZnJvbSAnLi9saWIvYmluZGluZy1zdGF0ZS9iaW5kaW5nLmFjdGlvbnMnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9iaW5kaW5nLXN0YXRlL2JpbmRpbmcuZWZmZWN0cyc7XHJcbiJdfQ==
|
|
@@ -1,35 +0,0 @@
|
|
|
1
|
-
import { createAction, props } from '@ngrx/store';
|
|
2
|
-
export function createAddBindingAction(bindingsRepository) {
|
|
3
|
-
return createAction(`[${bindingsRepository}/API] Add bindings`, props());
|
|
4
|
-
}
|
|
5
|
-
export function createAddBindingsAction(bindingsRepository) {
|
|
6
|
-
return createAction(`[${bindingsRepository}/API] Add bindings`, props());
|
|
7
|
-
}
|
|
8
|
-
export function createAddBindingsFailureAction(bindingsRepository) {
|
|
9
|
-
return createAction(`[${bindingsRepository}/API] Add bindings failure`, props());
|
|
10
|
-
}
|
|
11
|
-
export function createAddBindingsSuccessAction(bindingsRepository) {
|
|
12
|
-
return createAction(`[${bindingsRepository}/API] Add bindings success`);
|
|
13
|
-
}
|
|
14
|
-
export function createEditBindingAction(bindingsRepository) {
|
|
15
|
-
return createAction(`[${bindingsRepository}/API] Edit binding`, props());
|
|
16
|
-
}
|
|
17
|
-
export function createEditBindingFailureAction(bindingsRepository) {
|
|
18
|
-
return createAction(`[${bindingsRepository}/API] Edit binding failure`, props());
|
|
19
|
-
}
|
|
20
|
-
export function createEditBindingSuccessAction(bindingsRepository) {
|
|
21
|
-
return createAction(`[${bindingsRepository}/API] Edit binding success`);
|
|
22
|
-
}
|
|
23
|
-
export function createDeleteBindingAction(bindingsRepository) {
|
|
24
|
-
return createAction(`[${bindingsRepository}/API] Delete binding`, props());
|
|
25
|
-
}
|
|
26
|
-
export function createDeleteBindingsAction(bindingsRepository) {
|
|
27
|
-
return createAction(`[${bindingsRepository}/API] Delete bindings`, props());
|
|
28
|
-
}
|
|
29
|
-
export function createDeleteBindingsFailureAction(bindingsRepository) {
|
|
30
|
-
return createAction(`[${bindingsRepository}/API] Delete bindings failure`, props());
|
|
31
|
-
}
|
|
32
|
-
export function createDeleteBindingsSuccessAction(bindingsRepository) {
|
|
33
|
-
return createAction(`[${bindingsRepository}/API] Delete bindings success`);
|
|
34
|
-
}
|
|
35
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmluZGluZy5hY3Rpb25zLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vc3JjL2xpYnMvc3RvcmUvc3JjL2xpYi9iaW5kaW5nLXN0YXRlL2JpbmRpbmcuYWN0aW9ucy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBRSxNQUFNLGFBQWEsQ0FBQztBQUVsRCxNQUFNLFVBQVUsc0JBQXNCLENBQVUsa0JBQTBCO0lBQ3hFLE9BQU8sWUFBWSxDQUNqQixJQUFJLGtCQUFrQixvQkFBb0IsRUFDMUMsS0FBSyxFQUF3QixDQUM5QixDQUFDO0FBQ0osQ0FBQztBQUVELE1BQU0sVUFBVSx1QkFBdUIsQ0FBVSxrQkFBMEI7SUFDekUsT0FBTyxZQUFZLENBQ2pCLElBQUksa0JBQWtCLG9CQUFvQixFQUMxQyxLQUFLLEVBQTJCLENBQ2pDLENBQUM7QUFDSixDQUFDO0FBRUQsTUFBTSxVQUFVLDhCQUE4QixDQUFDLGtCQUEwQjtJQUN2RSxPQUFPLFlBQVksQ0FDakIsSUFBSSxrQkFBa0IsNEJBQTRCLEVBQ2xELEtBQUssRUFBa0IsQ0FDeEIsQ0FBQztBQUNKLENBQUM7QUFFRCxNQUFNLFVBQVUsOEJBQThCLENBQUMsa0JBQTBCO0lBQ3ZFLE9BQU8sWUFBWSxDQUNqQixJQUFJLGtCQUFrQiw0QkFBNEIsQ0FDbkQsQ0FBQztBQUNKLENBQUM7QUFFRCxNQUFNLFVBQVUsdUJBQXVCLENBQVEsa0JBQTBCO0lBQ3ZFLE9BQU8sWUFBWSxDQUNqQixJQUFJLGtCQUFrQixvQkFBb0IsRUFDMUMsS0FBSyxFQUFzQixDQUM1QixDQUFDO0FBQ0osQ0FBQztBQUVELE1BQU0sVUFBVSw4QkFBOEIsQ0FBQyxrQkFBMEI7SUFDdkUsT0FBTyxZQUFZLENBQ2pCLElBQUksa0JBQWtCLDRCQUE0QixFQUNsRCxLQUFLLEVBQWtCLENBQ3hCLENBQUM7QUFDSixDQUFDO0FBRUQsTUFBTSxVQUFVLDhCQUE4QixDQUFDLGtCQUEwQjtJQUN2RSxPQUFPLFlBQVksQ0FDakIsSUFBSSxrQkFBa0IsNEJBQTRCLENBQ25ELENBQUM7QUFDSixDQUFDO0FBRUQsTUFBTSxVQUFVLHlCQUF5QixDQUFDLGtCQUEwQjtJQUNsRSxPQUFPLFlBQVksQ0FDakIsSUFBSSxrQkFBa0Isc0JBQXNCLEVBQzVDLEtBQUssRUFBMkIsQ0FDakMsQ0FBQztBQUNKLENBQUM7QUFFRCxNQUFNLFVBQVUsMEJBQTBCLENBQUMsa0JBQTBCO0lBQ25FLE9BQU8sWUFBWSxDQUNqQixJQUFJLGtCQUFrQix1QkFBdUIsRUFDN0MsS0FBSyxFQUE0QixDQUNsQyxDQUFDO0FBQ0osQ0FBQztBQUVELE1BQU0sVUFBVSxpQ0FBaUMsQ0FBQyxrQkFBMEI7SUFDMUUsT0FBTyxZQUFZLENBQ2pCLElBQUksa0JBQWtCLCtCQUErQixFQUNyRCxLQUFLLEVBQWtCLENBQ3hCLENBQUM7QUFDSixDQUFDO0FBRUQsTUFBTSxVQUFVLGlDQUFpQyxDQUFDLGtCQUEwQjtJQUMxRSxPQUFPLFlBQVksQ0FDakIsSUFBSSxrQkFBa0IsK0JBQStCLENBQ3RELENBQUM7QUFDSixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3JlYXRlQWN0aW9uLCBwcm9wcyB9IGZyb20gJ0BuZ3J4L3N0b3JlJztcclxuXHJcbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVBZGRCaW5kaW5nQWN0aW9uPFRDcmVhdGU+KGJpbmRpbmdzUmVwb3NpdG9yeTogc3RyaW5nKSB7XHJcbiAgcmV0dXJuIGNyZWF0ZUFjdGlvbihcclxuICAgIGBbJHtiaW5kaW5nc1JlcG9zaXRvcnl9L0FQSV0gQWRkIGJpbmRpbmdzYCxcclxuICAgIHByb3BzPHsgYmluZGluZzogVENyZWF0ZSB9PigpXHJcbiAgKTtcclxufVxyXG5cclxuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZUFkZEJpbmRpbmdzQWN0aW9uPFRDcmVhdGU+KGJpbmRpbmdzUmVwb3NpdG9yeTogc3RyaW5nKSB7XHJcbiAgcmV0dXJuIGNyZWF0ZUFjdGlvbihcclxuICAgIGBbJHtiaW5kaW5nc1JlcG9zaXRvcnl9L0FQSV0gQWRkIGJpbmRpbmdzYCxcclxuICAgIHByb3BzPHsgYmluZGluZ3M6IFRDcmVhdGVbXSB9PigpXHJcbiAgKTtcclxufVxyXG5cclxuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZUFkZEJpbmRpbmdzRmFpbHVyZUFjdGlvbihiaW5kaW5nc1JlcG9zaXRvcnk6IHN0cmluZykge1xyXG4gIHJldHVybiBjcmVhdGVBY3Rpb24oXHJcbiAgICBgWyR7YmluZGluZ3NSZXBvc2l0b3J5fS9BUEldIEFkZCBiaW5kaW5ncyBmYWlsdXJlYCxcclxuICAgIHByb3BzPHsgZXJyb3I6IGFueSB9PigpXHJcbiAgKTtcclxufVxyXG5cclxuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZUFkZEJpbmRpbmdzU3VjY2Vzc0FjdGlvbihiaW5kaW5nc1JlcG9zaXRvcnk6IHN0cmluZykge1xyXG4gIHJldHVybiBjcmVhdGVBY3Rpb24oXHJcbiAgICBgWyR7YmluZGluZ3NSZXBvc2l0b3J5fS9BUEldIEFkZCBiaW5kaW5ncyBzdWNjZXNzYFxyXG4gICk7XHJcbn1cclxuXHJcbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVFZGl0QmluZGluZ0FjdGlvbjxURWRpdD4oYmluZGluZ3NSZXBvc2l0b3J5OiBzdHJpbmcpIHtcclxuICByZXR1cm4gY3JlYXRlQWN0aW9uKFxyXG4gICAgYFske2JpbmRpbmdzUmVwb3NpdG9yeX0vQVBJXSBFZGl0IGJpbmRpbmdgLFxyXG4gICAgcHJvcHM8eyBiaW5kaW5nOiBURWRpdCB9PigpXHJcbiAgKTtcclxufVxyXG5cclxuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZUVkaXRCaW5kaW5nRmFpbHVyZUFjdGlvbihiaW5kaW5nc1JlcG9zaXRvcnk6IHN0cmluZykge1xyXG4gIHJldHVybiBjcmVhdGVBY3Rpb24oXHJcbiAgICBgWyR7YmluZGluZ3NSZXBvc2l0b3J5fS9BUEldIEVkaXQgYmluZGluZyBmYWlsdXJlYCxcclxuICAgIHByb3BzPHsgZXJyb3I6IGFueSB9PigpXHJcbiAgKTtcclxufVxyXG5cclxuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZUVkaXRCaW5kaW5nU3VjY2Vzc0FjdGlvbihiaW5kaW5nc1JlcG9zaXRvcnk6IHN0cmluZykge1xyXG4gIHJldHVybiBjcmVhdGVBY3Rpb24oXHJcbiAgICBgWyR7YmluZGluZ3NSZXBvc2l0b3J5fS9BUEldIEVkaXQgYmluZGluZyBzdWNjZXNzYFxyXG4gICk7XHJcbn1cclxuXHJcbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVEZWxldGVCaW5kaW5nQWN0aW9uKGJpbmRpbmdzUmVwb3NpdG9yeTogc3RyaW5nKSB7XHJcbiAgcmV0dXJuIGNyZWF0ZUFjdGlvbihcclxuICAgIGBbJHtiaW5kaW5nc1JlcG9zaXRvcnl9L0FQSV0gRGVsZXRlIGJpbmRpbmdgLFxyXG4gICAgcHJvcHM8eyBpZDogbnVtYmVyIHwgc3RyaW5nIH0+KClcclxuICApO1xyXG59XHJcblxyXG5leHBvcnQgZnVuY3Rpb24gY3JlYXRlRGVsZXRlQmluZGluZ3NBY3Rpb24oYmluZGluZ3NSZXBvc2l0b3J5OiBzdHJpbmcpIHtcclxuICByZXR1cm4gY3JlYXRlQWN0aW9uKFxyXG4gICAgYFske2JpbmRpbmdzUmVwb3NpdG9yeX0vQVBJXSBEZWxldGUgYmluZGluZ3NgLFxyXG4gICAgcHJvcHM8eyBiaW5kaW5nSWRzOiBudW1iZXJbXSB9PigpXHJcbiAgKTtcclxufVxyXG5cclxuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZURlbGV0ZUJpbmRpbmdzRmFpbHVyZUFjdGlvbihiaW5kaW5nc1JlcG9zaXRvcnk6IHN0cmluZykge1xyXG4gIHJldHVybiBjcmVhdGVBY3Rpb24oXHJcbiAgICBgWyR7YmluZGluZ3NSZXBvc2l0b3J5fS9BUEldIERlbGV0ZSBiaW5kaW5ncyBmYWlsdXJlYCxcclxuICAgIHByb3BzPHsgZXJyb3I6IGFueSB9PigpXHJcbiAgKTtcclxufVxyXG5cclxuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZURlbGV0ZUJpbmRpbmdzU3VjY2Vzc0FjdGlvbihiaW5kaW5nc1JlcG9zaXRvcnk6IHN0cmluZykge1xyXG4gIHJldHVybiBjcmVhdGVBY3Rpb24oXHJcbiAgICBgWyR7YmluZGluZ3NSZXBvc2l0b3J5fS9BUEldIERlbGV0ZSBiaW5kaW5ncyBzdWNjZXNzYFxyXG4gICk7XHJcbn1cclxuXHJcbiJdfQ==
|
|
@@ -1,124 +0,0 @@
|
|
|
1
|
-
import { createEffect, ofType } from '@ngrx/effects';
|
|
2
|
-
import { catchError, map, of, switchMap, tap, withLatestFrom, } from 'rxjs';
|
|
3
|
-
import { createAddBindingAction, createAddBindingsAction, createAddBindingsFailureAction, createAddBindingsSuccessAction, createDeleteBindingAction, createDeleteBindingsAction, createDeleteBindingsFailureAction, createDeleteBindingsSuccessAction, createEditBindingAction, createEditBindingFailureAction, createEditBindingSuccessAction, } from './binding.actions';
|
|
4
|
-
export function createSingleBindingEffectsWithEdit(bindingsRepository, actions$, detail$, bindingSingularName, bindingPluralName, addFunction, editFunction, deleteFunction, snackbar, translateService, tableService, overrideDetailWithBinding = false) {
|
|
5
|
-
const addEffect = createAddBindingEffect(bindingsRepository, actions$, detail$, bindingPluralName, addFunction, snackbar, translateService);
|
|
6
|
-
const editEffect = createEditBindingEffect(bindingsRepository, actions$, detail$, bindingSingularName, editFunction, snackbar, translateService, overrideDetailWithBinding);
|
|
7
|
-
const deleteEffect = createDeleteBindingEffect(bindingsRepository, actions$, detail$, bindingPluralName, deleteFunction, snackbar, translateService);
|
|
8
|
-
const modifiedSuccessEffect = createBindingModifiedSuccessEffect(bindingsRepository, actions$, tableService);
|
|
9
|
-
return { addEffect, editEffect, deleteEffect, modifiedSuccessEffect };
|
|
10
|
-
}
|
|
11
|
-
export function createBindingsEffectsWithEdit(bindingsRepository, actions$, detail$, bindingSingularName, bindingPluralName, addFunction, editFunction, deleteFunction, snackbar, translateService, tableService, overrideDetailWithBinding = false) {
|
|
12
|
-
const addEffect = createAddBindingsEffect(bindingsRepository, actions$, detail$, bindingPluralName, addFunction, snackbar, translateService);
|
|
13
|
-
const editEffect = createEditBindingEffect(bindingsRepository, actions$, detail$, bindingSingularName, editFunction, snackbar, translateService, overrideDetailWithBinding);
|
|
14
|
-
const deleteEffect = createDeleteBindingsEffect(bindingsRepository, actions$, detail$, bindingPluralName, deleteFunction, snackbar, translateService);
|
|
15
|
-
const modifiedSuccessEffect = createBindingModifiedSuccessEffect(bindingsRepository, actions$, tableService);
|
|
16
|
-
return { addEffect, editEffect, deleteEffect, modifiedSuccessEffect };
|
|
17
|
-
}
|
|
18
|
-
export function createBindingsEffects(bindingsRepository, actions$, detail$, bindingPluralName, addFunction, deleteFunction, snackbar, translateService, tableService) {
|
|
19
|
-
const addEffect = createAddBindingsEffect(bindingsRepository, actions$, detail$, bindingPluralName, addFunction, snackbar, translateService);
|
|
20
|
-
const deleteEffect = createDeleteBindingsEffect(bindingsRepository, actions$, detail$, bindingPluralName, deleteFunction, snackbar, translateService);
|
|
21
|
-
const modifiedSuccessEffect = createBindingModifiedSuccessEffect(bindingsRepository, actions$, tableService);
|
|
22
|
-
return { addEffect, deleteEffect, modifiedSuccessEffect };
|
|
23
|
-
}
|
|
24
|
-
function createAddBindingEffect(bindingsRepository, actions$, detail$, bindingPluralName, addFunction, snackbar, translateService) {
|
|
25
|
-
return createEffect(() => actions$.pipe(ofType(createAddBindingAction(bindingsRepository)), withLatestFrom(detail$), switchMap(([{ binding }, detail]) => {
|
|
26
|
-
const translatedPluralName = translateService.instant(bindingPluralName);
|
|
27
|
-
const successMessage = `${translateService.instant('BINDINGS_EFFECTS.SUCCESS_ADD')} ${translatedPluralName}!`;
|
|
28
|
-
const failureMessage = `${translateService.instant('BINDINGS_EFFECTS.FAILURE_ADD')} ${translatedPluralName}!`;
|
|
29
|
-
return addFunction(binding).pipe(map(() => {
|
|
30
|
-
snackbar.showSuccess(successMessage);
|
|
31
|
-
return createAddBindingsSuccessAction(bindingsRepository)();
|
|
32
|
-
}), catchError((error) => {
|
|
33
|
-
snackbar.showError(failureMessage);
|
|
34
|
-
return of(createAddBindingsFailureAction(bindingsRepository)({ error }));
|
|
35
|
-
}));
|
|
36
|
-
})));
|
|
37
|
-
}
|
|
38
|
-
function createAddBindingsEffect(bindingsRepository, actions$, detail$, bindingPluralName, addFunction, snackbar, translateService) {
|
|
39
|
-
return createEffect(() => actions$.pipe(ofType(createAddBindingsAction(bindingsRepository)), withLatestFrom(detail$), switchMap(([{ bindings }, detail]) => {
|
|
40
|
-
const translatedPluralName = translateService.instant(bindingPluralName);
|
|
41
|
-
const successMessage = `${translateService.instant('BINDINGS_EFFECTS.SUCCESS_ADD')} ${translatedPluralName}!`;
|
|
42
|
-
const failureMessage = `${translateService.instant('BINDINGS_EFFECTS.FAILURE_ADD')} ${translatedPluralName}!`;
|
|
43
|
-
if (!detail?.id) {
|
|
44
|
-
snackbar.showError(failureMessage);
|
|
45
|
-
return of(createAddBindingsFailureAction(bindingsRepository)({
|
|
46
|
-
error: failureMessage,
|
|
47
|
-
}));
|
|
48
|
-
}
|
|
49
|
-
return addFunction(bindings, detail.id).pipe(map(() => {
|
|
50
|
-
snackbar.showSuccess(successMessage);
|
|
51
|
-
return createAddBindingsSuccessAction(bindingsRepository)();
|
|
52
|
-
}), catchError((error) => {
|
|
53
|
-
snackbar.showError(failureMessage);
|
|
54
|
-
return of(createAddBindingsFailureAction(bindingsRepository)({ error }));
|
|
55
|
-
}));
|
|
56
|
-
})));
|
|
57
|
-
}
|
|
58
|
-
function createEditBindingEffect(bindingsRepository, actions$, detail$, bindingSingularName, editFunction, snackbar, translateService, overrideDetailWithBinding = false) {
|
|
59
|
-
return createEffect(() => actions$.pipe(ofType(createEditBindingAction(bindingsRepository)), withLatestFrom(detail$), switchMap(([{ binding }, detail]) => {
|
|
60
|
-
const translatedPluralName = translateService.instant(bindingSingularName);
|
|
61
|
-
const successMessage = `${translateService.instant('BINDINGS_EFFECTS.SUCCESS_EDIT')} ${translatedPluralName}!`;
|
|
62
|
-
const failureMessage = `${translateService.instant('BINDINGS_EFFECTS.FAILURE_EDIT')} ${translatedPluralName}!`;
|
|
63
|
-
const id = overrideDetailWithBinding ? binding?.id : detail?.id;
|
|
64
|
-
if (!id) {
|
|
65
|
-
snackbar.showError(failureMessage);
|
|
66
|
-
return of(createEditBindingFailureAction(bindingsRepository)({
|
|
67
|
-
error: failureMessage,
|
|
68
|
-
}));
|
|
69
|
-
}
|
|
70
|
-
return editFunction(binding, id).pipe(map(() => {
|
|
71
|
-
snackbar.showSuccess(successMessage);
|
|
72
|
-
return createEditBindingSuccessAction(bindingsRepository)();
|
|
73
|
-
}), catchError((error) => {
|
|
74
|
-
snackbar.showError(failureMessage);
|
|
75
|
-
return of(createEditBindingFailureAction(bindingsRepository)({ error }));
|
|
76
|
-
}));
|
|
77
|
-
})));
|
|
78
|
-
}
|
|
79
|
-
function createDeleteBindingEffect(bindingsRepository, actions$, detail$, bindingPluralName, deleteFunction, snackbar, translateService) {
|
|
80
|
-
return createEffect(() => actions$.pipe(ofType(createDeleteBindingAction(bindingsRepository)), withLatestFrom(detail$), switchMap(([{ id }, detail]) => {
|
|
81
|
-
const translatedPluralName = translateService.instant(bindingPluralName);
|
|
82
|
-
const successMessage = `${translateService.instant('BINDINGS_EFFECTS.SUCCESS_DELETE')} ${translatedPluralName}!`;
|
|
83
|
-
const failureMessage = `${translateService.instant('BINDINGS_EFFECTS.FAILURE_DELETE')} ${translatedPluralName}!`;
|
|
84
|
-
if (!id && !detail?.id) {
|
|
85
|
-
snackbar.showError(failureMessage);
|
|
86
|
-
return of(createDeleteBindingsFailureAction(bindingsRepository)({
|
|
87
|
-
error: failureMessage,
|
|
88
|
-
}));
|
|
89
|
-
}
|
|
90
|
-
return deleteFunction(id, id ?? detail?.id).pipe(map(() => {
|
|
91
|
-
snackbar.showSuccess(successMessage);
|
|
92
|
-
return createDeleteBindingsSuccessAction(bindingsRepository)();
|
|
93
|
-
}), catchError((error) => {
|
|
94
|
-
snackbar.showError(failureMessage);
|
|
95
|
-
return of(createDeleteBindingsFailureAction(bindingsRepository)({ error }));
|
|
96
|
-
}));
|
|
97
|
-
})));
|
|
98
|
-
}
|
|
99
|
-
function createDeleteBindingsEffect(bindingsRepository, actions$, detail$, bindingPluralName, deleteFunction, snackbar, translateService) {
|
|
100
|
-
return createEffect(() => actions$.pipe(ofType(createDeleteBindingsAction(bindingsRepository)), withLatestFrom(detail$), switchMap(([{ bindingIds }, detail]) => {
|
|
101
|
-
const translatedPluralName = translateService.instant(bindingPluralName);
|
|
102
|
-
const successMessage = `${translateService.instant('BINDINGS_EFFECTS.SUCCESS_DELETE')} ${translatedPluralName}!`;
|
|
103
|
-
const failureMessage = `${translateService.instant('BINDINGS_EFFECTS.FAILURE_DELETE')} ${translatedPluralName}!`;
|
|
104
|
-
if (!detail?.id) {
|
|
105
|
-
snackbar.showError(failureMessage);
|
|
106
|
-
return of(createDeleteBindingsFailureAction(bindingsRepository)({
|
|
107
|
-
error: failureMessage,
|
|
108
|
-
}));
|
|
109
|
-
}
|
|
110
|
-
return deleteFunction(bindingIds, detail.id).pipe(map(() => {
|
|
111
|
-
snackbar.showSuccess(successMessage);
|
|
112
|
-
return createDeleteBindingsSuccessAction(bindingsRepository)();
|
|
113
|
-
}), catchError((error) => {
|
|
114
|
-
snackbar.showError(failureMessage);
|
|
115
|
-
return of(createDeleteBindingsFailureAction(bindingsRepository)({ error }));
|
|
116
|
-
}));
|
|
117
|
-
})));
|
|
118
|
-
}
|
|
119
|
-
function createBindingModifiedSuccessEffect(bindingsRepository, actions$, tableService) {
|
|
120
|
-
return createEffect(() => actions$.pipe(ofType(createAddBindingsSuccessAction(bindingsRepository), createEditBindingSuccessAction(bindingsRepository), createDeleteBindingsSuccessAction(bindingsRepository)), tap(() => {
|
|
121
|
-
tableService.forceReload();
|
|
122
|
-
})), { dispatch: false });
|
|
123
|
-
}
|
|
124
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"binding.effects.js","sourceRoot":"","sources":["../../../../../../../src/libs/store/src/lib/binding-state/binding.effects.ts"],"names":[],"mappings":"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","sourcesContent":["import { Actions, createEffect, ofType } from '@ngrx/effects';\r\nimport {\r\n  catchError,\r\n  map,\r\n  Observable,\r\n  of,\r\n  switchMap,\r\n  tap,\r\n  withLatestFrom,\r\n} from 'rxjs';\r\nimport {\r\n  createAddBindingAction,\r\n  createAddBindingsAction,\r\n  createAddBindingsFailureAction,\r\n  createAddBindingsSuccessAction,\r\n  createDeleteBindingAction,\r\n  createDeleteBindingsAction,\r\n  createDeleteBindingsFailureAction,\r\n  createDeleteBindingsSuccessAction,\r\n  createEditBindingAction,\r\n  createEditBindingFailureAction,\r\n  createEditBindingSuccessAction,\r\n} from './binding.actions';\r\n\r\nexport function createSingleBindingEffectsWithEdit<\r\n  T extends { id: number | string },\r\n  TCreate,\r\n  TEdit extends { id?: number | string }\r\n>(\r\n  bindingsRepository: string,\r\n  actions$: Actions,\r\n  detail$: Observable<T | undefined>,\r\n  bindingSingularName: string,\r\n  bindingPluralName: string,\r\n  addFunction: (\r\n    bindings: TCreate,\r\n  ) => Observable<any>,\r\n  editFunction: (binding: TEdit, detailId: number | string) => Observable<any>,\r\n  deleteFunction: (\r\n    bindingIds: string | number,\r\n    detailId: number | string\r\n  ) => Observable<any>,\r\n  snackbar: any,\r\n  translateService: any,\r\n  tableService: any,\r\n  overrideDetailWithBinding = false,\r\n) {\r\n  const addEffect = createAddBindingEffect(\r\n    bindingsRepository,\r\n    actions$,\r\n    detail$,\r\n    bindingPluralName,\r\n    addFunction,\r\n    snackbar,\r\n    translateService,\r\n  );\r\n\r\n  const editEffect = createEditBindingEffect(\r\n    bindingsRepository,\r\n    actions$,\r\n    detail$,\r\n    bindingSingularName,\r\n    editFunction,\r\n    snackbar,\r\n    translateService,\r\n    overrideDetailWithBinding\r\n  );\r\n\r\n  const deleteEffect = createDeleteBindingEffect(\r\n    bindingsRepository,\r\n    actions$,\r\n    detail$,\r\n    bindingPluralName,\r\n    deleteFunction,\r\n    snackbar,\r\n    translateService\r\n  );\r\n\r\n  const modifiedSuccessEffect = createBindingModifiedSuccessEffect(\r\n    bindingsRepository,\r\n    actions$,\r\n    tableService\r\n  );\r\n\r\n  return { addEffect, editEffect, deleteEffect, modifiedSuccessEffect };\r\n}\r\n\r\nexport function createBindingsEffectsWithEdit<\r\n  T extends { id: number | string },\r\n  TCreate,\r\n  TEdit extends { id?: number | string }\r\n>(\r\n  bindingsRepository: string,\r\n  actions$: Actions,\r\n  detail$: Observable<T | undefined>,\r\n  bindingSingularName: string,\r\n  bindingPluralName: string,\r\n  addFunction: (\r\n    bindings: TCreate[],\r\n    detailId: number | string\r\n  ) => Observable<any>,\r\n  editFunction: (binding: TEdit, detailId: number | string) => Observable<any>,\r\n  deleteFunction: (\r\n    bindingIds: number[],\r\n    detailId: number | string\r\n  ) => Observable<any>,\r\n  snackbar: any,\r\n  translateService: any,\r\n  tableService: any,\r\n  overrideDetailWithBinding = false,\r\n) {\r\n  const addEffect = createAddBindingsEffect(\r\n    bindingsRepository,\r\n    actions$,\r\n    detail$,\r\n    bindingPluralName,\r\n    addFunction,\r\n    snackbar,\r\n    translateService\r\n  );\r\n\r\n  const editEffect = createEditBindingEffect(\r\n    bindingsRepository,\r\n    actions$,\r\n    detail$,\r\n    bindingSingularName,\r\n    editFunction,\r\n    snackbar,\r\n    translateService,\r\n    overrideDetailWithBinding\r\n  );\r\n\r\n  const deleteEffect = createDeleteBindingsEffect(\r\n    bindingsRepository,\r\n    actions$,\r\n    detail$,\r\n    bindingPluralName,\r\n    deleteFunction,\r\n    snackbar,\r\n    translateService\r\n  );\r\n\r\n  const modifiedSuccessEffect = createBindingModifiedSuccessEffect(\r\n    bindingsRepository,\r\n    actions$,\r\n    tableService\r\n  );\r\n\r\n  return { addEffect, editEffect, deleteEffect, modifiedSuccessEffect };\r\n}\r\n\r\nexport function createBindingsEffects<\r\n  T extends { id: number | string },\r\n  TCreate\r\n>(\r\n  bindingsRepository: string,\r\n  actions$: Actions,\r\n  detail$: Observable<T | undefined>,\r\n  bindingPluralName: string,\r\n  addFunction: (\r\n    bindings: TCreate[],\r\n    detailId: number | string\r\n  ) => Observable<any>,\r\n  deleteFunction: (\r\n    bindingIds: number[],\r\n    detailId: number | string\r\n  ) => Observable<any>,\r\n  snackbar: any,\r\n  translateService: any,\r\n  tableService: any\r\n) {\r\n  const addEffect = createAddBindingsEffect(\r\n    bindingsRepository,\r\n    actions$,\r\n    detail$,\r\n    bindingPluralName,\r\n    addFunction,\r\n    snackbar,\r\n    translateService\r\n  );\r\n\r\n  const deleteEffect = createDeleteBindingsEffect(\r\n    bindingsRepository,\r\n    actions$,\r\n    detail$,\r\n    bindingPluralName,\r\n    deleteFunction,\r\n    snackbar,\r\n    translateService\r\n  );\r\n\r\n  const modifiedSuccessEffect = createBindingModifiedSuccessEffect(\r\n    bindingsRepository,\r\n    actions$,\r\n    tableService\r\n  );\r\n\r\n  return { addEffect, deleteEffect, modifiedSuccessEffect };\r\n}\r\n\r\nfunction createAddBindingEffect<T extends { id: number | string }, TCreate>(\r\n  bindingsRepository: string,\r\n  actions$: Actions,\r\n  detail$: Observable<T | undefined>,\r\n  bindingPluralName: string,\r\n  addFunction: (\r\n    bindings: TCreate,\r\n  ) => Observable<any>,\r\n  snackbar: any,\r\n  translateService: any,\r\n) {\r\n  return createEffect(() =>\r\n    actions$.pipe(\r\n      ofType(createAddBindingAction<TCreate>(bindingsRepository)),\r\n      withLatestFrom(detail$),\r\n      switchMap(([{ binding }, detail]) => {\r\n        const translatedPluralName =\r\n          translateService.instant(bindingPluralName);\r\n        const successMessage = `${translateService.instant(\r\n          'BINDINGS_EFFECTS.SUCCESS_ADD'\r\n        )} ${translatedPluralName}!`;\r\n        const failureMessage = `${translateService.instant(\r\n          'BINDINGS_EFFECTS.FAILURE_ADD'\r\n        )} ${translatedPluralName}!`;\r\n\r\n        return addFunction(binding).pipe(\r\n          map(() => {\r\n            snackbar.showSuccess(successMessage);\r\n            return createAddBindingsSuccessAction(bindingsRepository)();\r\n          }),\r\n          catchError((error) => {\r\n            snackbar.showError(failureMessage);\r\n            return of(\r\n              createAddBindingsFailureAction(bindingsRepository)({ error })\r\n            );\r\n          })\r\n        );\r\n      })\r\n    )\r\n  );\r\n}\r\n\r\nfunction createAddBindingsEffect<T extends { id: number | string }, TCreate>(\r\n  bindingsRepository: string,\r\n  actions$: Actions,\r\n  detail$: Observable<T | undefined>,\r\n  bindingPluralName: string,\r\n  addFunction: (\r\n    bindings: TCreate[],\r\n    detailId: number | string\r\n  ) => Observable<any>,\r\n  snackbar: any,\r\n  translateService: any\r\n) {\r\n  return createEffect(() =>\r\n    actions$.pipe(\r\n      ofType(createAddBindingsAction<TCreate>(bindingsRepository)),\r\n      withLatestFrom(detail$),\r\n      switchMap(([{ bindings }, detail]) => {\r\n        const translatedPluralName =\r\n          translateService.instant(bindingPluralName);\r\n        const successMessage = `${translateService.instant(\r\n          'BINDINGS_EFFECTS.SUCCESS_ADD'\r\n        )} ${translatedPluralName}!`;\r\n        const failureMessage = `${translateService.instant(\r\n          'BINDINGS_EFFECTS.FAILURE_ADD'\r\n        )} ${translatedPluralName}!`;\r\n\r\n        if (!detail?.id) {\r\n          snackbar.showError(failureMessage);\r\n          return of(\r\n            createAddBindingsFailureAction(bindingsRepository)({\r\n              error: failureMessage,\r\n            })\r\n          );\r\n        }\r\n\r\n        return addFunction(bindings, detail.id).pipe(\r\n          map(() => {\r\n            snackbar.showSuccess(successMessage);\r\n            return createAddBindingsSuccessAction(bindingsRepository)();\r\n          }),\r\n          catchError((error) => {\r\n            snackbar.showError(failureMessage);\r\n            return of(\r\n              createAddBindingsFailureAction(bindingsRepository)({ error })\r\n            );\r\n          })\r\n        );\r\n      })\r\n    )\r\n  );\r\n}\r\n\r\nfunction createEditBindingEffect<\r\n  T extends { id: number | string },\r\n  TEdit extends { id?: number | string }\r\n>(\r\n  bindingsRepository: string,\r\n  actions$: Actions,\r\n  detail$: Observable<T | undefined>,\r\n  bindingSingularName: string,\r\n  editFunction: (binding: TEdit, detailId: number | string) => Observable<any>,\r\n  snackbar: any,\r\n  translateService: any,\r\n  overrideDetailWithBinding = false,\r\n) {\r\n  return createEffect(() =>\r\n    actions$.pipe(\r\n      ofType(createEditBindingAction<TEdit>(bindingsRepository)),\r\n      withLatestFrom(detail$),\r\n      switchMap(([{ binding }, detail]) => {\r\n        const translatedPluralName =\r\n          translateService.instant(bindingSingularName);\r\n        const successMessage = `${translateService.instant(\r\n          'BINDINGS_EFFECTS.SUCCESS_EDIT'\r\n        )} ${translatedPluralName}!`;\r\n        const failureMessage = `${translateService.instant(\r\n          'BINDINGS_EFFECTS.FAILURE_EDIT'\r\n        )} ${translatedPluralName}!`;\r\n\r\n        const id = overrideDetailWithBinding ? binding?.id : detail?.id;\r\n        if (!id) {\r\n          snackbar.showError(failureMessage);\r\n          return of(\r\n            createEditBindingFailureAction(bindingsRepository)({\r\n              error: failureMessage,\r\n            })\r\n          );\r\n        }\r\n\r\n        return editFunction(binding, id).pipe(\r\n          map(() => {\r\n            snackbar.showSuccess(successMessage);\r\n            return createEditBindingSuccessAction(bindingsRepository)();\r\n          }),\r\n          catchError((error) => {\r\n            snackbar.showError(failureMessage);\r\n            return of(\r\n              createEditBindingFailureAction(bindingsRepository)({ error })\r\n            );\r\n          })\r\n        );\r\n      })\r\n    )\r\n  );\r\n}\r\n\r\nfunction createDeleteBindingEffect<T extends { id: number | string }>(\r\n  bindingsRepository: string,\r\n  actions$: Actions,\r\n  detail$: Observable<T | undefined>,\r\n  bindingPluralName: string,\r\n  deleteFunction: (\r\n    bindingIds: string | number,\r\n    detailId: string | number\r\n  ) => Observable<any>,\r\n  snackbar: any,\r\n  translateService: any\r\n) {\r\n  return createEffect(() =>\r\n    actions$.pipe(\r\n      ofType(createDeleteBindingAction(bindingsRepository)),\r\n      withLatestFrom(detail$),\r\n      switchMap(([{ id }, detail]) => {\r\n        const translatedPluralName =\r\n          translateService.instant(bindingPluralName);\r\n        const successMessage = `${translateService.instant(\r\n          'BINDINGS_EFFECTS.SUCCESS_DELETE'\r\n        )} ${translatedPluralName}!`;\r\n        const failureMessage = `${translateService.instant(\r\n          'BINDINGS_EFFECTS.FAILURE_DELETE'\r\n        )} ${translatedPluralName}!`;\r\n\r\n        if (!id && !detail?.id) {\r\n          snackbar.showError(failureMessage);\r\n          return of(\r\n            createDeleteBindingsFailureAction(bindingsRepository)({\r\n              error: failureMessage,\r\n            })\r\n          );\r\n        }\r\n\r\n        return deleteFunction(id, id ?? detail?.id).pipe(\r\n          map(() => {\r\n            snackbar.showSuccess(successMessage);\r\n            return createDeleteBindingsSuccessAction(bindingsRepository)();\r\n          }),\r\n          catchError((error) => {\r\n            snackbar.showError(failureMessage);\r\n            return of(\r\n              createDeleteBindingsFailureAction(bindingsRepository)({ error })\r\n            );\r\n          })\r\n        );\r\n      })\r\n    )\r\n  );\r\n}\r\n\r\nfunction createDeleteBindingsEffect<T extends { id: number | string }>(\r\n  bindingsRepository: string,\r\n  actions$: Actions,\r\n  detail$: Observable<T | undefined>,\r\n  bindingPluralName: string,\r\n  deleteFunction: (\r\n    bindingIds: number[],\r\n    detailId: string | number\r\n  ) => Observable<any>,\r\n  snackbar: any,\r\n  translateService: any\r\n) {\r\n  return createEffect(() =>\r\n    actions$.pipe(\r\n      ofType(createDeleteBindingsAction(bindingsRepository)),\r\n      withLatestFrom(detail$),\r\n      switchMap(([{ bindingIds }, detail]) => {\r\n        const translatedPluralName =\r\n          translateService.instant(bindingPluralName);\r\n        const successMessage = `${translateService.instant(\r\n          'BINDINGS_EFFECTS.SUCCESS_DELETE'\r\n        )} ${translatedPluralName}!`;\r\n        const failureMessage = `${translateService.instant(\r\n          'BINDINGS_EFFECTS.FAILURE_DELETE'\r\n        )} ${translatedPluralName}!`;\r\n\r\n        if (!detail?.id) {\r\n          snackbar.showError(failureMessage);\r\n          return of(\r\n            createDeleteBindingsFailureAction(bindingsRepository)({\r\n              error: failureMessage,\r\n            })\r\n          );\r\n        }\r\n\r\n        return deleteFunction(bindingIds, detail.id).pipe(\r\n          map(() => {\r\n            snackbar.showSuccess(successMessage);\r\n            return createDeleteBindingsSuccessAction(bindingsRepository)();\r\n          }),\r\n          catchError((error) => {\r\n            snackbar.showError(failureMessage);\r\n            return of(\r\n              createDeleteBindingsFailureAction(bindingsRepository)({ error })\r\n            );\r\n          })\r\n        );\r\n      })\r\n    )\r\n  );\r\n}\r\n\r\nfunction createBindingModifiedSuccessEffect(\r\n  bindingsRepository: string,\r\n  actions$: Actions,\r\n  tableService: any\r\n) {\r\n  return createEffect(\r\n    () =>\r\n      actions$.pipe(\r\n        ofType(\r\n          createAddBindingsSuccessAction(bindingsRepository),\r\n          createEditBindingSuccessAction(bindingsRepository),\r\n          createDeleteBindingsSuccessAction(bindingsRepository)\r\n        ),\r\n        tap(() => {\r\n          tableService.forceReload();\r\n        })\r\n      ),\r\n    { dispatch: false }\r\n  );\r\n}\r\n"]}
|
|
@@ -1,47 +0,0 @@
|
|
|
1
|
-
import { createAction, props } from '@ngrx/store';
|
|
2
|
-
export function createInitDetailAction(detailsRepository) {
|
|
3
|
-
return createAction(`[${detailsRepository} Page] Init`, props());
|
|
4
|
-
}
|
|
5
|
-
export function createInitNewDetailAction(detailsRepository) {
|
|
6
|
-
return createAction(`[${detailsRepository} Page] Init New`);
|
|
7
|
-
}
|
|
8
|
-
export function createLoadDetailSuccessAction(detailsRepository) {
|
|
9
|
-
return createAction(`[${detailsRepository}/API] Load ${detailsRepository} Success`, props());
|
|
10
|
-
}
|
|
11
|
-
export function createLoadDetailFailureAction(detailsRepository) {
|
|
12
|
-
return createAction(`[${detailsRepository}/API] Load ${detailsRepository} Failure`, props());
|
|
13
|
-
}
|
|
14
|
-
export function createUpdateDetailAction(detailsRepository) {
|
|
15
|
-
return createAction(`[${detailsRepository}/API] Update ${detailsRepository}`, props());
|
|
16
|
-
}
|
|
17
|
-
export function createUpdateDetailSetErrorsAction(detailsRepository) {
|
|
18
|
-
return createAction(`[${detailsRepository}/API] Update Validation Errors ${detailsRepository}`, props());
|
|
19
|
-
}
|
|
20
|
-
export function createUpdateFormStateAction(detailsRepository) {
|
|
21
|
-
return createAction(`[${detailsRepository}/API] Update Form State`, props());
|
|
22
|
-
}
|
|
23
|
-
export function createSaveDetailAction(detailsRepository) {
|
|
24
|
-
return createAction(`[${detailsRepository}/API] Save Detail `);
|
|
25
|
-
}
|
|
26
|
-
export function createSaveDetailSuccessAction(detailsRepository) {
|
|
27
|
-
return createAction(`[${detailsRepository}/API] Save Detail Success`, props());
|
|
28
|
-
}
|
|
29
|
-
export function createSaveDetailFailureAction(detailsRepository) {
|
|
30
|
-
return createAction(`[${detailsRepository}/API] Save Detail Failure`, props());
|
|
31
|
-
}
|
|
32
|
-
export function createUpdateSaveDetailAction(detailsRepository) {
|
|
33
|
-
return createAction(`[${detailsRepository}/API] Update Detail `);
|
|
34
|
-
}
|
|
35
|
-
export function createResetStateAction(detailsRepository) {
|
|
36
|
-
return createAction(`[${detailsRepository}/API] Reset State`);
|
|
37
|
-
}
|
|
38
|
-
export function createDeleteDetailAction(detailsRepository) {
|
|
39
|
-
return createAction(`[${detailsRepository}/API] Delete Detail`);
|
|
40
|
-
}
|
|
41
|
-
export function createDeleteDetailSuccessAction(detailsRepository) {
|
|
42
|
-
return createAction(`[${detailsRepository}/API] Delete Detail Success`);
|
|
43
|
-
}
|
|
44
|
-
export function createDeleteDetailFailureAction(detailsRepository) {
|
|
45
|
-
return createAction(`[${detailsRepository}/API] Delete Detail Failure`, props());
|
|
46
|
-
}
|
|
47
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGV0YWlsLmFjdGlvbnMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9zcmMvbGlicy9zdG9yZS9zcmMvbGliL2RldGFpbC1zdGF0ZS9kZXRhaWwuYWN0aW9ucy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBRSxNQUFNLGFBQWEsQ0FBQztBQUdsRCxNQUFNLFVBQVUsc0JBQXNCLENBQUMsaUJBQXlCO0lBQzlELE9BQU8sWUFBWSxDQUNqQixJQUFJLGlCQUFpQixhQUFhLEVBQ2xDLEtBQUssRUFBcUQsQ0FDM0QsQ0FBQztBQUNKLENBQUM7QUFFRCxNQUFNLFVBQVUseUJBQXlCLENBQUMsaUJBQXlCO0lBQ2pFLE9BQU8sWUFBWSxDQUFDLElBQUksaUJBQWlCLGlCQUFpQixDQUFDLENBQUM7QUFDOUQsQ0FBQztBQUVELE1BQU0sVUFBVSw2QkFBNkIsQ0FBSSxpQkFBeUI7SUFDeEUsT0FBTyxZQUFZLENBQ2pCLElBQUksaUJBQWlCLGNBQWMsaUJBQWlCLFVBQVUsRUFDOUQsS0FBSyxFQUFlLENBQ3JCLENBQUM7QUFDSixDQUFDO0FBRUQsTUFBTSxVQUFVLDZCQUE2QixDQUFDLGlCQUF5QjtJQUNyRSxPQUFPLFlBQVksQ0FDakIsSUFBSSxpQkFBaUIsY0FBYyxpQkFBaUIsVUFBVSxFQUM5RCxLQUFLLEVBQWtCLENBQ3hCLENBQUM7QUFDSixDQUFDO0FBRUQsTUFBTSxVQUFVLHdCQUF3QixDQUFJLGlCQUF5QjtJQUNuRSxPQUFPLFlBQVksQ0FDakIsSUFBSSxpQkFBaUIsZ0JBQWdCLGlCQUFpQixFQUFFLEVBQ3hELEtBQUssRUFBZSxDQUNyQixDQUFDO0FBQ0osQ0FBQztBQUVELE1BQU0sVUFBVSxpQ0FBaUMsQ0FBQyxpQkFBeUI7SUFDekUsT0FBTyxZQUFZLENBQ2pCLElBQUksaUJBQWlCLGtDQUFrQyxpQkFBaUIsRUFBRSxFQUMxRSxLQUFLLEVBQWtCLENBQ3hCLENBQUE7QUFDSCxDQUFDO0FBRUQsTUFBTSxVQUFVLDJCQUEyQixDQUFDLGlCQUF5QjtJQUNuRSxPQUFPLFlBQVksQ0FDakIsSUFBSSxpQkFBaUIseUJBQXlCLEVBQzlDLEtBQUssRUFBNEIsQ0FDbEMsQ0FBQztBQUNKLENBQUM7QUFFRCxNQUFNLFVBQVUsc0JBQXNCLENBQUMsaUJBQXlCO0lBQzlELE9BQU8sWUFBWSxDQUFDLElBQUksaUJBQWlCLG9CQUFvQixDQUFDLENBQUM7QUFDakUsQ0FBQztBQUVELE1BQU0sVUFBVSw2QkFBNkIsQ0FBSSxpQkFBeUI7SUFDeEUsT0FBTyxZQUFZLENBQ2pCLElBQUksaUJBQWlCLDJCQUEyQixFQUNoRCxLQUFLLEVBQWUsQ0FDckIsQ0FBQztBQUNKLENBQUM7QUFFRCxNQUFNLFVBQVUsNkJBQTZCLENBQUMsaUJBQXlCO0lBQ3JFLE9BQU8sWUFBWSxDQUNqQixJQUFJLGlCQUFpQiwyQkFBMkIsRUFDaEQsS0FBSyxFQUFrQixDQUN4QixDQUFDO0FBQ0osQ0FBQztBQUVELE1BQU0sVUFBVSw0QkFBNEIsQ0FBQyxpQkFBeUI7SUFDcEUsT0FBTyxZQUFZLENBQUMsSUFBSSxpQkFBaUIsc0JBQXNCLENBQUMsQ0FBQztBQUNuRSxDQUFDO0FBRUQsTUFBTSxVQUFVLHNCQUFzQixDQUFDLGlCQUF5QjtJQUM5RCxPQUFPLFlBQVksQ0FBQyxJQUFJLGlCQUFpQixtQkFBbUIsQ0FBQyxDQUFDO0FBQ2hFLENBQUM7QUFFRCxNQUFNLFVBQVUsd0JBQXdCLENBQUMsaUJBQXlCO0lBQ2hFLE9BQU8sWUFBWSxDQUFDLElBQUksaUJBQWlCLHFCQUFxQixDQUFDLENBQUM7QUFDbEUsQ0FBQztBQUVELE1BQU0sVUFBVSwrQkFBK0IsQ0FBQyxpQkFBeUI7SUFDdkUsT0FBTyxZQUFZLENBQUMsSUFBSSxpQkFBaUIsNkJBQTZCLENBQUMsQ0FBQztBQUMxRSxDQUFDO0FBRUQsTUFBTSxVQUFVLCtCQUErQixDQUFDLGlCQUF5QjtJQUN2RSxPQUFPLFlBQVksQ0FDakIsSUFBSSxpQkFBaUIsNkJBQTZCLEVBQ2xELEtBQUssRUFBa0IsQ0FDeEIsQ0FBQztBQUNKLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBjcmVhdGVBY3Rpb24sIHByb3BzIH0gZnJvbSAnQG5ncngvc3RvcmUnO1xyXG5pbXBvcnQgeyBGb3JtU3RhdGUgfSBmcm9tICcuL2RldGFpbC5tb2RlbHMnO1xyXG5cclxuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZUluaXREZXRhaWxBY3Rpb24oZGV0YWlsc1JlcG9zaXRvcnk6IHN0cmluZykge1xyXG4gIHJldHVybiBjcmVhdGVBY3Rpb24oXHJcbiAgICBgWyR7ZGV0YWlsc1JlcG9zaXRvcnl9IFBhZ2VdIEluaXRgLFxyXG4gICAgcHJvcHM8eyBvYmo6IHN0cmluZyB8IG51bGwgfCBudW1iZXIgfCB1bmRlZmluZWQgfCBhbnkgfT4oKVxyXG4gICk7XHJcbn1cclxuXHJcbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVJbml0TmV3RGV0YWlsQWN0aW9uKGRldGFpbHNSZXBvc2l0b3J5OiBzdHJpbmcpIHtcclxuICByZXR1cm4gY3JlYXRlQWN0aW9uKGBbJHtkZXRhaWxzUmVwb3NpdG9yeX0gUGFnZV0gSW5pdCBOZXdgKTtcclxufVxyXG5cclxuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZUxvYWREZXRhaWxTdWNjZXNzQWN0aW9uPFQ+KGRldGFpbHNSZXBvc2l0b3J5OiBzdHJpbmcpIHtcclxuICByZXR1cm4gY3JlYXRlQWN0aW9uKFxyXG4gICAgYFske2RldGFpbHNSZXBvc2l0b3J5fS9BUEldIExvYWQgJHtkZXRhaWxzUmVwb3NpdG9yeX0gU3VjY2Vzc2AsXHJcbiAgICBwcm9wczx7IGl0ZW06IFQgfT4oKVxyXG4gICk7XHJcbn1cclxuXHJcbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVMb2FkRGV0YWlsRmFpbHVyZUFjdGlvbihkZXRhaWxzUmVwb3NpdG9yeTogc3RyaW5nKSB7XHJcbiAgcmV0dXJuIGNyZWF0ZUFjdGlvbihcclxuICAgIGBbJHtkZXRhaWxzUmVwb3NpdG9yeX0vQVBJXSBMb2FkICR7ZGV0YWlsc1JlcG9zaXRvcnl9IEZhaWx1cmVgLFxyXG4gICAgcHJvcHM8eyBlcnJvcjogYW55IH0+KClcclxuICApO1xyXG59XHJcblxyXG5leHBvcnQgZnVuY3Rpb24gY3JlYXRlVXBkYXRlRGV0YWlsQWN0aW9uPFQ+KGRldGFpbHNSZXBvc2l0b3J5OiBzdHJpbmcpIHtcclxuICByZXR1cm4gY3JlYXRlQWN0aW9uKFxyXG4gICAgYFske2RldGFpbHNSZXBvc2l0b3J5fS9BUEldIFVwZGF0ZSAke2RldGFpbHNSZXBvc2l0b3J5fWAsXHJcbiAgICBwcm9wczx7IGl0ZW06IFQgfT4oKVxyXG4gICk7XHJcbn1cclxuXHJcbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVVcGRhdGVEZXRhaWxTZXRFcnJvcnNBY3Rpb24oZGV0YWlsc1JlcG9zaXRvcnk6IHN0cmluZykge1xyXG4gIHJldHVybiBjcmVhdGVBY3Rpb24oXHJcbiAgICBgWyR7ZGV0YWlsc1JlcG9zaXRvcnl9L0FQSV0gVXBkYXRlIFZhbGlkYXRpb24gRXJyb3JzICR7ZGV0YWlsc1JlcG9zaXRvcnl9YCxcclxuICAgIHByb3BzPHsgZXJyb3I6IGFueSB9PigpXHJcbiAgKVxyXG59XHJcblxyXG5leHBvcnQgZnVuY3Rpb24gY3JlYXRlVXBkYXRlRm9ybVN0YXRlQWN0aW9uKGRldGFpbHNSZXBvc2l0b3J5OiBzdHJpbmcpIHtcclxuICByZXR1cm4gY3JlYXRlQWN0aW9uKFxyXG4gICAgYFske2RldGFpbHNSZXBvc2l0b3J5fS9BUEldIFVwZGF0ZSBGb3JtIFN0YXRlYCxcclxuICAgIHByb3BzPHsgZm9ybVN0YXRlOiBGb3JtU3RhdGUgfT4oKVxyXG4gICk7XHJcbn1cclxuXHJcbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVTYXZlRGV0YWlsQWN0aW9uKGRldGFpbHNSZXBvc2l0b3J5OiBzdHJpbmcpIHtcclxuICByZXR1cm4gY3JlYXRlQWN0aW9uKGBbJHtkZXRhaWxzUmVwb3NpdG9yeX0vQVBJXSBTYXZlIERldGFpbCBgKTtcclxufVxyXG5cclxuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZVNhdmVEZXRhaWxTdWNjZXNzQWN0aW9uPFQ+KGRldGFpbHNSZXBvc2l0b3J5OiBzdHJpbmcpIHtcclxuICByZXR1cm4gY3JlYXRlQWN0aW9uKFxyXG4gICAgYFske2RldGFpbHNSZXBvc2l0b3J5fS9BUEldIFNhdmUgRGV0YWlsIFN1Y2Nlc3NgLFxyXG4gICAgcHJvcHM8eyBpdGVtOiBUIH0+KClcclxuICApO1xyXG59XHJcblxyXG5leHBvcnQgZnVuY3Rpb24gY3JlYXRlU2F2ZURldGFpbEZhaWx1cmVBY3Rpb24oZGV0YWlsc1JlcG9zaXRvcnk6IHN0cmluZykge1xyXG4gIHJldHVybiBjcmVhdGVBY3Rpb24oXHJcbiAgICBgWyR7ZGV0YWlsc1JlcG9zaXRvcnl9L0FQSV0gU2F2ZSBEZXRhaWwgRmFpbHVyZWAsXHJcbiAgICBwcm9wczx7IGVycm9yOiBhbnkgfT4oKVxyXG4gICk7XHJcbn1cclxuXHJcbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVVcGRhdGVTYXZlRGV0YWlsQWN0aW9uKGRldGFpbHNSZXBvc2l0b3J5OiBzdHJpbmcpIHtcclxuICByZXR1cm4gY3JlYXRlQWN0aW9uKGBbJHtkZXRhaWxzUmVwb3NpdG9yeX0vQVBJXSBVcGRhdGUgRGV0YWlsIGApO1xyXG59XHJcblxyXG5leHBvcnQgZnVuY3Rpb24gY3JlYXRlUmVzZXRTdGF0ZUFjdGlvbihkZXRhaWxzUmVwb3NpdG9yeTogc3RyaW5nKSB7XHJcbiAgcmV0dXJuIGNyZWF0ZUFjdGlvbihgWyR7ZGV0YWlsc1JlcG9zaXRvcnl9L0FQSV0gUmVzZXQgU3RhdGVgKTtcclxufVxyXG5cclxuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZURlbGV0ZURldGFpbEFjdGlvbihkZXRhaWxzUmVwb3NpdG9yeTogc3RyaW5nKSB7XHJcbiAgcmV0dXJuIGNyZWF0ZUFjdGlvbihgWyR7ZGV0YWlsc1JlcG9zaXRvcnl9L0FQSV0gRGVsZXRlIERldGFpbGApO1xyXG59XHJcblxyXG5leHBvcnQgZnVuY3Rpb24gY3JlYXRlRGVsZXRlRGV0YWlsU3VjY2Vzc0FjdGlvbihkZXRhaWxzUmVwb3NpdG9yeTogc3RyaW5nKSB7XHJcbiAgcmV0dXJuIGNyZWF0ZUFjdGlvbihgWyR7ZGV0YWlsc1JlcG9zaXRvcnl9L0FQSV0gRGVsZXRlIERldGFpbCBTdWNjZXNzYCk7XHJcbn1cclxuXHJcbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVEZWxldGVEZXRhaWxGYWlsdXJlQWN0aW9uKGRldGFpbHNSZXBvc2l0b3J5OiBzdHJpbmcpIHtcclxuICByZXR1cm4gY3JlYXRlQWN0aW9uKFxyXG4gICAgYFske2RldGFpbHNSZXBvc2l0b3J5fS9BUEldIERlbGV0ZSBEZXRhaWwgRmFpbHVyZWAsXHJcbiAgICBwcm9wczx7IGVycm9yOiBhbnkgfT4oKVxyXG4gICk7XHJcbn1cclxuIl19
|