@wemake4u/form-player-se 1.0.39 → 1.0.40
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 +24 -0
- package/esm2022/lib/builtIn/console.json +253 -0
- package/esm2022/lib/builtIn/dialog.json +109 -0
- package/esm2022/lib/builtIn/feel.json +26 -0
- package/esm2022/lib/builtIn/form.json +172 -0
- package/esm2022/lib/builtIn/formGroup.json +218 -0
- package/esm2022/lib/builtIn/formatter.json +112 -0
- package/esm2022/lib/builtIn/function.json +53 -0
- package/esm2022/lib/builtIn/register.json +14 -0
- package/esm2022/lib/components/setFilter/setFilter.component.mjs +18 -3
- package/esm2022/lib/directives/accordionpanel.directive.mjs +10 -5
- package/esm2022/lib/directives/collapse.directive.mjs +22 -12
- package/esm2022/lib/directives/collapsepatch.directive.mjs +2 -1
- package/esm2022/lib/directives/datetime.directive.mjs +18 -21
- package/esm2022/lib/directives/dropdown.directive.mjs +31 -16
- package/esm2022/lib/directives/grid.directive.mjs +10 -8
- package/esm2022/lib/directives/readonly.directive.mjs +10 -9
- package/esm2022/lib/directives/register.directive.mjs +8 -10
- package/esm2022/lib/directives/required.directive.mjs +57 -0
- package/esm2022/lib/directives/tabcontrol.directive.mjs +10 -9
- package/esm2022/lib/dynamic-fields/dynamic-fields.component.mjs +20 -4
- package/esm2022/lib/dynamic-form/dynamic-form.component.mjs +43 -21
- package/esm2022/lib/dynamic-host/dynamic-host.component.mjs +32 -10
- package/esm2022/lib/services/event.service.mjs +17 -6
- package/esm2022/lib/services/grid.service.mjs +4 -1
- package/esm2022/lib/services/listener.service.mjs +23 -0
- package/esm2022/lib/services/programmability.service.mjs +54 -38
- package/esm2022/lib/services/status.service.mjs +10 -5
- package/esm2022/lib/services/subscribe.service.mjs +54 -0
- package/esm2022/lib/services/validation.service.mjs +11 -2
- package/esm2022/lib/utils/deepEqual.mjs +46 -0
- package/esm2022/lib/utils/observable.mjs +7 -0
- package/esm2022/lib/utils/proxy.mjs +28 -1
- package/esm2022/lib/utils/resolveRefs.mjs +67 -0
- package/esm2022/public-api.mjs +5 -1
- package/fesm2022/wemake4u-form-player-se.mjs +1573 -175
- package/fesm2022/wemake4u-form-player-se.mjs.map +1 -1
- package/lib/builtIn/builtIn.d.ts +32 -0
- package/lib/components/setFilter/setFilter.component.d.ts +1 -0
- package/lib/directives/accordionpanel.directive.d.ts +4 -2
- package/lib/directives/collapse.directive.d.ts +5 -3
- package/lib/directives/datetime.directive.d.ts +7 -8
- package/lib/directives/dropdown.directive.d.ts +6 -3
- package/lib/directives/grid.directive.d.ts +4 -3
- package/lib/directives/readonly.directive.d.ts +3 -4
- package/lib/directives/register.directive.d.ts +3 -3
- package/lib/directives/required.directive.d.ts +17 -0
- package/lib/directives/tabcontrol.directive.d.ts +5 -6
- package/lib/dynamic-fields/dynamic-fields.component.d.ts +1 -0
- package/lib/dynamic-form/dynamic-form.component.d.ts +4 -1
- package/lib/dynamic-host/dynamic-host.component.d.ts +6 -2
- package/lib/services/event.service.d.ts +8 -2
- package/lib/services/listener.service.d.ts +11 -0
- package/lib/services/programmability.service.d.ts +8 -9
- package/lib/services/status.service.d.ts +5 -1
- package/lib/services/subscribe.service.d.ts +14 -0
- package/lib/services/validation.service.d.ts +5 -2
- package/lib/utils/deepEqual.d.ts +1 -0
- package/lib/utils/observable.d.ts +2 -0
- package/lib/utils/proxy.d.ts +2 -0
- package/lib/utils/resolveRefs.d.ts +12 -0
- package/package.json +1 -1
- package/public-api.d.ts +4 -0
|
@@ -0,0 +1,218 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "formGroup",
|
|
3
|
+
"detail": "Form",
|
|
4
|
+
"info": "Tracks the value and validity state of a group of FormControl instances.\n\n---\n\n### Description\n\nA FormGroup aggregates the values and validation status of multiple child controls and allows managing them as a single unit.\n\n---\n\n### Examples\n\n```ts\nconst form = new FormGroup({\n name: new FormControl(''),\n age: new FormControl(0)\n});\n```",
|
|
5
|
+
"entries": [
|
|
6
|
+
{
|
|
7
|
+
"name": "get",
|
|
8
|
+
"type": "function",
|
|
9
|
+
"detail": "Returns a child control given its path",
|
|
10
|
+
"info": "Returns a child control identified by the given path.\n\n---\n\n### Function signature\n\n```\nget(path: string | (string | number)[]): AbstractControl | null\n```\n\n---\n\n### Examples\n\n```ts\nform.get('name');\nform.get(['address', 'street']);\n```",
|
|
11
|
+
"params": [
|
|
12
|
+
{
|
|
13
|
+
"name": "path",
|
|
14
|
+
"type": "string | (string | number)[]"
|
|
15
|
+
}
|
|
16
|
+
]
|
|
17
|
+
},
|
|
18
|
+
{
|
|
19
|
+
"name": "setValue",
|
|
20
|
+
"type": "function",
|
|
21
|
+
"detail": "Sets the value of the FormGroup",
|
|
22
|
+
"info": "Sets the value of the entire FormGroup.\n\n---\n\n### Function signature\n\n```\nsetValue(value: object, options?: object): void\n```\n\n---\n\n### Examples\n\n```ts\nform.setValue({ name: 'Mario', age: 30 });\n```",
|
|
23
|
+
"params": [
|
|
24
|
+
{
|
|
25
|
+
"name": "value",
|
|
26
|
+
"type": "object"
|
|
27
|
+
},
|
|
28
|
+
{
|
|
29
|
+
"name": "options",
|
|
30
|
+
"type": "object",
|
|
31
|
+
"optional": true
|
|
32
|
+
}
|
|
33
|
+
]
|
|
34
|
+
},
|
|
35
|
+
{
|
|
36
|
+
"name": "patchValue",
|
|
37
|
+
"type": "function",
|
|
38
|
+
"detail": "Patches the value of the FormGroup",
|
|
39
|
+
"info": "Updates one or more values of the FormGroup without affecting other controls.\n\n---\n\n### Function signature\n\n```\npatchValue(value: object, options?: object): void\n```\n\n---\n\n### Examples\n\n```ts\nform.patchValue({ name: 'Luigi' });\n```",
|
|
40
|
+
"params": [
|
|
41
|
+
{
|
|
42
|
+
"name": "value",
|
|
43
|
+
"type": "object"
|
|
44
|
+
},
|
|
45
|
+
{
|
|
46
|
+
"name": "options",
|
|
47
|
+
"type": "object",
|
|
48
|
+
"optional": true
|
|
49
|
+
}
|
|
50
|
+
]
|
|
51
|
+
},
|
|
52
|
+
{
|
|
53
|
+
"name": "reset",
|
|
54
|
+
"type": "function",
|
|
55
|
+
"detail": "Resets the FormGroup",
|
|
56
|
+
"info": "Resets the FormGroup to an initial or provided state.\n\n---\n\n### Function signature\n\n```\nreset(value?: object, options?: object): void\n```\n\n---\n\n### Examples\n\n```ts\nform.reset();\nform.reset({ name: 'Anna', age: 25 });\n```",
|
|
57
|
+
"params": [
|
|
58
|
+
{
|
|
59
|
+
"name": "value",
|
|
60
|
+
"type": "object",
|
|
61
|
+
"optional": true
|
|
62
|
+
},
|
|
63
|
+
{
|
|
64
|
+
"name": "options",
|
|
65
|
+
"type": "object",
|
|
66
|
+
"optional": true
|
|
67
|
+
}
|
|
68
|
+
]
|
|
69
|
+
},
|
|
70
|
+
{
|
|
71
|
+
"name": "addControl",
|
|
72
|
+
"type": "function",
|
|
73
|
+
"detail": "Adds a new control to the group",
|
|
74
|
+
"info": "Adds a new control to the FormGroup.\n\n---\n\n### Function signature\n\n```\naddControl(name: string, control: AbstractControl): void\n```\n\n---\n\n### Examples\n\n```ts\nform.addControl('email', new FormControl(''));\n```",
|
|
75
|
+
"params": [
|
|
76
|
+
{
|
|
77
|
+
"name": "name",
|
|
78
|
+
"type": "string"
|
|
79
|
+
},
|
|
80
|
+
{
|
|
81
|
+
"name": "control",
|
|
82
|
+
"type": "AbstractControl"
|
|
83
|
+
}
|
|
84
|
+
]
|
|
85
|
+
},
|
|
86
|
+
{
|
|
87
|
+
"name": "removeControl",
|
|
88
|
+
"type": "function",
|
|
89
|
+
"detail": "Removes an existing control from the group",
|
|
90
|
+
"info": "Removes a control from the FormGroup.\n\n---\n\n### Function signature\n\n```\nremoveControl(name: string): void\n```\n\n---\n\n### Examples\n\n```ts\nform.removeControl('age');\n```",
|
|
91
|
+
"params": [
|
|
92
|
+
{
|
|
93
|
+
"name": "name",
|
|
94
|
+
"type": "string"
|
|
95
|
+
}
|
|
96
|
+
]
|
|
97
|
+
},
|
|
98
|
+
{
|
|
99
|
+
"name": "contains",
|
|
100
|
+
"type": "function",
|
|
101
|
+
"detail": "Checks if the group contains a control",
|
|
102
|
+
"info": "Checks whether a control with the given name exists in the FormGroup.\n\n---\n\n### Function signature\n\n```\ncontains(controlName: string): boolean\n```\n\n---\n\n### Examples\n\n```ts\nform.contains('name'); // true\n```",
|
|
103
|
+
"params": [
|
|
104
|
+
{
|
|
105
|
+
"name": "controlName",
|
|
106
|
+
"type": "string"
|
|
107
|
+
}
|
|
108
|
+
]
|
|
109
|
+
},
|
|
110
|
+
{
|
|
111
|
+
"name": "setControl",
|
|
112
|
+
"type": "function",
|
|
113
|
+
"detail": "Replaces an existing control",
|
|
114
|
+
"info": "Replaces an existing control with a new one.\n\n---\n\n### Function signature\n\n```\nsetControl(name: string, control: AbstractControl): void\n```\n\n---\n\n### Examples\n\n```ts\nform.setControl('name', new FormControl('Giulia'));\n```",
|
|
115
|
+
"params": [
|
|
116
|
+
{
|
|
117
|
+
"name": "name",
|
|
118
|
+
"type": "string"
|
|
119
|
+
},
|
|
120
|
+
{
|
|
121
|
+
"name": "control",
|
|
122
|
+
"type": "AbstractControl"
|
|
123
|
+
}
|
|
124
|
+
]
|
|
125
|
+
},
|
|
126
|
+
{
|
|
127
|
+
"name": "markAsTouched",
|
|
128
|
+
"type": "function",
|
|
129
|
+
"detail": "",
|
|
130
|
+
"info": "Marks all controls in the FormGroup as touched.\n\n---\n\n### Function signature\n\n```\nmarkAsTouched(options?: object): void\n```\n\n---\n\n### Examples\n\n```ts\nform.markAsTouched();\n```",
|
|
131
|
+
"params": [
|
|
132
|
+
{
|
|
133
|
+
"name": "options",
|
|
134
|
+
"type": "object",
|
|
135
|
+
"optional": true
|
|
136
|
+
}
|
|
137
|
+
]
|
|
138
|
+
},
|
|
139
|
+
{
|
|
140
|
+
"name": "markAsUntouched",
|
|
141
|
+
"type": "function",
|
|
142
|
+
"detail": "",
|
|
143
|
+
"info": "Marks all controls in the FormGroup as untouched.\n\n---\n\n### Function signature\n\n```\nmarkAsUntouched(options?: object): void\n```\n\n---\n\n### Examples\n\n```ts\nform.markAsUntouched();\n```",
|
|
144
|
+
"params": [
|
|
145
|
+
{
|
|
146
|
+
"name": "options",
|
|
147
|
+
"type": "object",
|
|
148
|
+
"optional": true
|
|
149
|
+
}
|
|
150
|
+
]
|
|
151
|
+
},
|
|
152
|
+
{
|
|
153
|
+
"name": "markAsDirty",
|
|
154
|
+
"type": "function",
|
|
155
|
+
"detail": "",
|
|
156
|
+
"info": "Marks all controls in the FormGroup as dirty.\n\n---\n\n### Function signature\n\n```\nmarkAsDirty(options?: object): void\n```\n\n---\n\n### Examples\n\n```ts\nform.markAsDirty();\n```",
|
|
157
|
+
"params": [
|
|
158
|
+
{
|
|
159
|
+
"name": "options",
|
|
160
|
+
"type": "object",
|
|
161
|
+
"optional": true
|
|
162
|
+
}
|
|
163
|
+
]
|
|
164
|
+
},
|
|
165
|
+
{
|
|
166
|
+
"name": "markAsPristine",
|
|
167
|
+
"type": "function",
|
|
168
|
+
"detail": "",
|
|
169
|
+
"info": "Marks all controls in the FormGroup as pristine.\n\n---\n\n### Function signature\n\n```\nmarkAsPristine(options?: object): void\n```\n\n---\n\n### Examples\n\n```ts\nform.markAsPristine();\n```",
|
|
170
|
+
"params": [
|
|
171
|
+
{
|
|
172
|
+
"name": "options",
|
|
173
|
+
"type": "object",
|
|
174
|
+
"optional": true
|
|
175
|
+
}
|
|
176
|
+
]
|
|
177
|
+
},
|
|
178
|
+
{
|
|
179
|
+
"name": "disable",
|
|
180
|
+
"type": "function",
|
|
181
|
+
"detail": "Disables the control",
|
|
182
|
+
"info": "Disables the FormGroup and all its child controls.\n\n---\n\n### Function signature\n\n```\ndisable(options?: object): void\n```\n\n---\n\n### Examples\n\n```ts\nform.disable();\n```",
|
|
183
|
+
"params": [
|
|
184
|
+
{
|
|
185
|
+
"name": "options",
|
|
186
|
+
"type": "object",
|
|
187
|
+
"optional": true
|
|
188
|
+
}
|
|
189
|
+
]
|
|
190
|
+
},
|
|
191
|
+
{
|
|
192
|
+
"name": "enable",
|
|
193
|
+
"type": "function",
|
|
194
|
+
"detail": "Enables the control",
|
|
195
|
+
"info": "Enables the FormGroup and all its child controls.\n\n---\n\n### Function signature\n\n```\nenable(options?: object): void\n```\n\n---\n\n### Examples\n\n```ts\nform.enable();\n```",
|
|
196
|
+
"params": [
|
|
197
|
+
{
|
|
198
|
+
"name": "options",
|
|
199
|
+
"type": "object",
|
|
200
|
+
"optional": true
|
|
201
|
+
}
|
|
202
|
+
]
|
|
203
|
+
},
|
|
204
|
+
{
|
|
205
|
+
"name": "updateValueAndValidity",
|
|
206
|
+
"type": "function",
|
|
207
|
+
"detail": "Recalculates the value and validation status",
|
|
208
|
+
"info": "Recalculates the value and validation status of the FormGroup.\n\n---\n\n### Function signature\n\n```\nupdateValueAndValidity(options?: object): void\n```\n\n---\n\n### Examples\n\n```ts\nform.updateValueAndValidity();\n```",
|
|
209
|
+
"params": [
|
|
210
|
+
{
|
|
211
|
+
"name": "options",
|
|
212
|
+
"type": "object",
|
|
213
|
+
"optional": true
|
|
214
|
+
}
|
|
215
|
+
]
|
|
216
|
+
}
|
|
217
|
+
]
|
|
218
|
+
}
|
|
@@ -0,0 +1,112 @@
|
|
|
1
|
+
[
|
|
2
|
+
{
|
|
3
|
+
"name": "formatDate",
|
|
4
|
+
"type": "function",
|
|
5
|
+
"detail": "Formats a date value",
|
|
6
|
+
"info": "Formats an ISO date string into a localized date representation.\n\n---\n\n### Function signature\n\n```\nformatDate(isoDate: string | null | undefined, options?: Intl.DateTimeFormatOptions, locale?: string): string\n```\n\n---\n\n### Examples\n\n```feel\nformatDate(\"2024-01-15\")\n// \"15/01/2024\"\n\nformatDate(\"2024-01-15\", { month: \"long\" })\n// \"15 gennaio 2024\"\n\nformatDate(null)\n// \"\"\n```",
|
|
7
|
+
"params": [
|
|
8
|
+
{
|
|
9
|
+
"name": "isoDate",
|
|
10
|
+
"type": "string | null | undefined"
|
|
11
|
+
},
|
|
12
|
+
{
|
|
13
|
+
"name": "options",
|
|
14
|
+
"type": "Intl.DateTimeFormatOptions",
|
|
15
|
+
"optional": true
|
|
16
|
+
},
|
|
17
|
+
{
|
|
18
|
+
"name": "locale",
|
|
19
|
+
"type": "string",
|
|
20
|
+
"optional": true
|
|
21
|
+
}
|
|
22
|
+
]
|
|
23
|
+
},
|
|
24
|
+
{
|
|
25
|
+
"name": "formatTime",
|
|
26
|
+
"type": "function",
|
|
27
|
+
"detail": "Formats a time value",
|
|
28
|
+
"info": "Formats an ISO date string into a localized time representation using a 24-hour clock.\n\n---\n\n### Function signature\n\n```\nformatTime(isoDate: string | null | undefined, options?: Intl.DateTimeFormatOptions, locale?: string): string\n```\n\n---\n\n### Examples\n\n```feel\nformatTime(\"2024-01-15T14:30:45\")\n// \"14:30:45\"\n\nformatTime(\"2024-01-15T14:30:45\", { second: undefined })\n// \"14:30\"\n```",
|
|
29
|
+
"params": [
|
|
30
|
+
{
|
|
31
|
+
"name": "isoDate",
|
|
32
|
+
"type": "string | null | undefined"
|
|
33
|
+
},
|
|
34
|
+
{
|
|
35
|
+
"name": "options",
|
|
36
|
+
"type": "Intl.DateTimeFormatOptions",
|
|
37
|
+
"optional": true
|
|
38
|
+
},
|
|
39
|
+
{
|
|
40
|
+
"name": "locale",
|
|
41
|
+
"type": "string",
|
|
42
|
+
"optional": true
|
|
43
|
+
}
|
|
44
|
+
]
|
|
45
|
+
},
|
|
46
|
+
{
|
|
47
|
+
"name": "formatDateTime",
|
|
48
|
+
"type": "function",
|
|
49
|
+
"detail": "Formats a date and time value",
|
|
50
|
+
"info": "Formats an ISO date string into a localized date and time representation.\n\n---\n\n### Function signature\n\n```\nformatDateTime(isoDate: string | null | undefined, options?: Intl.DateTimeFormatOptions, locale?: string): string\n```\n\n---\n\n### Examples\n\n```feel\nformatDateTime(\"2024-01-15T14:30:45\")\n// \"15/01/2024 14:30:45\"\n```",
|
|
51
|
+
"params": [
|
|
52
|
+
{
|
|
53
|
+
"name": "isoDate",
|
|
54
|
+
"type": "string | null | undefined"
|
|
55
|
+
},
|
|
56
|
+
{
|
|
57
|
+
"name": "options",
|
|
58
|
+
"type": "Intl.DateTimeFormatOptions",
|
|
59
|
+
"optional": true
|
|
60
|
+
},
|
|
61
|
+
{
|
|
62
|
+
"name": "locale",
|
|
63
|
+
"type": "string",
|
|
64
|
+
"optional": true
|
|
65
|
+
}
|
|
66
|
+
]
|
|
67
|
+
},
|
|
68
|
+
{
|
|
69
|
+
"name": "formatCurrency",
|
|
70
|
+
"type": "function",
|
|
71
|
+
"detail": "Formats a currency value",
|
|
72
|
+
"info": "Formats a numeric value as a localized currency string.\n\n---\n\n### Function signature\n\n```\nformatCurrency(value: number, currency?: string, locale?: string): string\n```\n\n---\n\n### Examples\n\n```feel\nformatCurrency(1234.5)\n// \"€ 1.234,50\"\n\nformatCurrency(1234.5, \"USD\", \"en-US\")\n// \"$1,234.50\"\n```",
|
|
73
|
+
"params": [
|
|
74
|
+
{
|
|
75
|
+
"name": "value",
|
|
76
|
+
"type": "number"
|
|
77
|
+
},
|
|
78
|
+
{
|
|
79
|
+
"name": "currency",
|
|
80
|
+
"type": "string",
|
|
81
|
+
"optional": true
|
|
82
|
+
},
|
|
83
|
+
{
|
|
84
|
+
"name": "locale",
|
|
85
|
+
"type": "string",
|
|
86
|
+
"optional": true
|
|
87
|
+
}
|
|
88
|
+
]
|
|
89
|
+
},
|
|
90
|
+
{
|
|
91
|
+
"name": "formatNumber",
|
|
92
|
+
"type": "function",
|
|
93
|
+
"detail": "Formats a numeric value",
|
|
94
|
+
"info": "Formats a numeric value using localized decimal formatting and a fixed number of decimal places.\n\n---\n\n### Function signature\n\n```\nformatNumber(value: number, decimals?: number, locale?: string): string\n```\n\n---\n\n### Examples\n\n```feel\nformatNumber(1234.567)\n// \"1.234,57\"\n\nformatNumber(1234.5, 0)\n// \"1.235\"\n\nformatNumber(1234.5, 3, \"en-US\")\n// \"1,234.500\"\n```",
|
|
95
|
+
"params": [
|
|
96
|
+
{
|
|
97
|
+
"name": "value",
|
|
98
|
+
"type": "number"
|
|
99
|
+
},
|
|
100
|
+
{
|
|
101
|
+
"name": "decimals",
|
|
102
|
+
"type": "number",
|
|
103
|
+
"optional": true
|
|
104
|
+
},
|
|
105
|
+
{
|
|
106
|
+
"name": "locale",
|
|
107
|
+
"type": "string",
|
|
108
|
+
"optional": true
|
|
109
|
+
}
|
|
110
|
+
]
|
|
111
|
+
}
|
|
112
|
+
]
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
[
|
|
2
|
+
{
|
|
3
|
+
"name": "invokable",
|
|
4
|
+
"type": "function",
|
|
5
|
+
"detail": "Wraps an invokable object into a function",
|
|
6
|
+
"info": "Wraps an object exposing an `invoke` method into a callable function.\n\n---\n\n### Function signature\n\n```\ninvokable(func: any): Function\n```\n\n---\n\n### Notes\n\nIf the provided object does not expose an `invoke` method, a no-op function is returned.\n\n---\n\n### Examples\n\n```ts\nconst fn = {\n invoke: (args: any[]) => console.log(args)\n};\n\nconst wrapped = invokable(fn);\nwrapped(1, 2, 3);\n```",
|
|
7
|
+
"params": [
|
|
8
|
+
{
|
|
9
|
+
"name": "func",
|
|
10
|
+
"type": "any"
|
|
11
|
+
}
|
|
12
|
+
]
|
|
13
|
+
},
|
|
14
|
+
{
|
|
15
|
+
"name": "executeOnce",
|
|
16
|
+
"type": "function",
|
|
17
|
+
"detail": "Executes a callback once on an observable",
|
|
18
|
+
"info": "Executes a callback when the first value is emitted by an observable.\n\n---\n\n### Function signature\n\n```\nexecuteOnce<T>(observable: Observable<T>, callback: any): void\n```\n\n---\n\n### Notes\n\nThe observable is automatically completed after the first emitted value using `take(1)`.\n\n---\n\n### Examples\n\n```ts\nexecuteOnce(userLoaded$, {\n invoke: user => console.log(user)\n});\n```",
|
|
19
|
+
"params": [
|
|
20
|
+
{
|
|
21
|
+
"name": "observable",
|
|
22
|
+
"type": "Observable<any>"
|
|
23
|
+
},
|
|
24
|
+
{
|
|
25
|
+
"name": "callback",
|
|
26
|
+
"type": "any"
|
|
27
|
+
}
|
|
28
|
+
]
|
|
29
|
+
},
|
|
30
|
+
{
|
|
31
|
+
"name": "openForm",
|
|
32
|
+
"type": "function",
|
|
33
|
+
"detail": "Opens a form dialog",
|
|
34
|
+
"info": "Opens a dialog using a form template or a form schema object.\n\n---\n\n### Function signature\n\n```\nopenForm(template: string | object, options: DialogOptions): void\n```\n\n---\n\n### Notes\n\nIf a template name is provided, the form schema is resolved through metadata. Dependency injection is applied to the dialog context.\n\n---\n\n### Examples\n\n```ts\nopenForm(\"userForm\", {\n title: \"Edit user\"\n});\n```\n\n```ts\nopenForm({ forms: [] }, {\n title: \"Custom form\",\n buttons: \"OKCancel\"\n});\n```",
|
|
35
|
+
"params": [
|
|
36
|
+
{
|
|
37
|
+
"name": "template",
|
|
38
|
+
"type": "string | object"
|
|
39
|
+
},
|
|
40
|
+
{
|
|
41
|
+
"name": "options",
|
|
42
|
+
"type": "DialogOptions"
|
|
43
|
+
}
|
|
44
|
+
]
|
|
45
|
+
},
|
|
46
|
+
{
|
|
47
|
+
"name": "newGuid",
|
|
48
|
+
"type": "function",
|
|
49
|
+
"detail": "Generates a new unique identifier",
|
|
50
|
+
"info": "Generates and returns a new globally unique identifier.\n\n---\n\n### Function signature\n\n```\nnewGuid(): string\n```\n\n---\n\n### Examples\n\n```ts\nconst id = newGuid();\n// \"550e8400-e29b-41d4-a716-446655440000\"\n```",
|
|
51
|
+
"params": []
|
|
52
|
+
}
|
|
53
|
+
]
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
[
|
|
2
|
+
{
|
|
3
|
+
"name": "control",
|
|
4
|
+
"type": "function",
|
|
5
|
+
"detail": "Returns a form control by name",
|
|
6
|
+
"info": "Returns the form control associated with the provided control name.\n\n---\n\n### Function signature\n\n```\ncontrol(name: string): Control | null\n```\n\n---\n\n### Notes\n\nThe control is resolved from the local registry. If not found, the lookup continues in parent scopes. A name starting with `\"../\"` explicitly resolves the control from the parent scope.\n\n---\n\n### Examples\n\n```ts\ncontrol(\"username\")\n```\n\n```ts\ncontrol(\"address\")\n```\n\n```ts\n// Resolve control from parent scope\ncontrol(\"../total\")\n```\n\n```ts\n// Returns null if not found\ncontrol(\"unknown\")\n```",
|
|
7
|
+
"params": [
|
|
8
|
+
{
|
|
9
|
+
"name": "name",
|
|
10
|
+
"type": "string"
|
|
11
|
+
}
|
|
12
|
+
]
|
|
13
|
+
}
|
|
14
|
+
]
|
|
@@ -52,15 +52,16 @@ export class SetFilterComponent {
|
|
|
52
52
|
type: 'excludeAll'
|
|
53
53
|
};
|
|
54
54
|
}
|
|
55
|
+
const filterType = this.getFilterType();
|
|
55
56
|
const filters = selectedValues.map(value => ({
|
|
56
|
-
filterType:
|
|
57
|
+
filterType: filterType,
|
|
57
58
|
type: 'equals',
|
|
58
59
|
filter: value
|
|
59
60
|
}));
|
|
60
61
|
if (filters.length === 1)
|
|
61
62
|
return filters[0];
|
|
62
63
|
return {
|
|
63
|
-
filterType:
|
|
64
|
+
filterType: filterType,
|
|
64
65
|
operator: 'OR',
|
|
65
66
|
conditions: filters
|
|
66
67
|
};
|
|
@@ -99,6 +100,20 @@ export class SetFilterComponent {
|
|
|
99
100
|
resolvePath(obj, path) {
|
|
100
101
|
return path.split('.').reduce((acc, part) => acc?.[part], obj);
|
|
101
102
|
}
|
|
103
|
+
getFilterType() {
|
|
104
|
+
const cellDataType = this.params?.colDef?.cellDataType;
|
|
105
|
+
switch (cellDataType) {
|
|
106
|
+
case 'number':
|
|
107
|
+
return 'number';
|
|
108
|
+
case 'date':
|
|
109
|
+
case 'dateTime':
|
|
110
|
+
return 'date';
|
|
111
|
+
case 'text':
|
|
112
|
+
return 'text';
|
|
113
|
+
default:
|
|
114
|
+
return 'number';
|
|
115
|
+
}
|
|
116
|
+
}
|
|
102
117
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: SetFilterComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
103
118
|
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.14", type: SetFilterComponent, isStandalone: true, selector: "ng-component", ngImport: i0, template: "<div style=\"padding: 5px;background-color: white;\">\r\n\r\n <div style=\"padding: 5px\">\r\n <ngx-sirio-input type=\"text\"\r\n [placeholder]=\"Texts.TypeToSearch\"\r\n [(ngModel)]=\"searchText\"\r\n (ngModelChange)=\"onSearchChange()\">\r\n </ngx-sirio-input>\r\n </div>\r\n\r\n <div style=\"padding: 5px; max-height: 200px; overflow-y: auto;\">\r\n <ngx-sirio-checkbox [(ngModel)]=\"selectAll\" (ngModelChange)=\"onSelectAllChange()\">{{Texts.SelectAll}}</ngx-sirio-checkbox>\r\n\r\n <ngx-sirio-checkbox-group>\r\n <ngx-sirio-checkbox *ngFor=\"let option of filteredOptions\"\r\n [(ngModel)]=\"option.selected\"\r\n [value]=\"option.value\"\r\n (change)=\"onSelectionChange()\">\r\n {{ option.label }}\r\n </ngx-sirio-checkbox>\r\n </ngx-sirio-checkbox-group>\r\n </div>\r\n\r\n</div>\r\n", dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: SirioInputComponent, selector: "ngx-sirio-input", inputs: ["disabledState", "value", "label", "labelPopover", "ariaLabelPopoverButton", "type", "name", "placeholder", "textHelp", "textFeedback", "rows", "cols", "ariaLabel", "ariaAutocomplete", "ariaInvalid", "ariaDescribedBy", "role"], outputs: ["focusEvent", "inputEvent", "blurEvent", "keyupEvent", "keydownEvent"] }, { kind: "component", type: SirioCheckboxComponent, selector: "ngx-sirio-checkbox", inputs: ["disabled", "name", "textHelp", "textFeedback", "value", "ariaInvalid", "ariaDescribedBy", "disabledState", "checked"], outputs: ["focusEvent", "blurEvent", "changeEvent"] }, { kind: "component", type: SirioCheckboxGroupComponent, selector: "ngx-sirio-checkbox-group", inputs: ["textHelp", "textFeedback", "label", "labelPopover", "ariaLabelPopoverButton", "ariaLabel", "ariaInvalid", "ariaDescribedBy", "disabledState", "value"], outputs: ["focusEvent", "blurEvent", "changeEvent"] }] });
|
|
104
119
|
}
|
|
@@ -108,4 +123,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
|
|
|
108
123
|
SirioCheckboxComponent, SirioCheckboxGroupComponent,
|
|
109
124
|
SirioButtonComponent], template: "<div style=\"padding: 5px;background-color: white;\">\r\n\r\n <div style=\"padding: 5px\">\r\n <ngx-sirio-input type=\"text\"\r\n [placeholder]=\"Texts.TypeToSearch\"\r\n [(ngModel)]=\"searchText\"\r\n (ngModelChange)=\"onSearchChange()\">\r\n </ngx-sirio-input>\r\n </div>\r\n\r\n <div style=\"padding: 5px; max-height: 200px; overflow-y: auto;\">\r\n <ngx-sirio-checkbox [(ngModel)]=\"selectAll\" (ngModelChange)=\"onSelectAllChange()\">{{Texts.SelectAll}}</ngx-sirio-checkbox>\r\n\r\n <ngx-sirio-checkbox-group>\r\n <ngx-sirio-checkbox *ngFor=\"let option of filteredOptions\"\r\n [(ngModel)]=\"option.selected\"\r\n [value]=\"option.value\"\r\n (change)=\"onSelectionChange()\">\r\n {{ option.label }}\r\n </ngx-sirio-checkbox>\r\n </ngx-sirio-checkbox-group>\r\n </div>\r\n\r\n</div>\r\n" }]
|
|
110
125
|
}] });
|
|
111
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"setFilter.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-sirio/src/lib/components/setFilter/setFilter.component.ts","../../../../../../projects/ngx-sirio/src/lib/components/setFilter/setfilter.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component } from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport { FormsModule } from '@angular/forms';\r\nimport { IFilterParams, IDoesFilterPassParams } from 'ag-grid-community';\r\nimport { IFilterAngularComp } from '@ag-grid-community/angular';\r\nimport { SirioInputComponent, SirioCheckboxGroupComponent, SirioCheckboxComponent, SirioButtonComponent } from 'ngx-sirio-lib';\r\nimport { isRecord } from '../../common/record';\r\nimport { Texts } from '../../locale/locale-it';\r\n\r\n@Component({\r\n  templateUrl: './setfilter.component.html',\r\n  standalone: true,\r\n  imports: [CommonModule, FormsModule, SirioInputComponent\r\n    , SirioCheckboxComponent, SirioCheckboxGroupComponent\r\n    , SirioButtonComponent],  \r\n})\r\nexport class SetFilterComponent implements IFilterAngularComp {\r\n  private params!: IFilterParams;\r\n  private fieldName!: string;\r\n\r\n  Texts = Texts;\r\n\r\n  selectAll: boolean = true;\r\n  searchText: string = '';\r\n\r\n  options: { value: any; label: string; selected: boolean }[] = [];\r\n  filteredOptions: typeof this.options = [];\r\n\r\n  agInit(params: IFilterParams): void {\r\n    this.params = params;\r\n    this.fieldName = params.colDef.field!;\r\n\r\n    const map = params.colDef.filterParams?.map;\r\n\r\n    const result = isRecord(\r\n      map,\r\n      key => typeof key === 'string' || typeof key === 'number',\r\n      val => typeof val === 'string'\r\n    );\r\n\r\n    if (result) {\r\n      this.options = Object.entries(map).map(([key, label]) => ({\r\n        value: this.parseKey(key),\r\n        label: label,\r\n        selected: true\r\n      }));\r\n    }\r\n    else {\r\n      this.options = [];\r\n    }\r\n    \r\n    this.filteredOptions = [...this.options];\r\n  }\r\n\r\n  isFilterActive(): boolean {\r\n    return this.options.some(o => !o.selected);\r\n  }\r\n\r\n  doesFilterPass(params: IDoesFilterPassParams): boolean {\r\n    const value = this.resolvePath(params.data, this.fieldName);\r\n    return this.options.some(o => o.selected && o.value === value);\r\n  }\r\n\r\n  getModel() {\r\n    const selectedValues = this.options\r\n      .filter(o => o.selected)\r\n      .map(o => o.value);\r\n\r\n    if (selectedValues.length === this.options.length) { \r\n      return null;\r\n    }\r\n\r\n    if (selectedValues.length === 0) {\r\n      return {\r\n        filterType: 'text',\r\n        type: 'excludeAll'\r\n      }\r\n    }\r\n\r\n    const filters = selectedValues.map(value => ({\r\n      filterType: 'number',\r\n      type: 'equals',\r\n      filter: value\r\n    }));\r\n\r\n    if (filters.length === 1)\r\n      return filters[0];\r\n\r\n    return {\r\n      filterType: 'number',\r\n      operator: 'OR',\r\n      conditions: filters\r\n    }\r\n  }\r\n\r\n  setModel(model: any): void {\r\n    const selected = model?.values ?? this.options.map(o => o.value);\r\n    this.options.forEach(o => o.selected = selected.includes(o.value));\r\n    this.updateFilteredOptions();\r\n  }\r\n\r\n  onSelectionChange(): void {\r\n    this.params.filterChangedCallback();\r\n  }\r\n\r\n  onSearchChange(): void {\r\n    this.updateFilteredOptions();\r\n  }\r\n\r\n  onSelectAllChange(): void {    \r\n    this.setAll(this.selectAll);\r\n  }\r\n\r\n  private parseKey(key: string): boolean | number | string {\r\n    if (key === 'true') return true;\r\n    if (key === 'false') return false;\r\n    const num = Number(key);\r\n    return isNaN(num) ? key : num;\r\n  }\r\n\r\n  private setAll(select: boolean): void {\r\n    this.options.forEach(o => o.selected = select);\r\n    this.updateFilteredOptions();\r\n    this.params.filterChangedCallback();\r\n  }\r\n\r\n  private updateFilteredOptions(): void {\r\n    const search = this.searchText.toLowerCase();\r\n    this.filteredOptions = this.options.filter(o =>\r\n      o.label.toLowerCase().includes(search)\r\n    );\r\n  }\r\n\r\n  private resolvePath(obj: any, path: string): any {\r\n    return path.split('.').reduce((acc, part) => acc?.[part], obj);\r\n  }\r\n}\r\n","<div style=\"padding: 5px;background-color: white;\">\r\n\r\n  <div style=\"padding: 5px\">\r\n    <ngx-sirio-input type=\"text\"\r\n                     [placeholder]=\"Texts.TypeToSearch\"\r\n                     [(ngModel)]=\"searchText\"\r\n                     (ngModelChange)=\"onSearchChange()\">\r\n    </ngx-sirio-input>\r\n  </div>\r\n\r\n  <div style=\"padding: 5px; max-height: 200px; overflow-y: auto;\">\r\n    <ngx-sirio-checkbox [(ngModel)]=\"selectAll\" (ngModelChange)=\"onSelectAllChange()\">{{Texts.SelectAll}}</ngx-sirio-checkbox>\r\n\r\n    <ngx-sirio-checkbox-group>\r\n      <ngx-sirio-checkbox *ngFor=\"let option of filteredOptions\"\r\n                          [(ngModel)]=\"option.selected\"\r\n                          [value]=\"option.value\"\r\n                          (change)=\"onSelectionChange()\">\r\n        {{ option.label }}\r\n      </ngx-sirio-checkbox>\r\n    </ngx-sirio-checkbox-group>\r\n  </div>\r\n\r\n</div>\r\n"]}
|
|
126
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"setFilter.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-sirio/src/lib/components/setFilter/setFilter.component.ts","../../../../../../projects/ngx-sirio/src/lib/components/setFilter/setfilter.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component } from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport { FormsModule } from '@angular/forms';\r\nimport { IFilterParams, IDoesFilterPassParams } from 'ag-grid-community';\r\nimport { IFilterAngularComp } from '@ag-grid-community/angular';\r\nimport { SirioInputComponent, SirioCheckboxGroupComponent, SirioCheckboxComponent, SirioButtonComponent } from 'ngx-sirio-lib';\r\nimport { isRecord } from '../../common/record';\r\nimport { Texts } from '../../locale/locale-it';\r\n\r\n@Component({\r\n  templateUrl: './setfilter.component.html',\r\n  standalone: true,\r\n  imports: [CommonModule, FormsModule, SirioInputComponent\r\n    , SirioCheckboxComponent, SirioCheckboxGroupComponent\r\n    , SirioButtonComponent],  \r\n})\r\nexport class SetFilterComponent implements IFilterAngularComp {\r\n  private params!: IFilterParams;\r\n  private fieldName!: string;\r\n\r\n  Texts = Texts;\r\n\r\n  selectAll: boolean = true;\r\n  searchText: string = '';\r\n\r\n  options: { value: any; label: string; selected: boolean }[] = [];\r\n  filteredOptions: typeof this.options = [];\r\n\r\n  agInit(params: IFilterParams): void {\r\n    this.params = params;\r\n    this.fieldName = params.colDef.field!;\r\n\r\n    const map = params.colDef.filterParams?.map;\r\n\r\n    const result = isRecord(\r\n      map,\r\n      key => typeof key === 'string' || typeof key === 'number',\r\n      val => typeof val === 'string'\r\n    );\r\n\r\n    if (result) {\r\n      this.options = Object.entries(map).map(([key, label]) => ({\r\n        value: this.parseKey(key),\r\n        label: label,\r\n        selected: true\r\n      }));\r\n    }\r\n    else {\r\n      this.options = [];\r\n    }\r\n    \r\n    this.filteredOptions = [...this.options];\r\n  }\r\n\r\n  isFilterActive(): boolean {\r\n    return this.options.some(o => !o.selected);\r\n  }\r\n\r\n  doesFilterPass(params: IDoesFilterPassParams): boolean {\r\n    const value = this.resolvePath(params.data, this.fieldName);\r\n    return this.options.some(o => o.selected && o.value === value);\r\n  }\r\n\r\n  getModel() {\r\n    const selectedValues = this.options\r\n      .filter(o => o.selected)\r\n      .map(o => o.value);\r\n\r\n    if (selectedValues.length === this.options.length) { \r\n      return null;\r\n    }\r\n\r\n    if (selectedValues.length === 0) {\r\n      return {\r\n        filterType: 'text',\r\n        type: 'excludeAll'\r\n      }\r\n    }\r\n\r\n    const filterType = this.getFilterType();\r\n\r\n    const filters = selectedValues.map(value => ({\r\n      filterType: filterType,\r\n      type: 'equals',\r\n      filter: value\r\n    }));\r\n\r\n    if (filters.length === 1)\r\n      return filters[0];\r\n\r\n    return {\r\n      filterType: filterType,\r\n      operator: 'OR',\r\n      conditions: filters\r\n    }\r\n  }\r\n\r\n  setModel(model: any): void {\r\n    const selected = model?.values ?? this.options.map(o => o.value);\r\n    this.options.forEach(o => o.selected = selected.includes(o.value));\r\n    this.updateFilteredOptions();\r\n  }\r\n\r\n  onSelectionChange(): void {\r\n    this.params.filterChangedCallback();\r\n  }\r\n\r\n  onSearchChange(): void {\r\n    this.updateFilteredOptions();\r\n  }\r\n\r\n  onSelectAllChange(): void {    \r\n    this.setAll(this.selectAll);\r\n  }\r\n\r\n  private parseKey(key: string): boolean | number | string {\r\n    if (key === 'true') return true;\r\n    if (key === 'false') return false;\r\n    const num = Number(key);\r\n    return isNaN(num) ? key : num;\r\n  }\r\n\r\n  private setAll(select: boolean): void {\r\n    this.options.forEach(o => o.selected = select);\r\n    this.updateFilteredOptions();\r\n    this.params.filterChangedCallback();\r\n  }\r\n\r\n  private updateFilteredOptions(): void {\r\n    const search = this.searchText.toLowerCase();\r\n    this.filteredOptions = this.options.filter(o =>\r\n      o.label.toLowerCase().includes(search)\r\n    );\r\n  }\r\n\r\n  private resolvePath(obj: any, path: string): any {\r\n    return path.split('.').reduce((acc, part) => acc?.[part], obj);\r\n  }\r\n\r\n  private getFilterType() {\r\n    const cellDataType = this.params?.colDef?.cellDataType;\r\n\r\n    switch (cellDataType) {\r\n      case 'number':\r\n        return 'number';\r\n      case 'date':\r\n      case 'dateTime':\r\n        return 'date';\r\n      case 'text':\r\n        return 'text';\r\n      default:\r\n        return 'number';\r\n    }\r\n    \r\n  }\r\n}\r\n","<div style=\"padding: 5px;background-color: white;\">\r\n\r\n  <div style=\"padding: 5px\">\r\n    <ngx-sirio-input type=\"text\"\r\n                     [placeholder]=\"Texts.TypeToSearch\"\r\n                     [(ngModel)]=\"searchText\"\r\n                     (ngModelChange)=\"onSearchChange()\">\r\n    </ngx-sirio-input>\r\n  </div>\r\n\r\n  <div style=\"padding: 5px; max-height: 200px; overflow-y: auto;\">\r\n    <ngx-sirio-checkbox [(ngModel)]=\"selectAll\" (ngModelChange)=\"onSelectAllChange()\">{{Texts.SelectAll}}</ngx-sirio-checkbox>\r\n\r\n    <ngx-sirio-checkbox-group>\r\n      <ngx-sirio-checkbox *ngFor=\"let option of filteredOptions\"\r\n                          [(ngModel)]=\"option.selected\"\r\n                          [value]=\"option.value\"\r\n                          (change)=\"onSelectionChange()\">\r\n        {{ option.label }}\r\n      </ngx-sirio-checkbox>\r\n    </ngx-sirio-checkbox-group>\r\n  </div>\r\n\r\n</div>\r\n"]}
|
|
@@ -1,9 +1,14 @@
|
|
|
1
1
|
import { Directive, Host } from '@angular/core';
|
|
2
|
+
import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
|
|
2
3
|
import * as i0 from "@angular/core";
|
|
3
4
|
import * as i1 from "ngx-sirio-lib";
|
|
4
5
|
export class AccordionPanelDirective {
|
|
5
|
-
|
|
6
|
-
|
|
6
|
+
destroyRef;
|
|
7
|
+
constructor(panel, destroyRef) {
|
|
8
|
+
this.destroyRef = destroyRef;
|
|
9
|
+
panel.opened
|
|
10
|
+
.pipe(takeUntilDestroyed(this.destroyRef))
|
|
11
|
+
.subscribe((event) => {
|
|
7
12
|
const element = event.component.body.el.nativeElement;
|
|
8
13
|
// delay height calculation to allow for DOM updates
|
|
9
14
|
setTimeout(() => {
|
|
@@ -13,7 +18,7 @@ export class AccordionPanelDirective {
|
|
|
13
18
|
}, 0);
|
|
14
19
|
});
|
|
15
20
|
}
|
|
16
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: AccordionPanelDirective, deps: [{ token: i1.SirioAccordionPanelComponent, host: true }], target: i0.ɵɵFactoryTarget.Directive });
|
|
21
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: AccordionPanelDirective, deps: [{ token: i1.SirioAccordionPanelComponent, host: true }, { token: i0.DestroyRef }], target: i0.ɵɵFactoryTarget.Directive });
|
|
17
22
|
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.14", type: AccordionPanelDirective, isStandalone: true, selector: "[accordionPanel]", ngImport: i0 });
|
|
18
23
|
}
|
|
19
24
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: AccordionPanelDirective, decorators: [{
|
|
@@ -24,5 +29,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
|
|
|
24
29
|
}]
|
|
25
30
|
}], ctorParameters: () => [{ type: i1.SirioAccordionPanelComponent, decorators: [{
|
|
26
31
|
type: Host
|
|
27
|
-
}] }] });
|
|
28
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
32
|
+
}] }, { type: i0.DestroyRef }] });
|
|
33
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWNjb3JkaW9ucGFuZWwuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LXNpcmlvL3NyYy9saWIvZGlyZWN0aXZlcy9hY2NvcmRpb25wYW5lbC5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFjLFNBQVMsRUFBRSxJQUFJLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDNUQsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sNEJBQTRCLENBQUM7OztBQU9oRSxNQUFNLE9BQU8sdUJBQXVCO0lBSXhCO0lBRlYsWUFDVSxLQUFtQyxFQUNuQyxVQUFzQjtRQUF0QixlQUFVLEdBQVYsVUFBVSxDQUFZO1FBRTlCLEtBQUssQ0FBQyxNQUFNO2FBQ1QsSUFBSSxDQUFDLGtCQUFrQixDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsQ0FBQzthQUN6QyxTQUFTLENBQUMsQ0FBQyxLQUFrRCxFQUFFLEVBQUU7WUFDbEUsTUFBTSxPQUFPLEdBQUksS0FBSyxDQUFDLFNBQVMsQ0FBQyxJQUFZLENBQUMsRUFBRSxDQUFDLGFBQWEsQ0FBQztZQUMvRCxvREFBb0Q7WUFDcEQsVUFBVSxDQUFDLEdBQUcsRUFBRTtnQkFDZCw0Q0FBNEM7Z0JBQzVDLDZDQUE2QztnQkFDN0MsT0FBTyxDQUFDLEtBQUssQ0FBQyxNQUFNLEdBQUcsRUFBRSxDQUFDO1lBQzVCLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQztRQUNSLENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQzt3R0FqQlUsdUJBQXVCOzRGQUF2Qix1QkFBdUI7OzRGQUF2Qix1QkFBdUI7a0JBSm5DLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLGtCQUFrQjtvQkFDNUIsVUFBVSxFQUFFLElBQUk7aUJBQ2pCOzswQkFJSSxJQUFJIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGVzdHJveVJlZiwgRGlyZWN0aXZlLCBIb3N0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IHRha2VVbnRpbERlc3Ryb3llZCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUvcnhqcy1pbnRlcm9wJztcclxuaW1wb3J0IHsgU2lyaW9BY2NvcmRpb25QYW5lbENvbXBvbmVudCwgTmd4U2lyaW9FdmVudCB9IGZyb20gJ25neC1zaXJpby1saWInO1xyXG5cclxuQERpcmVjdGl2ZSh7XHJcbiAgc2VsZWN0b3I6ICdbYWNjb3JkaW9uUGFuZWxdJyxcclxuICBzdGFuZGFsb25lOiB0cnVlXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBBY2NvcmRpb25QYW5lbERpcmVjdGl2ZSB7XHJcblxyXG4gIGNvbnN0cnVjdG9yKFxyXG4gICAgQEhvc3QoKSBwYW5lbDogU2lyaW9BY2NvcmRpb25QYW5lbENvbXBvbmVudCxcclxuICAgIHByaXZhdGUgZGVzdHJveVJlZjogRGVzdHJveVJlZlxyXG4gICkge1xyXG4gICAgcGFuZWwub3BlbmVkXHJcbiAgICAgIC5waXBlKHRha2VVbnRpbERlc3Ryb3llZCh0aGlzLmRlc3Ryb3lSZWYpKVxyXG4gICAgICAuc3Vic2NyaWJlKChldmVudDogTmd4U2lyaW9FdmVudDxTaXJpb0FjY29yZGlvblBhbmVsQ29tcG9uZW50PikgPT4ge1xyXG4gICAgICBjb25zdCBlbGVtZW50ID0gKGV2ZW50LmNvbXBvbmVudC5ib2R5IGFzIGFueSkuZWwubmF0aXZlRWxlbWVudDtcclxuICAgICAgLy8gZGVsYXkgaGVpZ2h0IGNhbGN1bGF0aW9uIHRvIGFsbG93IGZvciBET00gdXBkYXRlc1xyXG4gICAgICBzZXRUaW1lb3V0KCgpID0+IHtcclxuICAgICAgICAvL2NvbnN0IHNjcm9sbEhlaWdodCA9IGVsZW1lbnQuc2Nyb2xsSGVpZ2h0O1xyXG4gICAgICAgIC8vZWxlbWVudC5zdHlsZS5oZWlnaHQgPSBgJHtzY3JvbGxIZWlnaHR9cHhgO1xyXG4gICAgICAgIGVsZW1lbnQuc3R5bGUuaGVpZ2h0ID0gJyc7XHJcbiAgICAgIH0sIDApO1xyXG4gICAgfSk7ICAgIFxyXG4gIH1cclxufVxyXG4iXX0=
|