@wemake4u/form-player-se 1.0.44 → 1.0.46
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/builtIn/builtIn.mjs +6 -2
- package/esm2022/lib/builtIn/cache.json +30 -0
- package/esm2022/lib/builtIn/form.json +25 -0
- package/esm2022/lib/builtIn/function.json +28 -0
- package/esm2022/lib/builtIn/nav.json +37 -0
- package/esm2022/lib/controls/control.mjs +8 -3
- package/esm2022/lib/controls/factory.mjs +33 -33
- package/esm2022/lib/dialog/dialog.component.mjs +5 -4
- package/esm2022/lib/directives/collapse.directive.mjs +22 -2
- package/esm2022/lib/directives/dropdown.directive.mjs +38 -8
- package/esm2022/lib/directives/grid.directive.mjs +10 -2
- package/esm2022/lib/directives/required.directive.mjs +2 -2
- package/esm2022/lib/directives/tabcontrol.directive.mjs +17 -5
- package/esm2022/lib/dynamic-fields/dynamic-fields.component.mjs +23 -9
- package/esm2022/lib/dynamic-form/dynamic-form.component.mjs +27 -7
- package/esm2022/lib/services/builder.service.mjs +9 -1
- package/esm2022/lib/services/compute.service.mjs +2 -2
- package/esm2022/lib/services/dialog.service.mjs +1 -1
- package/esm2022/lib/services/disable.service.mjs +2 -2
- package/esm2022/lib/services/feel.service.mjs +25 -7
- package/esm2022/lib/services/form.service.mjs +17 -1
- package/esm2022/lib/services/function.service.mjs +13 -2
- package/esm2022/lib/services/programmability.service.mjs +28 -14
- package/esm2022/lib/services/validation.service.mjs +89 -54
- package/esm2022/lib/services/weak.service.mjs +4 -3
- package/esm2022/lib/utils/cacheControl.mjs +24 -0
- package/esm2022/lib/utils/deepEqual.mjs +27 -19
- package/esm2022/lib/utils/groupByRow.mjs +2 -1
- package/esm2022/lib/utils/observable.mjs +7 -3
- package/esm2022/public-api.mjs +33 -1
- package/fesm2022/wemake4u-form-player-se.mjs +545 -169
- package/fesm2022/wemake4u-form-player-se.mjs.map +1 -1
- package/lib/controls/factory.d.ts +1 -1
- package/lib/directives/collapse.directive.d.ts +6 -1
- package/lib/directives/dropdown.directive.d.ts +5 -2
- package/lib/directives/tabcontrol.directive.d.ts +3 -1
- package/lib/dynamic-fields/dynamic-fields.component.d.ts +5 -3
- package/lib/dynamic-form/dynamic-form.component.d.ts +3 -0
- package/lib/services/dialog.service.d.ts +10 -3
- package/lib/services/feel.service.d.ts +7 -2
- package/lib/services/form.service.d.ts +3 -0
- package/lib/services/function.service.d.ts +2 -0
- package/lib/services/programmability.service.d.ts +3 -3
- package/lib/services/validation.service.d.ts +5 -2
- package/lib/services/weak.service.d.ts +1 -1
- package/lib/utils/cacheControl.d.ts +9 -0
- package/lib/utils/deepEqual.d.ts +3 -1
- package/lib/utils/groupByRow.d.ts +1 -0
- package/lib/utils/observable.d.ts +1 -1
- package/package.json +3 -3
- package/public-api.d.ts +32 -0
- package/esm2022/lib/utils/patch.mjs +0 -17
- package/lib/utils/patch.d.ts +0 -1
|
@@ -7,6 +7,8 @@ import registerFn from './register.json';
|
|
|
7
7
|
import formFn from './form.json';
|
|
8
8
|
import feelFn from './feel.json';
|
|
9
9
|
import jsonFn from './json.json';
|
|
10
|
+
import cacheFn from './cache.json';
|
|
11
|
+
import navFn from './nav.json';
|
|
10
12
|
export const builtIn = [
|
|
11
13
|
consoleFn,
|
|
12
14
|
formGroupFn,
|
|
@@ -19,8 +21,10 @@ export const builtIn = [
|
|
|
19
21
|
...registerFn,
|
|
20
22
|
...formFn,
|
|
21
23
|
...feelFn,
|
|
22
|
-
...jsonFn
|
|
24
|
+
...jsonFn,
|
|
25
|
+
...cacheFn,
|
|
26
|
+
...navFn
|
|
23
27
|
]
|
|
24
28
|
}
|
|
25
29
|
];
|
|
26
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
30
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnVpbHRJbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1zaXJpby9zcmMvbGliL2J1aWx0SW4vYnVpbHRJbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLFNBQVMsTUFBTSxnQkFBZ0IsQ0FBQztBQUN2QyxPQUFPLFdBQVcsTUFBTSxrQkFBa0IsQ0FBQztBQUMzQyxPQUFPLFFBQVEsTUFBTSxlQUFlLENBQUM7QUFDckMsT0FBTyxVQUFVLE1BQU0saUJBQWlCLENBQUM7QUFDekMsT0FBTyxXQUFXLE1BQU0sa0JBQWtCLENBQUM7QUFDM0MsT0FBTyxVQUFVLE1BQU0saUJBQWlCLENBQUM7QUFDekMsT0FBTyxNQUFNLE1BQU0sYUFBYSxDQUFDO0FBQ2pDLE9BQU8sTUFBTSxNQUFNLGFBQWEsQ0FBQztBQUNqQyxPQUFPLE1BQU0sTUFBTSxhQUFhLENBQUM7QUFDakMsT0FBTyxPQUFPLE1BQU0sY0FBYyxDQUFDO0FBQ25DLE9BQU8sS0FBSyxNQUFNLFlBQVksQ0FBQztBQUUvQixNQUFNLENBQUMsTUFBTSxPQUFPLEdBQUc7SUFDckIsU0FBUztJQUNULFdBQVc7SUFDWDtRQUNFLE1BQU0sRUFBRSxJQUFJO1FBQ1osU0FBUyxFQUFFO1lBQ1QsR0FBRyxRQUFRO1lBQ1gsR0FBRyxVQUFVO1lBQ2IsR0FBRyxXQUFXO1lBQ2QsR0FBRyxVQUFVO1lBQ2IsR0FBRyxNQUFNO1lBQ1QsR0FBRyxNQUFNO1lBQ1QsR0FBRyxNQUFNO1lBQ1QsR0FBRyxPQUFPO1lBQ1YsR0FBRyxLQUFLO1NBQ1Q7S0FDRjtDQUNGLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgY29uc29sZUZuIGZyb20gJy4vY29uc29sZS5qc29uJztcclxuaW1wb3J0IGZvcm1Hcm91cEZuIGZyb20gJy4vZm9ybUdyb3VwLmpzb24nO1xyXG5pbXBvcnQgZGlhbG9nRm4gZnJvbSAnLi9kaWFsb2cuanNvbic7XHJcbmltcG9ydCBmdW5jdGlvbkZuIGZyb20gJy4vZnVuY3Rpb24uanNvbic7XHJcbmltcG9ydCBmb3JtYXR0ZXJGbiBmcm9tICcuL2Zvcm1hdHRlci5qc29uJztcclxuaW1wb3J0IHJlZ2lzdGVyRm4gZnJvbSAnLi9yZWdpc3Rlci5qc29uJztcclxuaW1wb3J0IGZvcm1GbiBmcm9tICcuL2Zvcm0uanNvbic7XHJcbmltcG9ydCBmZWVsRm4gZnJvbSAnLi9mZWVsLmpzb24nO1xyXG5pbXBvcnQganNvbkZuIGZyb20gJy4vanNvbi5qc29uJztcclxuaW1wb3J0IGNhY2hlRm4gZnJvbSAnLi9jYWNoZS5qc29uJztcclxuaW1wb3J0IG5hdkZuIGZyb20gJy4vbmF2Lmpzb24nO1xyXG5cclxuZXhwb3J0IGNvbnN0IGJ1aWx0SW4gPSBbXHJcbiAgY29uc29sZUZuLFxyXG4gIGZvcm1Hcm91cEZuLFxyXG4gIHtcclxuICAgIFwibmFtZVwiOiBcImZuXCIsXHJcbiAgICBcImVudHJpZXNcIjogW1xyXG4gICAgICAuLi5kaWFsb2dGbixcclxuICAgICAgLi4uZnVuY3Rpb25GbixcclxuICAgICAgLi4uZm9ybWF0dGVyRm4sXHJcbiAgICAgIC4uLnJlZ2lzdGVyRm4sXHJcbiAgICAgIC4uLmZvcm1GbixcclxuICAgICAgLi4uZmVlbEZuLFxyXG4gICAgICAuLi5qc29uRm4sXHJcbiAgICAgIC4uLmNhY2hlRm4sXHJcbiAgICAgIC4uLm5hdkZuXHJcbiAgICBdXHJcbiAgfVxyXG5dO1xyXG4iXX0=
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
[
|
|
2
|
+
{
|
|
3
|
+
"name": "volatile",
|
|
4
|
+
"type": "function",
|
|
5
|
+
"detail": "Marks an expression as volatile and returns its value",
|
|
6
|
+
"info": "Returns the provided value unchanged and marks the current evaluation as volatile.\n\n---\n\n### Function signature\n\n```\nvolatile<T>(value: T): T\n```\n\n---\n\n### Notes\n\nThe value is returned unchanged.\n\nWhen this function is invoked, the current evaluation is marked as volatile so it can be excluded from caching.\n\n---\n\n### Examples\n\n```ts\nvolatile(user.name)\nvolatile(now())\n```",
|
|
7
|
+
"params": [
|
|
8
|
+
{
|
|
9
|
+
"name": "value",
|
|
10
|
+
"type": "any"
|
|
11
|
+
}
|
|
12
|
+
]
|
|
13
|
+
},
|
|
14
|
+
{
|
|
15
|
+
"name": "cacheFor",
|
|
16
|
+
"type": "function",
|
|
17
|
+
"detail": "Caches a value for a specified duration",
|
|
18
|
+
"info": "Returns the provided value unchanged and marks the current evaluation to be cached for the specified time-to-live (TTL) in milliseconds.\n\n---\n\n### Function signature\n\n```\ncacheFor<T>(value: T, ttl: number): T\n```\n\n---\n\n### Notes\n\nThe value is returned unchanged.\n\nWhen this function is invoked, the current evaluation result should be cached for the given TTL (in milliseconds).\n\nIf multiple cache directives are used, the last one applied should take precedence.\n\n---\n\n### Examples\n\n```ts\ncacheFor(now(), 1000)\n```",
|
|
19
|
+
"params": [
|
|
20
|
+
{
|
|
21
|
+
"name": "value",
|
|
22
|
+
"type": "any"
|
|
23
|
+
},
|
|
24
|
+
{
|
|
25
|
+
"name": "ttl",
|
|
26
|
+
"type": "number"
|
|
27
|
+
}
|
|
28
|
+
]
|
|
29
|
+
}
|
|
30
|
+
]
|
|
@@ -37,6 +37,31 @@
|
|
|
37
37
|
}
|
|
38
38
|
]
|
|
39
39
|
},
|
|
40
|
+
{
|
|
41
|
+
"name": "reset",
|
|
42
|
+
"type": "function",
|
|
43
|
+
"detail": "Resets a control by path",
|
|
44
|
+
"info": "Resets the control identified by the given path.\n\n---\n\n### Function signature\n\n```\nreset(path: Path): void\n```\n\n---\n\n### Examples\n\n```feel\nreset(\"user.name\")\n\nreset([\"items\", 0, \"price\"])\n```",
|
|
45
|
+
"params": [
|
|
46
|
+
{
|
|
47
|
+
"name": "path",
|
|
48
|
+
"type": "Path"
|
|
49
|
+
}
|
|
50
|
+
]
|
|
51
|
+
},
|
|
52
|
+
{
|
|
53
|
+
"name": "resetAll",
|
|
54
|
+
"type": "function",
|
|
55
|
+
"detail": "Resets multiple controls by path",
|
|
56
|
+
"info": "Resets all controls identified by the given paths.\n\n---\n\n### Function signature\n\n```\nresetAll(...paths: string[]): void\n```\n\n---\n\n### Examples\n\n```feel\nresetAll(\"user.name\", \"address.city\")\n\nresetAll(\"items.0.price\", \"items.1.price\")\n```",
|
|
57
|
+
"params": [
|
|
58
|
+
{
|
|
59
|
+
"name": "paths",
|
|
60
|
+
"type": "string[]",
|
|
61
|
+
"rest": true
|
|
62
|
+
}
|
|
63
|
+
]
|
|
64
|
+
},
|
|
40
65
|
{
|
|
41
66
|
"name": "status",
|
|
42
67
|
"type": "function",
|
|
@@ -27,6 +27,34 @@
|
|
|
27
27
|
}
|
|
28
28
|
]
|
|
29
29
|
},
|
|
30
|
+
{
|
|
31
|
+
"name": "asObservable",
|
|
32
|
+
"type": "function",
|
|
33
|
+
"detail": "Creates an observable that emits a single value",
|
|
34
|
+
"info": "Creates an observable that emits exactly one value and then completes.\n\n---\n\n### Function signature\n\n```\nofOnce<T>(value: T): Observable<T>\n```\n\n---\n\n### Notes\n\nThis is equivalent to `of(value)` but guarantees a single emission, avoiding ambiguity with multiple values.\n\n---\n\n### Examples\n\n```ts\nofOnce(42)\n\nexecuteOnce(ofOnce(\"hello\"), {\n invoke: value => console.log(value)\n});\n```",
|
|
35
|
+
"params": [
|
|
36
|
+
{
|
|
37
|
+
"name": "value",
|
|
38
|
+
"type": "any"
|
|
39
|
+
}
|
|
40
|
+
]
|
|
41
|
+
},
|
|
42
|
+
{
|
|
43
|
+
"name": "setTimeout",
|
|
44
|
+
"type": "function",
|
|
45
|
+
"detail": "Executes a callback after a delay",
|
|
46
|
+
"info": "Executes a callback once after the specified delay in milliseconds.\n\n---\n\n### Function signature\n\n```\nsetTimeout(callback: any, delay: number): void\n```\n\n---\n\n### Notes\n\nThe callback is invoked only once after the given delay.\n\n---\n\n### Examples\n\n```ts\nsetTimeout({\n invoke: () => console.log('done')\n}, 1000);\n```",
|
|
47
|
+
"params": [
|
|
48
|
+
{
|
|
49
|
+
"name": "callback",
|
|
50
|
+
"type": "any"
|
|
51
|
+
},
|
|
52
|
+
{
|
|
53
|
+
"name": "delay",
|
|
54
|
+
"type": "number"
|
|
55
|
+
}
|
|
56
|
+
]
|
|
57
|
+
},
|
|
30
58
|
{
|
|
31
59
|
"name": "openForm",
|
|
32
60
|
"type": "function",
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
[
|
|
2
|
+
{
|
|
3
|
+
"name": "canPrevious",
|
|
4
|
+
"type": "function",
|
|
5
|
+
"detail": "Checks if navigation to the previous step is allowed",
|
|
6
|
+
"info": "Returns true if it is possible to navigate to the previous step, otherwise false.\n\n---\n\n### Function signature\n\n```\ncanPrevious(): boolean\n```\n\n---\n\n### Notes\n\nThis function does not perform navigation, it only evaluates whether moving to the previous step is allowed.\n\n---\n\n### Examples\n\n```ts\ncanPrevious()\n```",
|
|
7
|
+
"params": []
|
|
8
|
+
},
|
|
9
|
+
{
|
|
10
|
+
"name": "goPrevious",
|
|
11
|
+
"type": "function",
|
|
12
|
+
"detail": "Navigates to the previous step",
|
|
13
|
+
"info": "Navigates to the previous step if allowed.\n\n---\n\n### Function signature\n\n```\ngoPrevious(): void\n```\n\n---\n\n### Notes\n\nThis function performs navigation to the previous step. It is recommended to check `canPrevious()` before invoking.\n\n---\n\n### Examples\n\n```ts\ngoPrevious()\n```",
|
|
14
|
+
"params": []
|
|
15
|
+
},
|
|
16
|
+
{
|
|
17
|
+
"name": "canNext",
|
|
18
|
+
"type": "function",
|
|
19
|
+
"detail": "Checks if navigation to the next step is allowed",
|
|
20
|
+
"info": "Returns true if it is possible to navigate to the next step, otherwise false.\n\n---\n\n### Function signature\n\n```\ncanNext(): boolean\n```\n\n---\n\n### Notes\n\nThis function does not perform navigation, it only evaluates whether moving to the next step is allowed.\n\n---\n\n### Examples\n\n```ts\ncanNext()\n```",
|
|
21
|
+
"params": []
|
|
22
|
+
},
|
|
23
|
+
{
|
|
24
|
+
"name": "goNext",
|
|
25
|
+
"type": "function",
|
|
26
|
+
"detail": "Navigates to the next step",
|
|
27
|
+
"info": "Navigates to the next step if allowed.\n\n---\n\n### Function signature\n\n```\ngoNext(): void\n```\n\n---\n\n### Notes\n\nThis function performs navigation to the next step. It is recommended to check `canNext()` before invoking.\n\n---\n\n### Examples\n\n```ts\ngoNext()\n```",
|
|
28
|
+
"params": []
|
|
29
|
+
},
|
|
30
|
+
{
|
|
31
|
+
"name": "activeNav",
|
|
32
|
+
"type": "property",
|
|
33
|
+
"detail": "Gets the index of the active navigation step",
|
|
34
|
+
"info": "Returns the index of the currently active navigation step.\n\n---\n\n### Signature\n\n```\nactiveNav: number\n```\n\n---\n\n### Notes\n\nThe value represents the current position in the navigation flow.\n\n---\n\n### Examples\n\n```ts\nactiveNav\n```",
|
|
35
|
+
"params": []
|
|
36
|
+
}
|
|
37
|
+
]
|
|
@@ -6,12 +6,17 @@ export class Control {
|
|
|
6
6
|
throw new Error('ControlContext must not be null or undefined');
|
|
7
7
|
}
|
|
8
8
|
this.context = context;
|
|
9
|
+
const stateless = (context.metadata?.stateless === true);
|
|
9
10
|
context.destroyRef?.onDestroy(() => {
|
|
10
|
-
|
|
11
|
+
if (!stateless) {
|
|
12
|
+
this.onSaveState();
|
|
13
|
+
}
|
|
11
14
|
this.onDestroy();
|
|
12
15
|
});
|
|
13
16
|
this.onInit();
|
|
14
|
-
|
|
17
|
+
if (!stateless) {
|
|
18
|
+
setTimeout(() => this.onLoadState());
|
|
19
|
+
}
|
|
15
20
|
}
|
|
16
21
|
get name() {
|
|
17
22
|
return this.context.name;
|
|
@@ -86,4 +91,4 @@ export class ItemControl extends ContainerControl {
|
|
|
86
91
|
this.index = index;
|
|
87
92
|
}
|
|
88
93
|
}
|
|
89
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
94
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udHJvbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1zaXJpby9zcmMvbGliL2NvbnRyb2xzL2NvbnRyb2wudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBRXpELE1BQU0sT0FBTyxPQUFPO0lBRUQsT0FBTyxDQUFpQjtJQUV6QyxZQUFZLE9BQXVCO1FBQ2pDLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQztZQUNiLE1BQU0sSUFBSSxLQUFLLENBQUMsOENBQThDLENBQUMsQ0FBQztRQUNsRSxDQUFDO1FBRUQsSUFBSSxDQUFDLE9BQU8sR0FBRyxPQUFPLENBQUM7UUFFdkIsTUFBTSxTQUFTLEdBQUcsQ0FBQyxPQUFPLENBQUMsUUFBUSxFQUFFLFNBQVMsS0FBSyxJQUFJLENBQUMsQ0FBQztRQUV6RCxPQUFPLENBQUMsVUFBVSxFQUFFLFNBQVMsQ0FBQyxHQUFHLEVBQUU7WUFDakMsSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDO2dCQUNmLElBQUksQ0FBQyxXQUFXLEVBQUUsQ0FBQztZQUNyQixDQUFDO1lBQ0QsSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDO1FBQ25CLENBQUMsQ0FBQyxDQUFDO1FBRUgsSUFBSSxDQUFDLE1BQU0sRUFBRSxDQUFDO1FBRWQsSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDO1lBQ2YsVUFBVSxDQUFDLEdBQUcsRUFBRSxDQUFDLElBQUksQ0FBQyxXQUFXLEVBQUUsQ0FBQyxDQUFDO1FBQ3ZDLENBQUM7SUFFSCxDQUFDO0lBRUQsSUFBVyxJQUFJO1FBQ2IsT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQztJQUMzQixDQUFDO0lBRVMsV0FBVztRQUNuQixPQUFPLElBQUksQ0FBQyxPQUFPLENBQUMsUUFBUSxDQUFDO0lBQy9CLENBQUM7SUFFUyxlQUFlO1FBQ3ZCLE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQyxZQUFZLENBQUM7SUFDbkMsQ0FBQztJQUVTLGFBQWE7UUFDckIsT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDLFVBQVUsQ0FBQztJQUNqQyxDQUFDO0lBRVMsV0FBVztRQUNuQixPQUFPLElBQUksQ0FBQyxPQUFPLENBQUMsUUFBUSxDQUFDO0lBQy9CLENBQUM7SUFFUyxhQUFhO1FBQ3JCLE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQyxVQUFVLENBQUM7SUFDakMsQ0FBQztJQUVTLFdBQVc7UUFDbkIsT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDLFFBQVEsQ0FBQztJQUMvQixDQUFDO0lBRVMsTUFBTTtJQUNoQixDQUFDO0lBRVMsV0FBVztJQUNyQixDQUFDO0lBRVMsV0FBVztJQUNyQixDQUFDO0lBRVMsU0FBUztJQUNuQixDQUFDO0lBRVMsUUFBUTtRQUNoQixNQUFNLEVBQUUsR0FBRyxJQUFJLENBQUMsS0FBSyxFQUFFLENBQUM7UUFDeEIsSUFBSSxDQUFDLEVBQUU7WUFBRSxPQUFPLElBQUksQ0FBQztRQUNyQixPQUFPLElBQUksQ0FBQyxLQUFLLEVBQUUsRUFBRSxRQUFRLENBQUMsRUFBRSxDQUFDLENBQUM7SUFDcEMsQ0FBQztJQUVTLFFBQVEsQ0FBQyxLQUFVO1FBQzNCLE1BQU0sRUFBRSxHQUFHLElBQUksQ0FBQyxLQUFLLEVBQUUsQ0FBQztRQUN4QixJQUFJLENBQUMsRUFBRTtZQUFFLE9BQU87UUFDaEIsSUFBSSxDQUFDLEtBQUssRUFBRSxFQUFFLFFBQVEsQ0FBQyxFQUFFLEVBQUUsS0FBSyxDQUFDLENBQUM7SUFDcEMsQ0FBQztJQUVTLFVBQVU7UUFDbEIsTUFBTSxFQUFFLEdBQUcsSUFBSSxDQUFDLEtBQUssRUFBRSxDQUFDO1FBQ3hCLElBQUksQ0FBQyxFQUFFO1lBQUUsT0FBTztRQUNoQixJQUFJLENBQUMsS0FBSyxFQUFFLEVBQUUsVUFBVSxDQUFDLEVBQUUsQ0FBQyxDQUFDO0lBQy9CLENBQUM7SUFFRCx5QkFBeUI7SUFFakIsS0FBSztRQUNYLE9BQU8sR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksSUFBSSxJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksRUFBRSxDQUFDO0lBQ3JELENBQUM7SUFFTyxLQUFLO1FBQ1gsT0FBTyxJQUFJLENBQUMsV0FBVyxFQUFFLENBQUMsR0FBRyxDQUFDLFlBQVksQ0FBQyxDQUFDO0lBQzlDLENBQUM7Q0FJRjtBQUVELE1BQU0sT0FBTyxnQkFBaUIsU0FBUSxPQUFPO0lBRTNDLFlBQVksT0FBdUI7UUFDakMsS0FBSyxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQ2pCLENBQUM7SUFFRCxXQUFXLENBQ1QsU0FBd0MsRUFDeEMsU0FBa0I7UUFFbEIsTUFBTSxRQUFRLEdBQUcsSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDO1FBQ3BDLE9BQU8sUUFBUTtZQUNiLENBQUMsQ0FBQyxRQUFRLENBQUMsV0FBVyxDQUFDLFNBQVMsRUFBRSxTQUFTLEVBQUUsS0FBSyxDQUFDO1lBQ25ELENBQUMsQ0FBQyxFQUFFLENBQUM7SUFDVCxDQUFDO0NBQ0Y7QUFFRCxNQUFNLE9BQU8sV0FBWSxTQUFRLGdCQUFnQjtJQUc3QjtJQURsQixZQUFZLE9BQXVCLEVBQ2pCLEtBQWE7UUFDN0IsS0FBSyxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBREMsVUFBSyxHQUFMLEtBQUssQ0FBUTtJQUUvQixDQUFDO0NBRUYiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBFbGVtZW50UmVmLCBJbmplY3RvciwgRGVzdHJveVJlZiB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcbmltcG9ydCB7IFJlZ2lzdGVyU2VydmljZSB9IGZyb20gXCIuLi9zZXJ2aWNlcy9yZWdpc3Rlci5zZXJ2aWNlXCI7XHJcbmltcG9ydCB7IFN0YXRlU2VydmljZSB9IGZyb20gXCIuLi9zZXJ2aWNlcy9zdGF0ZS5zZXJ2aWNlXCI7XHJcblxyXG5leHBvcnQgY2xhc3MgQ29udHJvbCB7XHJcblxyXG4gIHByaXZhdGUgcmVhZG9ubHkgY29udGV4dDogQ29udHJvbENvbnRleHQ7XHJcblxyXG4gIGNvbnN0cnVjdG9yKGNvbnRleHQ6IENvbnRyb2xDb250ZXh0KSB7XHJcbiAgICBpZiAoIWNvbnRleHQpIHtcclxuICAgICAgdGhyb3cgbmV3IEVycm9yKCdDb250cm9sQ29udGV4dCBtdXN0IG5vdCBiZSBudWxsIG9yIHVuZGVmaW5lZCcpO1xyXG4gICAgfVxyXG5cclxuICAgIHRoaXMuY29udGV4dCA9IGNvbnRleHQ7XHJcblxyXG4gICAgY29uc3Qgc3RhdGVsZXNzID0gKGNvbnRleHQubWV0YWRhdGE/LnN0YXRlbGVzcyA9PT0gdHJ1ZSk7XHJcblxyXG4gICAgY29udGV4dC5kZXN0cm95UmVmPy5vbkRlc3Ryb3koKCkgPT4ge1xyXG4gICAgICBpZiAoIXN0YXRlbGVzcykge1xyXG4gICAgICAgIHRoaXMub25TYXZlU3RhdGUoKTtcclxuICAgICAgfSAgICAgIFxyXG4gICAgICB0aGlzLm9uRGVzdHJveSgpO1xyXG4gICAgfSk7XHJcblxyXG4gICAgdGhpcy5vbkluaXQoKTtcclxuXHJcbiAgICBpZiAoIXN0YXRlbGVzcykge1xyXG4gICAgICBzZXRUaW1lb3V0KCgpID0+IHRoaXMub25Mb2FkU3RhdGUoKSk7XHJcbiAgICB9XHJcbiAgICBcclxuICB9XHJcblxyXG4gIHB1YmxpYyBnZXQgbmFtZSgpOiBzdHJpbmcge1xyXG4gICAgcmV0dXJuIHRoaXMuY29udGV4dC5uYW1lO1xyXG4gIH1cclxuXHJcbiAgcHJvdGVjdGVkIGdldE1ldGFkYXRhKCk6IGFueSB7XHJcbiAgICByZXR1cm4gdGhpcy5jb250ZXh0Lm1ldGFkYXRhO1xyXG4gIH1cclxuXHJcbiAgcHJvdGVjdGVkIGdldENvbXBvbmVudFJlZigpOiBhbnkge1xyXG4gICAgcmV0dXJuIHRoaXMuY29udGV4dC5jb21wb25lbnRSZWY7XHJcbiAgfVxyXG5cclxuICBwcm90ZWN0ZWQgZ2V0RWxlbWVudFJlZigpOiBFbGVtZW50UmVmIHtcclxuICAgIHJldHVybiB0aGlzLmNvbnRleHQuZWxlbWVudFJlZjtcclxuICB9XHJcblxyXG4gIHByb3RlY3RlZCBnZXRJbmplY3RvcigpOiBJbmplY3RvciB7XHJcbiAgICByZXR1cm4gdGhpcy5jb250ZXh0LmluamVjdG9yO1xyXG4gIH1cclxuXHJcbiAgcHJvdGVjdGVkIGdldERlc3Ryb3lSZWYoKTogRGVzdHJveVJlZiB7XHJcbiAgICByZXR1cm4gdGhpcy5jb250ZXh0LmRlc3Ryb3lSZWY7XHJcbiAgfVxyXG5cclxuICBwcm90ZWN0ZWQgZ2V0UmVnaXN0ZXIoKTogUmVnaXN0ZXJTZXJ2aWNlIHwgdW5kZWZpbmVkIHtcclxuICAgIHJldHVybiB0aGlzLmNvbnRleHQucmVnaXN0ZXI7XHJcbiAgfVxyXG5cclxuICBwcm90ZWN0ZWQgb25Jbml0KCk6IHZvaWQge1xyXG4gIH1cclxuXHJcbiAgcHJvdGVjdGVkIG9uTG9hZFN0YXRlKCk6IHZvaWQge1xyXG4gIH1cclxuXHJcbiAgcHJvdGVjdGVkIG9uU2F2ZVN0YXRlKCk6IHZvaWQge1xyXG4gIH1cclxuXHJcbiAgcHJvdGVjdGVkIG9uRGVzdHJveSgpOiB2b2lkIHtcclxuICB9XHJcblxyXG4gIHByb3RlY3RlZCBnZXRTdGF0ZTxUID0gYW55PigpOiBUIHwgbnVsbCB7XHJcbiAgICBjb25zdCBpZCA9IHRoaXMuZ2V0SWQoKTtcclxuICAgIGlmICghaWQpIHJldHVybiBudWxsO1xyXG4gICAgcmV0dXJuIHRoaXMuU3RhdGUoKT8uZ2V0U3RhdGUoaWQpO1xyXG4gIH1cclxuXHJcbiAgcHJvdGVjdGVkIHNldFN0YXRlKHN0YXRlOiBhbnkpOiB2b2lkIHtcclxuICAgIGNvbnN0IGlkID0gdGhpcy5nZXRJZCgpO1xyXG4gICAgaWYgKCFpZCkgcmV0dXJuO1xyXG4gICAgdGhpcy5TdGF0ZSgpPy5zZXRTdGF0ZShpZCwgc3RhdGUpO1xyXG4gIH1cclxuXHJcbiAgcHJvdGVjdGVkIGNsZWFyU3RhdGUoKTogdm9pZCB7XHJcbiAgICBjb25zdCBpZCA9IHRoaXMuZ2V0SWQoKTtcclxuICAgIGlmICghaWQpIHJldHVybjtcclxuICAgIHRoaXMuU3RhdGUoKT8uY2xlYXJTdGF0ZShpZCk7XHJcbiAgfVxyXG5cclxuICAvLyNyZWdpb24gUHJpdmF0ZSBNZW1iZXJzXHJcblxyXG4gIHByaXZhdGUgZ2V0SWQoKTogc3RyaW5nIHwgbnVsbCB7XHJcbiAgICByZXR1cm4gYCR7dGhpcy5jb250ZXh0LnBhdGh9LiR7dGhpcy5jb250ZXh0Lm5hbWV9YDtcclxuICB9XHJcblxyXG4gIHByaXZhdGUgU3RhdGUoKSB7XHJcbiAgICByZXR1cm4gdGhpcy5nZXRJbmplY3RvcigpLmdldChTdGF0ZVNlcnZpY2UpO1xyXG4gIH1cclxuXHJcbiAgLy8jZW5kcmVnaW9uXHJcblxyXG59XHJcblxyXG5leHBvcnQgY2xhc3MgQ29udGFpbmVyQ29udHJvbCBleHRlbmRzIENvbnRyb2wge1xyXG5cclxuICBjb25zdHJ1Y3Rvcihjb250ZXh0OiBDb250cm9sQ29udGV4dCkge1xyXG4gICAgc3VwZXIoY29udGV4dCk7XHJcbiAgfVxyXG5cclxuICBmaW5kQ29udHJvbChcclxuICAgIHByZWRpY2F0ZTogKGNvbnRyb2w6IENvbnRyb2wpID0+IGJvb2xlYW4sXHJcbiAgICBmaXJzdE9ubHk6IGJvb2xlYW5cclxuICApOiBDb250cm9sW10ge1xyXG4gICAgY29uc3QgcmVnaXN0ZXIgPSB0aGlzLmdldFJlZ2lzdGVyKCk7XHJcbiAgICByZXR1cm4gcmVnaXN0ZXJcclxuICAgICAgPyByZWdpc3Rlci5maW5kQ29udHJvbChwcmVkaWNhdGUsIGZpcnN0T25seSwgZmFsc2UpXHJcbiAgICAgIDogW107XHJcbiAgfVxyXG59XHJcblxyXG5leHBvcnQgY2xhc3MgSXRlbUNvbnRyb2wgZXh0ZW5kcyBDb250YWluZXJDb250cm9sIHtcclxuXHJcbiAgY29uc3RydWN0b3IoY29udGV4dDogQ29udHJvbENvbnRleHQsXHJcbiAgICBwdWJsaWMgcmVhZG9ubHkgaW5kZXg6IG51bWJlcikge1xyXG4gICAgc3VwZXIoY29udGV4dCk7XHJcbiAgfVxyXG5cclxufVxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBDb250cm9sQ29udGV4dCB7XHJcbiAgbmFtZTogc3RyaW5nO1xyXG4gIHBhdGg6IHN0cmluZztcclxuICBtZXRhZGF0YTogYW55O1xyXG4gIGNvbXBvbmVudFJlZjogYW55O1xyXG4gIGVsZW1lbnRSZWY6IEVsZW1lbnRSZWY7XHJcbiAgaW5qZWN0b3I6IEluamVjdG9yO1xyXG4gIGRlc3Ryb3lSZWY6IERlc3Ryb3lSZWY7XHJcbiAgcmVnaXN0ZXI/OiBSZWdpc3RlclNlcnZpY2U7ICBcclxufVxyXG4iXX0=
|
|
@@ -1,35 +1,35 @@
|
|
|
1
|
-
import { Control } from '
|
|
2
|
-
import { FormControl } from '
|
|
3
|
-
import { TextFieldControl } from '
|
|
4
|
-
import { SelectControl } from '
|
|
5
|
-
import { TagListControl } from '
|
|
6
|
-
import { NumberControl } from '
|
|
7
|
-
import { DateControl } from '
|
|
8
|
-
import { TimeControl } from '
|
|
9
|
-
import { DateTimeControl } from '
|
|
10
|
-
import { ToggleControl } from '
|
|
11
|
-
import { CheckBoxControl } from '
|
|
12
|
-
import { ChipRadioControl } from '
|
|
13
|
-
import { RadioControl } from '
|
|
14
|
-
import { ChipCheckListControl } from '
|
|
15
|
-
import { CheckListControl } from '
|
|
16
|
-
import { TextAreaControl } from '
|
|
17
|
-
import { FilePickerControl } from '
|
|
18
|
-
import { TextControl } from '
|
|
19
|
-
import { HtmlControl } from '
|
|
20
|
-
import { ImageControl } from '
|
|
21
|
-
import { TabControl } from '
|
|
22
|
-
import { ChartControl } from '
|
|
23
|
-
import { AccordionControl } from '
|
|
24
|
-
import { DynamicListControl } from '
|
|
25
|
-
import { GroupControl } from '
|
|
26
|
-
import { TableControl } from '
|
|
27
|
-
import { ButtonControl } from '
|
|
28
|
-
import { SeparatorControl } from '
|
|
29
|
-
import { SpacerControl } from '
|
|
30
|
-
import { IFrameControl } from '
|
|
31
|
-
import { TooltipControl } from '
|
|
32
|
-
import { DisplayFieldControl } from '
|
|
1
|
+
import { Control } from './control';
|
|
2
|
+
import { FormControl } from './form';
|
|
3
|
+
import { TextFieldControl } from './textfield';
|
|
4
|
+
import { SelectControl } from './select';
|
|
5
|
+
import { TagListControl } from './taglist';
|
|
6
|
+
import { NumberControl } from './number';
|
|
7
|
+
import { DateControl } from './date';
|
|
8
|
+
import { TimeControl } from './time';
|
|
9
|
+
import { DateTimeControl } from './datetime';
|
|
10
|
+
import { ToggleControl } from './toggle';
|
|
11
|
+
import { CheckBoxControl } from './checkbox';
|
|
12
|
+
import { ChipRadioControl } from './chipradio';
|
|
13
|
+
import { RadioControl } from './radio';
|
|
14
|
+
import { ChipCheckListControl } from './chipchecklist';
|
|
15
|
+
import { CheckListControl } from './checklist';
|
|
16
|
+
import { TextAreaControl } from './textarea';
|
|
17
|
+
import { FilePickerControl } from './filepicker';
|
|
18
|
+
import { TextControl } from './text';
|
|
19
|
+
import { HtmlControl } from './html';
|
|
20
|
+
import { ImageControl } from './image';
|
|
21
|
+
import { TabControl } from './tab';
|
|
22
|
+
import { ChartControl } from './chart';
|
|
23
|
+
import { AccordionControl } from './accordion';
|
|
24
|
+
import { DynamicListControl } from './dynamiclist';
|
|
25
|
+
import { GroupControl } from './group';
|
|
26
|
+
import { TableControl } from './table';
|
|
27
|
+
import { ButtonControl } from './button';
|
|
28
|
+
import { SeparatorControl } from './separator';
|
|
29
|
+
import { SpacerControl } from './spacer';
|
|
30
|
+
import { IFrameControl } from './iframe';
|
|
31
|
+
import { TooltipControl } from './tooltip';
|
|
32
|
+
import { DisplayFieldControl } from './displayfield';
|
|
33
33
|
export function createControl(context) {
|
|
34
34
|
switch (context.metadata.type) {
|
|
35
35
|
case "default":
|
|
@@ -119,4 +119,4 @@ export function createControl(context) {
|
|
|
119
119
|
return new Control(context);
|
|
120
120
|
}
|
|
121
121
|
}
|
|
122
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"factory.js","sourceRoot":"","sources":["../../../../../projects/ngx-sirio/src/lib/controls/factory.ts"],"names":[],"mappings":"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","sourcesContent":["import { Control, ControlContext } from '../controls/control';\r\nimport { FormControl } from '../controls/form';\r\nimport { TextFieldControl } from '../controls/textfield';\r\nimport { SelectControl } from '../controls/select';\r\nimport { TagListControl } from '../controls/taglist';\r\nimport { NumberControl } from '../controls/number';\r\nimport { DateControl } from '../controls/date';\r\nimport { TimeControl } from '../controls/time';\r\nimport { DateTimeControl } from '../controls/datetime';\r\nimport { ToggleControl } from '../controls/toggle';\r\nimport { CheckBoxControl } from '../controls/checkbox';\r\nimport { ChipRadioControl } from '../controls/chipradio';\r\nimport { RadioControl } from '../controls/radio';\r\nimport { ChipCheckListControl } from '../controls/chipchecklist';\r\nimport { CheckListControl } from '../controls/checklist';\r\nimport { TextAreaControl } from '../controls/textarea';\r\nimport { FilePickerControl } from '../controls/filepicker';\r\nimport { TextControl } from '../controls/text';\r\nimport { HtmlControl } from '../controls/html';\r\nimport { ImageControl } from '../controls/image';\r\nimport { TabControl } from '../controls/tab';\r\nimport { ChartControl } from '../controls/chart';\r\nimport { AccordionControl } from '../controls/accordion';\r\nimport { DynamicListControl } from '../controls/dynamiclist';\r\nimport { GroupControl } from '../controls/group';\r\nimport { TableControl } from '../controls/table';\r\nimport { ButtonControl } from '../controls/button';\r\nimport { SeparatorControl } from '../controls/separator';\r\nimport { SpacerControl } from '../controls/spacer';\r\nimport { IFrameControl } from '../controls/iframe';\r\nimport { TooltipControl } from '../controls/tooltip';\r\nimport { DisplayFieldControl } from '../controls/displayfield';\r\n\r\nexport function createControl(context: ControlContext): Control {\r\n\r\n  switch (context.metadata.type) {\r\n\r\n    case \"default\":\r\n      return new FormControl(context);\r\n\r\n    case \"textfield\":\r\n      return new TextFieldControl(context);\r\n\r\n    case \"select\":\r\n      return new SelectControl(context);\r\n\r\n    case \"taglist\":\r\n      return new TagListControl(context);\r\n\r\n    case \"number\":\r\n      return new NumberControl(context);\r\n\r\n    case \"datetime\":\r\n      switch (context.metadata.subtype) {\r\n        case \"date\":\r\n          return new DateControl(context);\r\n        case \"time\":\r\n          return new TimeControl(context);\r\n        case \"datetime\":\r\n          return new DateTimeControl(context);\r\n        default:\r\n          return new Control(context);\r\n      }\r\n\r\n    case \"checkbox\":\r\n      switch (context.metadata.subtype) {\r\n        case \"toggle\":\r\n          return new ToggleControl(context);\r\n        default:\r\n          return new CheckBoxControl(context);\r\n      }\r\n\r\n    case \"radio\":\r\n      switch (context.metadata.subtype) {\r\n        case \"chip\":\r\n          return new ChipRadioControl(context);\r\n        default:\r\n          return new RadioControl(context);\r\n      }\r\n\r\n    case \"checklist\":\r\n      switch (context.metadata.subtype) {\r\n        case \"chip\":\r\n          return new ChipCheckListControl(context);\r\n        default:\r\n          return new CheckListControl(context);\r\n      }\r\n\r\n    case \"textarea\":\r\n      return new TextAreaControl(context);\r\n\r\n    case \"filepicker\":\r\n      return new FilePickerControl(context);\r\n\r\n    case \"displayfield\":\r\n      return new DisplayFieldControl(context);\r\n\r\n    case \"text\":\r\n      return new TextControl(context);\r\n\r\n    case \"html\":\r\n      return new HtmlControl(context);\r\n\r\n    case \"image\":\r\n      return new ImageControl(context);\r\n\r\n    case \"dynamiclist\":\r\n      switch (context.metadata.subtype) {\r\n        case \"tab\":\r\n          return new TabControl(context);\r\n        case \"accordion\":\r\n          return new AccordionControl(context);\r\n        default:\r\n          return new DynamicListControl(context);\r\n      }\r\n\r\n    case \"group\":\r\n      return new GroupControl(context);\r\n\r\n    case \"table\":\r\n      return new TableControl(context);\r\n\r\n    case \"chart\":\r\n      return new ChartControl(context);\r\n\r\n    case \"button\":\r\n      return new ButtonControl(context);\r\n\r\n    case \"separator\":\r\n      return new SeparatorControl(context);\r\n\r\n    case \"spacer\":\r\n      return new SpacerControl(context);\r\n\r\n    case \"iframe\":\r\n      return new IFrameControl(context);\r\n\r\n    case \"tooltip\":\r\n      return new TooltipControl(context);\r\n\r\n    case \"tab\":\r\n      return new TabControl(context);\r\n\r\n    case \"accordion\":\r\n      return new AccordionControl(context);\r\n\r\n    default:\r\n      return new Control(context);\r\n  }\r\n}\r\n"]}
|
|
122
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"factory.js","sourceRoot":"","sources":["../../../../../projects/ngx-sirio/src/lib/controls/factory.ts"],"names":[],"mappings":"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","sourcesContent":["import { Control, ControlContext } from './control';\r\nimport { FormControl } from './form';\r\nimport { TextFieldControl } from './textfield';\r\nimport { SelectControl } from './select';\r\nimport { TagListControl } from './taglist';\r\nimport { NumberControl } from './number';\r\nimport { DateControl } from './date';\r\nimport { TimeControl } from './time';\r\nimport { DateTimeControl } from './datetime';\r\nimport { ToggleControl } from './toggle';\r\nimport { CheckBoxControl } from './checkbox';\r\nimport { ChipRadioControl } from './chipradio';\r\nimport { RadioControl } from './radio';\r\nimport { ChipCheckListControl } from './chipchecklist';\r\nimport { CheckListControl } from './checklist';\r\nimport { TextAreaControl } from './textarea';\r\nimport { FilePickerControl } from './filepicker';\r\nimport { TextControl } from './text';\r\nimport { HtmlControl } from './html';\r\nimport { ImageControl } from './image';\r\nimport { TabControl } from './tab';\r\nimport { ChartControl } from './chart';\r\nimport { AccordionControl } from './accordion';\r\nimport { DynamicListControl } from './dynamiclist';\r\nimport { GroupControl } from './group';\r\nimport { TableControl } from './table';\r\nimport { ButtonControl } from './button';\r\nimport { SeparatorControl } from './separator';\r\nimport { SpacerControl } from './spacer';\r\nimport { IFrameControl } from './iframe';\r\nimport { TooltipControl } from './tooltip';\r\nimport { DisplayFieldControl } from './displayfield';\r\n\r\nexport function createControl(context: ControlContext): Control {\r\n\r\n  switch (context.metadata.type) {\r\n\r\n    case \"default\":\r\n      return new FormControl(context);\r\n\r\n    case \"textfield\":\r\n      return new TextFieldControl(context);\r\n\r\n    case \"select\":\r\n      return new SelectControl(context);\r\n\r\n    case \"taglist\":\r\n      return new TagListControl(context);\r\n\r\n    case \"number\":\r\n      return new NumberControl(context);\r\n\r\n    case \"datetime\":\r\n      switch (context.metadata.subtype) {\r\n        case \"date\":\r\n          return new DateControl(context);\r\n        case \"time\":\r\n          return new TimeControl(context);\r\n        case \"datetime\":\r\n          return new DateTimeControl(context);\r\n        default:\r\n          return new Control(context);\r\n      }\r\n\r\n    case \"checkbox\":\r\n      switch (context.metadata.subtype) {\r\n        case \"toggle\":\r\n          return new ToggleControl(context);\r\n        default:\r\n          return new CheckBoxControl(context);\r\n      }\r\n\r\n    case \"radio\":\r\n      switch (context.metadata.subtype) {\r\n        case \"chip\":\r\n          return new ChipRadioControl(context);\r\n        default:\r\n          return new RadioControl(context);\r\n      }\r\n\r\n    case \"checklist\":\r\n      switch (context.metadata.subtype) {\r\n        case \"chip\":\r\n          return new ChipCheckListControl(context);\r\n        default:\r\n          return new CheckListControl(context);\r\n      }\r\n\r\n    case \"textarea\":\r\n      return new TextAreaControl(context);\r\n\r\n    case \"filepicker\":\r\n      return new FilePickerControl(context);\r\n\r\n    case \"displayfield\":\r\n      return new DisplayFieldControl(context);\r\n\r\n    case \"text\":\r\n      return new TextControl(context);\r\n\r\n    case \"html\":\r\n      return new HtmlControl(context);\r\n\r\n    case \"image\":\r\n      return new ImageControl(context);\r\n\r\n    case \"dynamiclist\":\r\n      switch (context.metadata.subtype) {\r\n        case \"tab\":\r\n          return new TabControl(context);\r\n        case \"accordion\":\r\n          return new AccordionControl(context);\r\n        default:\r\n          return new DynamicListControl(context);\r\n      }\r\n\r\n    case \"group\":\r\n      return new GroupControl(context);\r\n\r\n    case \"table\":\r\n      return new TableControl(context);\r\n\r\n    case \"chart\":\r\n      return new ChartControl(context);\r\n\r\n    case \"button\":\r\n      return new ButtonControl(context);\r\n\r\n    case \"separator\":\r\n      return new SeparatorControl(context);\r\n\r\n    case \"spacer\":\r\n      return new SpacerControl(context);\r\n\r\n    case \"iframe\":\r\n      return new IFrameControl(context);\r\n\r\n    case \"tooltip\":\r\n      return new TooltipControl(context);\r\n\r\n    case \"tab\":\r\n      return new TabControl(context);\r\n\r\n    case \"accordion\":\r\n      return new AccordionControl(context);\r\n\r\n    default:\r\n      return new Control(context);\r\n  }\r\n}\r\n"]}
|
|
@@ -48,7 +48,8 @@ export class DialogComponent extends SirioDialogElement {
|
|
|
48
48
|
this.doAction('Close');
|
|
49
49
|
}
|
|
50
50
|
doAction(action) {
|
|
51
|
-
this.
|
|
51
|
+
if (this.options.keepOpen !== true)
|
|
52
|
+
this.sirioDialogService.closeDialog();
|
|
52
53
|
this.SendResult(action);
|
|
53
54
|
}
|
|
54
55
|
showHeader() {
|
|
@@ -88,7 +89,7 @@ export class DialogComponent extends SirioDialogElement {
|
|
|
88
89
|
}
|
|
89
90
|
}
|
|
90
91
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: DialogComponent, deps: [{ token: i1.LanguageService }], target: i0.ɵɵFactoryTarget.Component });
|
|
91
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.14", type: DialogComponent, isStandalone: true, selector: "dynamic-dialog", viewQueries: [{ propertyName: "formHost", first: true, predicate: ["formHost"], descendants: true, read: ViewContainerRef, static: true }], usesInheritance: true, ngImport: i0, template: "<ngx-sirio-dialog (closeEvent)=\"doClose()\"\r\n dialog\r\n [type]=\"options.type ?? 'info'\"\r\n [size]=\"options.size ?? 'default'\"\r\n [isDrawer]=\"options.isDrawer ?? false\"\r\n [withCloseButton]=\"showCloseButton()\">\r\n\r\n <ngx-sirio-dialog-header [hidden]=\"!showHeader()\">\r\n <ngx-sirio-dialog-title [hidden]=\"!showTitle()\">{{ options.title }}</ngx-sirio-dialog-title>\r\n </ngx-sirio-dialog-header>\r\n\r\n <ngx-sirio-dialog-body>\r\n <ng-template #formHost></ng-template>\r\n </ngx-sirio-dialog-body>\r\n\r\n <ngx-sirio-dialog-footer *ngIf=\"showFooter()\">\r\n <ng-container [ngSwitch]=\"options.buttons\">\r\n <!-- OK -->\r\n <ng-container *ngSwitchCase=\"'OK'\">\r\n <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'OK' }\"></ng-container>\r\n </ng-container>\r\n <!-- Caso: OKCancel -->\r\n <ng-container *ngSwitchCase=\"'OKCancel'\">\r\n <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'OK' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Cancel' }\"></ng-container>\r\n </ng-container>\r\n <!-- Caso: ConfirmClose -->\r\n <ng-container *ngSwitchCase=\"'ConfirmCancel'\">\r\n <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'Confirm' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Cancel' }\"></ng-container>\r\n </ng-container>\r\n <!-- Caso: AbortRetryIgnore -->\r\n <ng-container *ngSwitchCase=\"'AbortRetryIgnore'\">\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Abort' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'Retry' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Ignore' }\"></ng-container>\r\n </ng-container>\r\n <!-- Caso: YesNoCancel -->\r\n <ng-container *ngSwitchCase=\"'YesNoCancel'\">\r\n <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'Yes' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'No' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Cancel' }\"></ng-container>\r\n </ng-container>\r\n <!-- Caso: YesNo -->\r\n <ng-container *ngSwitchCase=\"'YesNo'\">\r\n <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'Yes' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'No' }\"></ng-container>\r\n </ng-container>\r\n <!-- Caso: RetryCancel -->\r\n <ng-container *ngSwitchCase=\"'RetryCancel'\">\r\n <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'Retry' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Cancel' }\"></ng-container>\r\n </ng-container>\r\n <!-- Caso: CancelTryContinue -->\r\n <ng-container *ngSwitchCase=\"'CancelTryContinue'\">\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Cancel' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'Try' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Continue' }\"></ng-container>\r\n </ng-container>\r\n </ng-container>\r\n <!-- Templates -->\r\n <ng-template #confirmTemplate let-action=\"action\">\r\n <ngx-sirio-button (clickEvent)=\"doAction(action)\"\r\n [disabled]=\"isInvalid()\"\r\n color=\"primary\">\r\n {{ locale(Texts, action) }}\r\n </ngx-sirio-button>\r\n </ng-template>\r\n <ng-template #closeTemplate let-action=\"action\">\r\n <ngx-sirio-button (clickEvent)=\"doAction(action)\"\r\n color=\"secondary\">\r\n {{ locale(Texts, action) }}\r\n </ngx-sirio-button>\r\n </ng-template>\r\n\r\n </ngx-sirio-dialog-footer>\r\n\r\n</ngx-sirio-dialog>\r\n", styles: ["::ng-deep .sirio-dialog{background-color:#0000007f!important}::ng-deep .sirio-drawer .sirio-dialog .sirio-dialog-sm .sirio-dialog-content{max-width:18.75rem}::ng-deep .sirio-drawer .sirio-dialog .sirio-dialog-lg .sirio-dialog-content{max-width:50rem}::ng-deep .sirio-drawer .sirio-dialog .sirio-dialog-xl .sirio-dialog-content{max-width:71.25rem}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i2.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: DialogDirective, selector: "[dialog]" }, { kind: "component", type: SirioDialogComponent, selector: "ngx-sirio-dialog", inputs: ["type", "size", "drawerContext", "withCloseButton", "isDrawer", "dialogId"], outputs: ["closeEvent", "confirmEvent"] }, { kind: "component", type: SirioDialogBodyComponent, selector: "ngx-sirio-dialog-body" }, { kind: "component", type: SirioDialogHeaderComponent, selector: "ngx-sirio-dialog-header", inputs: ["closeButtonAriaLabel"], outputs: ["closeEvent"] }, { kind: "component", type: SirioDialogFooterComponent, selector: "ngx-sirio-dialog-footer", inputs: ["actionsLabel"], outputs: ["closeEvent", "confirmEvent"] }, { kind: "component", type: SirioButtonComponent, selector: "ngx-sirio-button", inputs: ["ariaExpanded", "ariaControls", "ariaActivedescendant", "ariaHaspopup", "ariaLabel", "ariaRequired", "ariaInvalid", "ariaDescribedby", "icon", "title", "role", "color", "isFloating", "isExtended", "isLight", "isSmall", "disabled", "isDropdown", "type", "dismissType", "isBtnBlock"], outputs: ["clickEvent", "focusEvent", "blurEvent"] }, { kind: "component", type: SirioDialogTitleComponent, selector: "ngx-sirio-dialog-title" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
92
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.14", type: DialogComponent, isStandalone: true, selector: "dynamic-dialog", viewQueries: [{ propertyName: "formHost", first: true, predicate: ["formHost"], descendants: true, read: ViewContainerRef, static: true }], usesInheritance: true, ngImport: i0, template: "<ngx-sirio-dialog (closeEvent)=\"doClose()\"\r\n dialog\r\n [type]=\"options.type ?? 'info'\"\r\n [size]=\"options.size ?? 'default'\"\r\n [isDrawer]=\"options.isDrawer ?? false\"\r\n [withCloseButton]=\"showCloseButton()\">\r\n\r\n <ngx-sirio-dialog-header [hidden]=\"!showHeader()\">\r\n <ngx-sirio-dialog-title [hidden]=\"!showTitle()\">{{ options.title }}</ngx-sirio-dialog-title>\r\n </ngx-sirio-dialog-header>\r\n\r\n <ngx-sirio-dialog-body>\r\n <ng-template #formHost></ng-template>\r\n </ngx-sirio-dialog-body>\r\n\r\n <ngx-sirio-dialog-footer *ngIf=\"showFooter()\">\r\n <ng-container [ngSwitch]=\"options.buttons\">\r\n <!-- OK -->\r\n <ng-container *ngSwitchCase=\"'OK'\">\r\n <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'OK' }\"></ng-container>\r\n </ng-container>\r\n <!-- Caso: OKCancel -->\r\n <ng-container *ngSwitchCase=\"'OKCancel'\">\r\n <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'OK' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Cancel' }\"></ng-container>\r\n </ng-container>\r\n <!-- Caso: ConfirmClose -->\r\n <ng-container *ngSwitchCase=\"'ConfirmCancel'\">\r\n <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'Confirm' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Cancel' }\"></ng-container>\r\n </ng-container>\r\n <!-- Caso: AbortRetryIgnore -->\r\n <ng-container *ngSwitchCase=\"'AbortRetryIgnore'\">\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Abort' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'Retry' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Ignore' }\"></ng-container>\r\n </ng-container>\r\n <!-- Caso: YesNoCancel -->\r\n <ng-container *ngSwitchCase=\"'YesNoCancel'\">\r\n <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'Yes' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'No' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Cancel' }\"></ng-container>\r\n </ng-container>\r\n <!-- Caso: YesNo -->\r\n <ng-container *ngSwitchCase=\"'YesNo'\">\r\n <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'Yes' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'No' }\"></ng-container>\r\n </ng-container>\r\n <!-- Caso: RetryCancel -->\r\n <ng-container *ngSwitchCase=\"'RetryCancel'\">\r\n <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'Retry' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Cancel' }\"></ng-container>\r\n </ng-container>\r\n <!-- Caso: CancelTryContinue -->\r\n <ng-container *ngSwitchCase=\"'CancelTryContinue'\">\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Cancel' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'Try' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Continue' }\"></ng-container>\r\n </ng-container>\r\n <!-- Caso: Custom -->\r\n <ng-container *ngSwitchCase=\"'Custom'\">\r\n <ng-container *ngFor=\"let customButton of options.customButtons ?? []; let i = index\">\r\n <ng-container *ngTemplateOutlet=\"customTemplate; context: { customButton: customButton }\"></ng-container>\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n <!-- Templates -->\r\n <ng-template #confirmTemplate let-action=\"action\">\r\n <ngx-sirio-button (clickEvent)=\"doAction(action)\"\r\n [disabled]=\"isInvalid()\"\r\n color=\"primary\">\r\n {{ locale(Texts, action) }}\r\n </ngx-sirio-button>\r\n </ng-template>\r\n <ng-template #closeTemplate let-action=\"action\">\r\n <ngx-sirio-button (clickEvent)=\"doAction(action)\"\r\n color=\"secondary\">\r\n {{ locale(Texts, action) }}\r\n </ngx-sirio-button>\r\n </ng-template>\r\n <ng-template #customTemplate\n let-customButton=\"customButton\">\r\n <ngx-sirio-button (clickEvent)=\"doAction(customButton.action)\"\r\n [color]=\"customButton.color\">\r\n {{ customButton.text }}\r\n </ngx-sirio-button>\r\n </ng-template>\r\n\r\n </ngx-sirio-dialog-footer>\r\n\r\n</ngx-sirio-dialog>\r\n", styles: ["::ng-deep .sirio-dialog{background-color:#0000007f!important}::ng-deep .sirio-drawer .sirio-dialog .sirio-dialog-sm .sirio-dialog-content{max-width:18.75rem}::ng-deep .sirio-drawer .sirio-dialog .sirio-dialog-lg .sirio-dialog-content{max-width:50rem}::ng-deep .sirio-drawer .sirio-dialog .sirio-dialog-xl .sirio-dialog-content{max-width:71.25rem}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i2.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: DialogDirective, selector: "[dialog]" }, { kind: "component", type: SirioDialogComponent, selector: "ngx-sirio-dialog", inputs: ["type", "size", "drawerContext", "withCloseButton", "isDrawer", "dialogId"], outputs: ["closeEvent", "confirmEvent"] }, { kind: "component", type: SirioDialogBodyComponent, selector: "ngx-sirio-dialog-body" }, { kind: "component", type: SirioDialogHeaderComponent, selector: "ngx-sirio-dialog-header", inputs: ["closeButtonAriaLabel"], outputs: ["closeEvent"] }, { kind: "component", type: SirioDialogFooterComponent, selector: "ngx-sirio-dialog-footer", inputs: ["actionsLabel"], outputs: ["closeEvent", "confirmEvent"] }, { kind: "component", type: SirioButtonComponent, selector: "ngx-sirio-button", inputs: ["ariaExpanded", "ariaControls", "ariaActivedescendant", "ariaHaspopup", "ariaLabel", "ariaRequired", "ariaInvalid", "ariaDescribedby", "icon", "title", "role", "color", "isFloating", "isExtended", "isLight", "isSmall", "disabled", "isDropdown", "type", "dismissType", "isBtnBlock"], outputs: ["clickEvent", "focusEvent", "blurEvent"] }, { kind: "component", type: SirioDialogTitleComponent, selector: "ngx-sirio-dialog-title" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
92
93
|
}
|
|
93
94
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: DialogComponent, decorators: [{
|
|
94
95
|
type: Component,
|
|
@@ -102,9 +103,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
|
|
|
102
103
|
SirioButtonComponent,
|
|
103
104
|
SirioDialogActionDirective,
|
|
104
105
|
SirioDialogTitleComponent
|
|
105
|
-
], changeDetection: ChangeDetectionStrategy.OnPush, template: "<ngx-sirio-dialog (closeEvent)=\"doClose()\"\r\n dialog\r\n [type]=\"options.type ?? 'info'\"\r\n [size]=\"options.size ?? 'default'\"\r\n [isDrawer]=\"options.isDrawer ?? false\"\r\n [withCloseButton]=\"showCloseButton()\">\r\n\r\n <ngx-sirio-dialog-header [hidden]=\"!showHeader()\">\r\n <ngx-sirio-dialog-title [hidden]=\"!showTitle()\">{{ options.title }}</ngx-sirio-dialog-title>\r\n </ngx-sirio-dialog-header>\r\n\r\n <ngx-sirio-dialog-body>\r\n <ng-template #formHost></ng-template>\r\n </ngx-sirio-dialog-body>\r\n\r\n <ngx-sirio-dialog-footer *ngIf=\"showFooter()\">\r\n <ng-container [ngSwitch]=\"options.buttons\">\r\n <!-- OK -->\r\n <ng-container *ngSwitchCase=\"'OK'\">\r\n <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'OK' }\"></ng-container>\r\n </ng-container>\r\n <!-- Caso: OKCancel -->\r\n <ng-container *ngSwitchCase=\"'OKCancel'\">\r\n <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'OK' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Cancel' }\"></ng-container>\r\n </ng-container>\r\n <!-- Caso: ConfirmClose -->\r\n <ng-container *ngSwitchCase=\"'ConfirmCancel'\">\r\n <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'Confirm' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Cancel' }\"></ng-container>\r\n </ng-container>\r\n <!-- Caso: AbortRetryIgnore -->\r\n <ng-container *ngSwitchCase=\"'AbortRetryIgnore'\">\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Abort' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'Retry' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Ignore' }\"></ng-container>\r\n </ng-container>\r\n <!-- Caso: YesNoCancel -->\r\n <ng-container *ngSwitchCase=\"'YesNoCancel'\">\r\n <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'Yes' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'No' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Cancel' }\"></ng-container>\r\n </ng-container>\r\n <!-- Caso: YesNo -->\r\n <ng-container *ngSwitchCase=\"'YesNo'\">\r\n <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'Yes' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'No' }\"></ng-container>\r\n </ng-container>\r\n <!-- Caso: RetryCancel -->\r\n <ng-container *ngSwitchCase=\"'RetryCancel'\">\r\n <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'Retry' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Cancel' }\"></ng-container>\r\n </ng-container>\r\n <!-- Caso: CancelTryContinue -->\r\n <ng-container *ngSwitchCase=\"'CancelTryContinue'\">\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Cancel' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'Try' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Continue' }\"></ng-container>\r\n </ng-container>\r\n </ng-container>\r\n <!-- Templates -->\r\n <ng-template #confirmTemplate let-action=\"action\">\r\n <ngx-sirio-button (clickEvent)=\"doAction(action)\"\r\n [disabled]=\"isInvalid()\"\r\n color=\"primary\">\r\n {{ locale(Texts, action) }}\r\n </ngx-sirio-button>\r\n </ng-template>\r\n <ng-template #closeTemplate let-action=\"action\">\r\n <ngx-sirio-button (clickEvent)=\"doAction(action)\"\r\n color=\"secondary\">\r\n {{ locale(Texts, action) }}\r\n </ngx-sirio-button>\r\n </ng-template>\r\n\r\n </ngx-sirio-dialog-footer>\r\n\r\n</ngx-sirio-dialog>\r\n", styles: ["::ng-deep .sirio-dialog{background-color:#0000007f!important}::ng-deep .sirio-drawer .sirio-dialog .sirio-dialog-sm .sirio-dialog-content{max-width:18.75rem}::ng-deep .sirio-drawer .sirio-dialog .sirio-dialog-lg .sirio-dialog-content{max-width:50rem}::ng-deep .sirio-drawer .sirio-dialog .sirio-dialog-xl .sirio-dialog-content{max-width:71.25rem}\n"] }]
|
|
106
|
+
], changeDetection: ChangeDetectionStrategy.OnPush, template: "<ngx-sirio-dialog (closeEvent)=\"doClose()\"\r\n dialog\r\n [type]=\"options.type ?? 'info'\"\r\n [size]=\"options.size ?? 'default'\"\r\n [isDrawer]=\"options.isDrawer ?? false\"\r\n [withCloseButton]=\"showCloseButton()\">\r\n\r\n <ngx-sirio-dialog-header [hidden]=\"!showHeader()\">\r\n <ngx-sirio-dialog-title [hidden]=\"!showTitle()\">{{ options.title }}</ngx-sirio-dialog-title>\r\n </ngx-sirio-dialog-header>\r\n\r\n <ngx-sirio-dialog-body>\r\n <ng-template #formHost></ng-template>\r\n </ngx-sirio-dialog-body>\r\n\r\n <ngx-sirio-dialog-footer *ngIf=\"showFooter()\">\r\n <ng-container [ngSwitch]=\"options.buttons\">\r\n <!-- OK -->\r\n <ng-container *ngSwitchCase=\"'OK'\">\r\n <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'OK' }\"></ng-container>\r\n </ng-container>\r\n <!-- Caso: OKCancel -->\r\n <ng-container *ngSwitchCase=\"'OKCancel'\">\r\n <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'OK' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Cancel' }\"></ng-container>\r\n </ng-container>\r\n <!-- Caso: ConfirmClose -->\r\n <ng-container *ngSwitchCase=\"'ConfirmCancel'\">\r\n <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'Confirm' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Cancel' }\"></ng-container>\r\n </ng-container>\r\n <!-- Caso: AbortRetryIgnore -->\r\n <ng-container *ngSwitchCase=\"'AbortRetryIgnore'\">\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Abort' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'Retry' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Ignore' }\"></ng-container>\r\n </ng-container>\r\n <!-- Caso: YesNoCancel -->\r\n <ng-container *ngSwitchCase=\"'YesNoCancel'\">\r\n <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'Yes' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'No' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Cancel' }\"></ng-container>\r\n </ng-container>\r\n <!-- Caso: YesNo -->\r\n <ng-container *ngSwitchCase=\"'YesNo'\">\r\n <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'Yes' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'No' }\"></ng-container>\r\n </ng-container>\r\n <!-- Caso: RetryCancel -->\r\n <ng-container *ngSwitchCase=\"'RetryCancel'\">\r\n <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'Retry' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Cancel' }\"></ng-container>\r\n </ng-container>\r\n <!-- Caso: CancelTryContinue -->\r\n <ng-container *ngSwitchCase=\"'CancelTryContinue'\">\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Cancel' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'Try' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Continue' }\"></ng-container>\r\n </ng-container>\r\n <!-- Caso: Custom -->\r\n <ng-container *ngSwitchCase=\"'Custom'\">\r\n <ng-container *ngFor=\"let customButton of options.customButtons ?? []; let i = index\">\r\n <ng-container *ngTemplateOutlet=\"customTemplate; context: { customButton: customButton }\"></ng-container>\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n <!-- Templates -->\r\n <ng-template #confirmTemplate let-action=\"action\">\r\n <ngx-sirio-button (clickEvent)=\"doAction(action)\"\r\n [disabled]=\"isInvalid()\"\r\n color=\"primary\">\r\n {{ locale(Texts, action) }}\r\n </ngx-sirio-button>\r\n </ng-template>\r\n <ng-template #closeTemplate let-action=\"action\">\r\n <ngx-sirio-button (clickEvent)=\"doAction(action)\"\r\n color=\"secondary\">\r\n {{ locale(Texts, action) }}\r\n </ngx-sirio-button>\r\n </ng-template>\r\n <ng-template #customTemplate\n let-customButton=\"customButton\">\r\n <ngx-sirio-button (clickEvent)=\"doAction(customButton.action)\"\r\n [color]=\"customButton.color\">\r\n {{ customButton.text }}\r\n </ngx-sirio-button>\r\n </ng-template>\r\n\r\n </ngx-sirio-dialog-footer>\r\n\r\n</ngx-sirio-dialog>\r\n", styles: ["::ng-deep .sirio-dialog{background-color:#0000007f!important}::ng-deep .sirio-drawer .sirio-dialog .sirio-dialog-sm .sirio-dialog-content{max-width:18.75rem}::ng-deep .sirio-drawer .sirio-dialog .sirio-dialog-lg .sirio-dialog-content{max-width:50rem}::ng-deep .sirio-drawer .sirio-dialog .sirio-dialog-xl .sirio-dialog-content{max-width:71.25rem}\n"] }]
|
|
106
107
|
}], ctorParameters: () => [{ type: i1.LanguageService }], propDecorators: { formHost: [{
|
|
107
108
|
type: ViewChild,
|
|
108
109
|
args: ['formHost', { read: ViewContainerRef, static: true }]
|
|
109
110
|
}] } });
|
|
110
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dialog.component.js","sourceRoot":"","sources":["../../../../../projects/ngx-sirio/src/lib/dialog/dialog.component.ts","../../../../../projects/ngx-sirio/src/lib/dialog/dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component, ChangeDetectionStrategy, ViewContainerRef, ViewChild, ComponentRef, Type\r\n} from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport { Subject, takeUntil } from 'rxjs';\r\nimport { FormDialogOptions, DialogAction, DialogResult } from '../services/dialog.service';\r\nimport { DialogDirective } from '../directives/dialog.directive';\r\nimport {\r\n  SirioDialogComponent, SirioDialogBodyComponent, SirioDialogHeaderComponent\r\n  , SirioDialogFooterComponent, SirioButtonComponent, SirioDialogActionDirective\r\n  , SirioDialogTitleComponent, SirioDialogElement\r\n} from 'ngx-sirio-lib';\r\n\r\nimport { LanguageService } from '@wemake4u/interact';\r\nimport { Texts } from '../locale/locale';\r\nimport { localize } from '../locale/localize';\r\n\r\n@Component({\r\n  selector: 'dynamic-dialog',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    DialogDirective,\r\n    SirioDialogComponent,\r\n    SirioDialogBodyComponent,\r\n    SirioDialogHeaderComponent,\r\n    SirioDialogFooterComponent,\r\n    SirioButtonComponent,\r\n    SirioDialogActionDirective,\r\n    SirioDialogTitleComponent    \r\n  ],\r\n  templateUrl: './dialog.component.html',\r\n  styleUrl: './dialog.component.css',\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class DialogComponent extends SirioDialogElement {\r\n  @ViewChild('formHost', { read: ViewContainerRef, static: true })\r\n  private formHost!: ViewContainerRef;\r\n  private formRef!: ComponentRef<any>\r\n  private dynamicFormType!: Type<any>;\r\n  Texts = Texts;\r\n\r\n  constructor(private languageService: LanguageService) {\r\n    super();\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.options = this.data.options ?? {};\r\n    this.currentValue = this.options.value;\r\n    this.dynamicFormType = this.data.dynamicFormType;\r\n  }\r\n\r\n  options: FormDialogOptions = { };\r\n  \r\n  ngAfterViewInit() {\r\n\r\n    let injector = this.options.injector\r\n      ?? this.formHost.injector;\r\n\r\n    const componentRef = this.formHost.createComponent(this.dynamicFormType, { injector });\r\n    const instance = componentRef.instance as any;\r\n\r\n    componentRef.setInput('schema', this.data.formSchema);\r\n    componentRef.setInput('value', this.options.value ?? { });\r\n    componentRef.setInput('showNav', this.options.showNav ?? false);\r\n    componentRef.setInput('showNavButton', this.options.showNavButton ?? false);\r\n    componentRef.setInput('showProgress', this.options.showProgress ?? false);\r\n    componentRef.setInput('showFormTitle', this.options.showFormTitle ?? false);\r\n\r\n    instance.valueChange\r\n      .pipe(takeUntil(this.destroy$))\r\n      .subscribe((value: any) => this.setCurrentValue(value));\r\n\r\n    this.formRef = componentRef;\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.destroy$.next();\r\n    this.destroy$.complete();\r\n  }\r\n\r\n  doClose() {\r\n    this.doAction('Close');\r\n  }\r\n\r\n  doAction(action: DialogAction) {\r\n    this.sirioDialogService.closeDialog();\r\n    this.SendResult(action);    \r\n  }\r\n\r\n  showHeader(): boolean {\r\n    return this.showTitle() || this.showCloseButton();    \r\n  }\r\n\r\n  showTitle(): boolean {\r\n    return this.options.title ? true: false;\r\n  }\r\n\r\n  showCloseButton(): boolean {\r\n    const result = this.options.closeButton === true;\r\n    return result;\r\n  }\r\n\r\n  showFooter(): boolean {\r\n    return this.options.buttons !== undefined;\r\n  }\r\n\r\n  isInvalid(): boolean {\r\n    return (this.formRef?.instance?.formGroup?.valid ?? true) !== true;\r\n  }\r\n\r\n  locale(component: any, key: string): string {\r\n    return localize(this.language, component, key);\r\n  }\r\n\r\n  private destroy$ = new Subject<void>();\r\n\r\n  private currentValue: any;\r\n\r\n  private setCurrentValue(value: any): void {\r\n    this.currentValue = value;\r\n  }\r\n\r\n  private get language(): string {\r\n    return this.languageService.getLanguage();\r\n  }\r\n\r\n  private SendResult(action: DialogAction) {\r\n    if (typeof this.options.onResult === 'function') {\r\n      const result: DialogResult = {\r\n        action: action,\r\n        value: this.currentValue\r\n      };\r\n      this.options.onResult(result);\r\n    }\r\n  }\r\n}\r\n","<ngx-sirio-dialog (closeEvent)=\"doClose()\"\r\n                  dialog\r\n                  [type]=\"options.type ?? 'info'\"\r\n                  [size]=\"options.size ?? 'default'\"\r\n                  [isDrawer]=\"options.isDrawer ?? false\"\r\n                  [withCloseButton]=\"showCloseButton()\">\r\n\r\n  <ngx-sirio-dialog-header [hidden]=\"!showHeader()\">\r\n    <ngx-sirio-dialog-title [hidden]=\"!showTitle()\">{{ options.title }}</ngx-sirio-dialog-title>\r\n  </ngx-sirio-dialog-header>\r\n\r\n  <ngx-sirio-dialog-body>\r\n    <ng-template #formHost></ng-template>\r\n  </ngx-sirio-dialog-body>\r\n\r\n  <ngx-sirio-dialog-footer *ngIf=\"showFooter()\">\r\n    <ng-container [ngSwitch]=\"options.buttons\">\r\n      <!-- OK -->\r\n      <ng-container *ngSwitchCase=\"'OK'\">\r\n        <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'OK' }\"></ng-container>\r\n      </ng-container>\r\n      <!-- Caso: OKCancel -->\r\n      <ng-container *ngSwitchCase=\"'OKCancel'\">\r\n        <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'OK' }\"></ng-container>\r\n        <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Cancel' }\"></ng-container>\r\n      </ng-container>\r\n      <!-- Caso: ConfirmClose -->\r\n      <ng-container *ngSwitchCase=\"'ConfirmCancel'\">\r\n        <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'Confirm' }\"></ng-container>\r\n        <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Cancel' }\"></ng-container>\r\n      </ng-container>\r\n      <!-- Caso: AbortRetryIgnore -->\r\n      <ng-container *ngSwitchCase=\"'AbortRetryIgnore'\">\r\n        <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Abort' }\"></ng-container>\r\n        <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'Retry' }\"></ng-container>\r\n        <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Ignore' }\"></ng-container>\r\n      </ng-container>\r\n      <!-- Caso: YesNoCancel -->\r\n      <ng-container *ngSwitchCase=\"'YesNoCancel'\">\r\n        <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'Yes' }\"></ng-container>\r\n        <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'No' }\"></ng-container>\r\n        <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Cancel' }\"></ng-container>\r\n      </ng-container>\r\n      <!-- Caso: YesNo -->\r\n      <ng-container *ngSwitchCase=\"'YesNo'\">\r\n        <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'Yes' }\"></ng-container>\r\n        <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'No' }\"></ng-container>\r\n      </ng-container>\r\n      <!-- Caso: RetryCancel -->\r\n      <ng-container *ngSwitchCase=\"'RetryCancel'\">\r\n        <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'Retry' }\"></ng-container>\r\n        <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Cancel' }\"></ng-container>\r\n      </ng-container>\r\n      <!-- Caso: CancelTryContinue -->\r\n      <ng-container *ngSwitchCase=\"'CancelTryContinue'\">\r\n        <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Cancel' }\"></ng-container>\r\n        <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'Try' }\"></ng-container>\r\n        <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Continue' }\"></ng-container>\r\n      </ng-container>\r\n    </ng-container>\r\n    <!-- Templates -->\r\n    <ng-template #confirmTemplate let-action=\"action\">\r\n      <ngx-sirio-button (clickEvent)=\"doAction(action)\"\r\n                        [disabled]=\"isInvalid()\"\r\n                        color=\"primary\">\r\n        {{ locale(Texts, action) }}\r\n      </ngx-sirio-button>\r\n    </ng-template>\r\n    <ng-template #closeTemplate let-action=\"action\">\r\n      <ngx-sirio-button (clickEvent)=\"doAction(action)\"\r\n                        color=\"secondary\">\r\n        {{ locale(Texts, action) }}\r\n      </ngx-sirio-button>\r\n    </ng-template>\r\n\r\n  </ngx-sirio-dialog-footer>\r\n\r\n</ngx-sirio-dialog>\r\n"]}
|
|
111
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dialog.component.js","sourceRoot":"","sources":["../../../../../projects/ngx-sirio/src/lib/dialog/dialog.component.ts","../../../../../projects/ngx-sirio/src/lib/dialog/dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component, ChangeDetectionStrategy, ViewContainerRef, ViewChild, ComponentRef, Type\r\n} from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport { Subject, takeUntil } from 'rxjs';\r\nimport { FormDialogOptions, DialogAction, DialogResult } from '../services/dialog.service';\r\nimport { DialogDirective } from '../directives/dialog.directive';\r\nimport {\r\n  SirioDialogComponent, SirioDialogBodyComponent, SirioDialogHeaderComponent\r\n  , SirioDialogFooterComponent, SirioButtonComponent, SirioDialogActionDirective\r\n  , SirioDialogTitleComponent, SirioDialogElement\r\n} from 'ngx-sirio-lib';\r\n\r\nimport { LanguageService } from '@wemake4u/interact';\r\nimport { Texts } from '../locale/locale';\r\nimport { localize } from '../locale/localize';\r\n\r\n@Component({\r\n  selector: 'dynamic-dialog',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    DialogDirective,\r\n    SirioDialogComponent,\r\n    SirioDialogBodyComponent,\r\n    SirioDialogHeaderComponent,\r\n    SirioDialogFooterComponent,\r\n    SirioButtonComponent,\r\n    SirioDialogActionDirective,\r\n    SirioDialogTitleComponent    \r\n  ],\r\n  templateUrl: './dialog.component.html',\r\n  styleUrl: './dialog.component.css',\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class DialogComponent extends SirioDialogElement {\r\n  @ViewChild('formHost', { read: ViewContainerRef, static: true })\r\n  private formHost!: ViewContainerRef;\r\n  private formRef!: ComponentRef<any>\r\n  private dynamicFormType!: Type<any>;\r\n  Texts = Texts;\r\n\r\n  constructor(private languageService: LanguageService) {\r\n    super();\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.options = this.data.options ?? {};\r\n    this.currentValue = this.options.value;\r\n    this.dynamicFormType = this.data.dynamicFormType;\r\n  }\r\n\r\n  options: FormDialogOptions = { };\r\n  \r\n  ngAfterViewInit() {\r\n\r\n    let injector = this.options.injector\r\n      ?? this.formHost.injector;\r\n\r\n    const componentRef = this.formHost.createComponent(this.dynamicFormType, { injector });\r\n    const instance = componentRef.instance as any;\r\n\r\n    componentRef.setInput('schema', this.data.formSchema);\r\n    componentRef.setInput('value', this.options.value ?? { });\r\n    componentRef.setInput('showNav', this.options.showNav ?? false);\r\n    componentRef.setInput('showNavButton', this.options.showNavButton ?? false);\r\n    componentRef.setInput('showProgress', this.options.showProgress ?? false);\r\n    componentRef.setInput('showFormTitle', this.options.showFormTitle ?? false);\r\n\r\n    instance.valueChange\r\n      .pipe(takeUntil(this.destroy$))\r\n      .subscribe((value: any) => this.setCurrentValue(value));\r\n\r\n    this.formRef = componentRef;\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.destroy$.next();\r\n    this.destroy$.complete();\r\n  }\r\n\r\n  doClose() {\r\n    this.doAction('Close');\r\n  }\r\n\r\n  doAction(action: DialogAction) {\r\n    if (this.options.keepOpen !== true)\r\n      this.sirioDialogService.closeDialog();\r\n    this.SendResult(action);    \r\n  }\r\n\r\n  showHeader(): boolean {\r\n    return this.showTitle() || this.showCloseButton();    \r\n  }\r\n\r\n  showTitle(): boolean {\r\n    return this.options.title ? true: false;\r\n  }\r\n\r\n  showCloseButton(): boolean {\r\n    const result = this.options.closeButton === true;\r\n    return result;\r\n  }\r\n\r\n  showFooter(): boolean {\r\n    return this.options.buttons !== undefined;\r\n  }\r\n\r\n  isInvalid(): boolean {\r\n    return (this.formRef?.instance?.formGroup?.valid ?? true) !== true;\r\n  }\r\n\r\n  locale(component: any, key: string): string {\r\n    return localize(this.language, component, key);\r\n  }\r\n\r\n  private destroy$ = new Subject<void>();\r\n\r\n  private currentValue: any;\r\n\r\n  private setCurrentValue(value: any): void {\r\n    this.currentValue = value;\r\n  }\r\n\r\n  private get language(): string {\r\n    return this.languageService.getLanguage();\r\n  }\r\n\r\n  private SendResult(action: DialogAction) {\r\n    if (typeof this.options.onResult === 'function') {\r\n      const result: DialogResult = {\r\n        action: action,\r\n        value: this.currentValue\r\n      };\r\n      this.options.onResult(result);\r\n    }\r\n  }\r\n}\r\n","<ngx-sirio-dialog (closeEvent)=\"doClose()\"\r\n                  dialog\r\n                  [type]=\"options.type ?? 'info'\"\r\n                  [size]=\"options.size ?? 'default'\"\r\n                  [isDrawer]=\"options.isDrawer ?? false\"\r\n                  [withCloseButton]=\"showCloseButton()\">\r\n\r\n  <ngx-sirio-dialog-header [hidden]=\"!showHeader()\">\r\n    <ngx-sirio-dialog-title [hidden]=\"!showTitle()\">{{ options.title }}</ngx-sirio-dialog-title>\r\n  </ngx-sirio-dialog-header>\r\n\r\n  <ngx-sirio-dialog-body>\r\n    <ng-template #formHost></ng-template>\r\n  </ngx-sirio-dialog-body>\r\n\r\n  <ngx-sirio-dialog-footer *ngIf=\"showFooter()\">\r\n    <ng-container [ngSwitch]=\"options.buttons\">\r\n      <!-- OK -->\r\n      <ng-container *ngSwitchCase=\"'OK'\">\r\n        <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'OK' }\"></ng-container>\r\n      </ng-container>\r\n      <!-- Caso: OKCancel -->\r\n      <ng-container *ngSwitchCase=\"'OKCancel'\">\r\n        <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'OK' }\"></ng-container>\r\n        <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Cancel' }\"></ng-container>\r\n      </ng-container>\r\n      <!-- Caso: ConfirmClose -->\r\n      <ng-container *ngSwitchCase=\"'ConfirmCancel'\">\r\n        <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'Confirm' }\"></ng-container>\r\n        <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Cancel' }\"></ng-container>\r\n      </ng-container>\r\n      <!-- Caso: AbortRetryIgnore -->\r\n      <ng-container *ngSwitchCase=\"'AbortRetryIgnore'\">\r\n        <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Abort' }\"></ng-container>\r\n        <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'Retry' }\"></ng-container>\r\n        <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Ignore' }\"></ng-container>\r\n      </ng-container>\r\n      <!-- Caso: YesNoCancel -->\r\n      <ng-container *ngSwitchCase=\"'YesNoCancel'\">\r\n        <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'Yes' }\"></ng-container>\r\n        <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'No' }\"></ng-container>\r\n        <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Cancel' }\"></ng-container>\r\n      </ng-container>\r\n      <!-- Caso: YesNo -->\r\n      <ng-container *ngSwitchCase=\"'YesNo'\">\r\n        <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'Yes' }\"></ng-container>\r\n        <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'No' }\"></ng-container>\r\n      </ng-container>\r\n      <!-- Caso: RetryCancel -->\r\n      <ng-container *ngSwitchCase=\"'RetryCancel'\">\r\n        <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'Retry' }\"></ng-container>\r\n        <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Cancel' }\"></ng-container>\r\n      </ng-container>\r\n      <!-- Caso: CancelTryContinue -->\r\n      <ng-container *ngSwitchCase=\"'CancelTryContinue'\">\r\n        <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Cancel' }\"></ng-container>\r\n        <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'Try' }\"></ng-container>\r\n        <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Continue' }\"></ng-container>\r\n      </ng-container>\r\n      <!-- Caso: Custom -->\r\n      <ng-container *ngSwitchCase=\"'Custom'\">\r\n        <ng-container *ngFor=\"let customButton of options.customButtons ?? []; let i = index\">\r\n          <ng-container *ngTemplateOutlet=\"customTemplate; context: { customButton: customButton }\"></ng-container>\r\n        </ng-container>\r\n      </ng-container>\r\n    </ng-container>\r\n    <!-- Templates -->\r\n    <ng-template #confirmTemplate let-action=\"action\">\r\n      <ngx-sirio-button (clickEvent)=\"doAction(action)\"\r\n                        [disabled]=\"isInvalid()\"\r\n                        color=\"primary\">\r\n        {{ locale(Texts, action) }}\r\n      </ngx-sirio-button>\r\n    </ng-template>\r\n    <ng-template #closeTemplate let-action=\"action\">\r\n      <ngx-sirio-button (clickEvent)=\"doAction(action)\"\r\n                        color=\"secondary\">\r\n        {{ locale(Texts, action) }}\r\n      </ngx-sirio-button>\r\n    </ng-template>\r\n    <ng-template #customTemplate\n                 let-customButton=\"customButton\">\r\n      <ngx-sirio-button (clickEvent)=\"doAction(customButton.action)\"\r\n                        [color]=\"customButton.color\">\r\n        {{ customButton.text }}\r\n      </ngx-sirio-button>\r\n    </ng-template>\r\n\r\n  </ngx-sirio-dialog-footer>\r\n\r\n</ngx-sirio-dialog>\r\n"]}
|