@agorapulse/ui-components 18.0.34 → 18.0.36

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (25) hide show
  1. package/agorapulse-ui-components-18.0.36.tgz +0 -0
  2. package/checkbox/checkbox.component.d.ts +2 -1
  3. package/directives/checkbox.directive.d.ts +60 -0
  4. package/directives/public_api.d.ts +1 -0
  5. package/esm2022/checkbox/checkbox.component.mjs +11 -4
  6. package/esm2022/directives/checkbox.directive.mjs +442 -0
  7. package/esm2022/directives/public_api.mjs +2 -1
  8. package/esm2022/index.mjs +2 -2
  9. package/esm2022/nav-selector/nav-selector-category/nav-selector-category.component.mjs +3 -3
  10. package/esm2022/nav-selector/nav-selector-group/nav-selector-group.component.mjs +3 -3
  11. package/esm2022/nav-selector/nav-selector-leaf/nav-selector-leaf.component.mjs +3 -3
  12. package/esm2022/nav-selector/nav-selector-leaf-details/nav-selector-leaf-details.component.mjs +3 -3
  13. package/esm2022/nav-selector/utils/nav-selector.filter.mjs +2 -2
  14. package/esm2022/nav-selector/utils/nav-selector.merger.mjs +2 -2
  15. package/fesm2022/agorapulse-ui-components-checkbox.mjs +10 -3
  16. package/fesm2022/agorapulse-ui-components-checkbox.mjs.map +1 -1
  17. package/fesm2022/agorapulse-ui-components-directives.mjs +442 -3
  18. package/fesm2022/agorapulse-ui-components-directives.mjs.map +1 -1
  19. package/fesm2022/agorapulse-ui-components-nav-selector.mjs +10 -10
  20. package/fesm2022/agorapulse-ui-components-nav-selector.mjs.map +1 -1
  21. package/fesm2022/agorapulse-ui-components.mjs +1 -1
  22. package/fesm2022/agorapulse-ui-components.mjs.map +1 -1
  23. package/index.d.ts +1 -1
  24. package/package.json +7 -7
  25. package/agorapulse-ui-components-18.0.34.tgz +0 -0
@@ -0,0 +1,442 @@
1
+ import { apCheck, SymbolComponent, SymbolRegistry } from '@agorapulse/ui-symbol';
2
+ import { booleanAttribute, Directive, ElementRef, EventEmitter, forwardRef, inject, Input, Output, Renderer2, ViewContainerRef, } from '@angular/core';
3
+ import { NG_VALIDATORS, NG_VALUE_ACCESSOR } from '@angular/forms';
4
+ import * as i0 from "@angular/core";
5
+ export const AP_CHECKBOX_DIRECTIVE_CONTROL_VALUE_ACCESSOR = {
6
+ provide: NG_VALUE_ACCESSOR,
7
+ useExisting: forwardRef(() => CheckboxDirective),
8
+ multi: true,
9
+ };
10
+ /*
11
+ Host bindings is important here:
12
+ - This provides encapsulation and reactivity regardless of how the directive is used in templates.
13
+ - It guarantees that properties like checked, disabled, required, and ARIA attributes always reflect
14
+ only the directive's logic, not just consumer bindings.
15
+ - So we need to have host bindings for all the properties that we want to control.
16
+ - We could also use @HostListener.
17
+ */
18
+ export class CheckboxDirective {
19
+ symbolRegistry = inject(SymbolRegistry);
20
+ elementRef = inject((ElementRef));
21
+ renderer = inject(Renderer2);
22
+ viewContainer = inject(ViewContainerRef);
23
+ ariaLabel;
24
+ ariaLabelledby;
25
+ ariaDescribedby;
26
+ disabled = false;
27
+ set indeterminate(indeterminate) {
28
+ if (indeterminate) {
29
+ this._checked = false;
30
+ }
31
+ this._indeterminate = indeterminate;
32
+ const input = this.elementRef.nativeElement;
33
+ if (input) {
34
+ input.indeterminate = indeterminate;
35
+ }
36
+ // Only update visibility if containers are ready
37
+ if (this.checkmarkContainer && this.indeterminateContainer) {
38
+ this.updateCheckmarkVisibility();
39
+ }
40
+ }
41
+ get indeterminate() {
42
+ return this._indeterminate;
43
+ }
44
+ set checked(checked) {
45
+ this._checked = checked;
46
+ // Only update visibility if containers are ready
47
+ if (this.checkmarkContainer && this.indeterminateContainer) {
48
+ this.updateCheckmarkVisibility();
49
+ }
50
+ }
51
+ get checked() {
52
+ return this._checked;
53
+ }
54
+ required = false;
55
+ set name(name) {
56
+ this._name = name;
57
+ }
58
+ get name() {
59
+ return this._name;
60
+ }
61
+ // eslint-disable-next-line @angular-eslint/no-output-native
62
+ change = new EventEmitter();
63
+ _checked = false;
64
+ _indeterminate = false;
65
+ _name = '';
66
+ _controlValueAccessorChangeFn = () => { };
67
+ _onTouched = () => { };
68
+ listeners = [];
69
+ styleElement;
70
+ wrapper;
71
+ checkmarkContainer;
72
+ indeterminateContainer;
73
+ symbolComponent;
74
+ ngOnInit() {
75
+ this.symbolRegistry.registerSymbols([apCheck]);
76
+ this.createCheckboxStructure();
77
+ this.setupEventListeners();
78
+ }
79
+ ngOnDestroy() {
80
+ this.listeners.forEach(unlisten => unlisten());
81
+ if (this.styleElement && this.styleElement.parentNode) {
82
+ this.styleElement.parentNode.removeChild(this.styleElement);
83
+ }
84
+ if (this.symbolComponent) {
85
+ this.symbolComponent.destroy();
86
+ }
87
+ if (this.checkmarkContainer && this.checkmarkContainer.parentNode) {
88
+ this.checkmarkContainer.parentNode.removeChild(this.checkmarkContainer);
89
+ }
90
+ if (this.indeterminateContainer && this.indeterminateContainer.parentNode) {
91
+ this.indeterminateContainer.parentNode.removeChild(this.indeterminateContainer);
92
+ }
93
+ // Move input back out of wrapper and remove wrapper
94
+ if (this.wrapper && this.wrapper.parentNode) {
95
+ const input = this.elementRef.nativeElement;
96
+ this.renderer.insertBefore(this.wrapper.parentNode, input, this.wrapper);
97
+ this.wrapper.parentNode.removeChild(this.wrapper);
98
+ }
99
+ }
100
+ createCheckboxStructure() {
101
+ const input = this.elementRef.nativeElement;
102
+ const parent = input.parentElement;
103
+ // Hot take - Input doesn't need positioning since it will be wrapped
104
+ // Make input's parent use inline-flex for alignment
105
+ if (parent) {
106
+ this.renderer.setStyle(parent, 'display', 'inline-flex');
107
+ this.renderer.setStyle(parent, 'align-items', 'center');
108
+ this.renderer.setStyle(parent, 'gap', 'var(--ref-spacing-xxs)');
109
+ }
110
+ this.renderer.addClass(input, 'ap-checkbox-styled');
111
+ this.checkmarkContainer = this.createOverlayContainer('ap-checkbox-checkmark');
112
+ this.wrapper = this.renderer.createElement('span');
113
+ this.renderer.setStyle(this.wrapper, 'position', 'relative');
114
+ this.renderer.setStyle(this.wrapper, 'display', 'inline-flex');
115
+ this.renderer.setStyle(this.wrapper, 'align-items', 'center');
116
+ this.renderer.setStyle(this.wrapper, 'vertical-align', 'middle');
117
+ this.renderer.insertBefore(parent, this.wrapper, input);
118
+ this.renderer.appendChild(this.wrapper, input);
119
+ this.renderer.appendChild(this.wrapper, this.checkmarkContainer);
120
+ this.indeterminateContainer = this.createOverlayContainer('ap-checkbox-indeterminate');
121
+ this.renderer.appendChild(this.wrapper, this.indeterminateContainer);
122
+ this.createCheckmarkSymbol();
123
+ this.createIndeterminateBar();
124
+ this.applyCheckboxStyles();
125
+ this.updateCheckmarkVisibility();
126
+ }
127
+ createOverlayContainer(className) {
128
+ const container = this.renderer.createElement('span');
129
+ this.renderer.addClass(container, className);
130
+ this.renderer.setStyle(container, 'position', 'absolute');
131
+ this.renderer.setStyle(container, 'top', '50%');
132
+ this.renderer.setStyle(container, 'left', '50%');
133
+ this.renderer.setStyle(container, 'transform', 'translate(-50%, -50%)');
134
+ this.renderer.setStyle(container, 'width', 'auto');
135
+ this.renderer.setStyle(container, 'height', 'auto');
136
+ this.renderer.setStyle(container, 'display', 'flex');
137
+ this.renderer.setStyle(container, 'justify-content', 'center');
138
+ this.renderer.setStyle(container, 'align-items', 'center');
139
+ this.renderer.setStyle(container, 'pointer-events', 'none');
140
+ this.renderer.setStyle(container, 'opacity', '0');
141
+ this.renderer.setStyle(container, 'z-index', '1');
142
+ return container;
143
+ }
144
+ createCheckmarkSymbol() {
145
+ // Create the symbol component
146
+ this.symbolComponent = this.viewContainer.createComponent(SymbolComponent);
147
+ // Set inputs using setInput method for signal-based inputs
148
+ this.symbolComponent.setInput('symbolId', 'check');
149
+ this.symbolComponent.setInput('color', 'white');
150
+ this.symbolComponent.setInput('size', 10);
151
+ // Append the symbol to our checkmark container
152
+ this.renderer.appendChild(this.checkmarkContainer, this.symbolComponent.location.nativeElement);
153
+ }
154
+ createIndeterminateBar() {
155
+ // Create the indeterminate bar element exactly like the component
156
+ const bar = this.renderer.createElement('span');
157
+ this.renderer.setStyle(bar, 'height', '1.5px');
158
+ this.renderer.setStyle(bar, 'background', 'var(--ref-color-white)');
159
+ this.renderer.setStyle(bar, 'width', '8px');
160
+ // Append the bar to the indeterminate container
161
+ this.renderer.appendChild(this.indeterminateContainer, bar);
162
+ }
163
+ updateCheckmarkVisibility() {
164
+ if (this.checkmarkContainer) {
165
+ const opacity = this._checked && !this._indeterminate ? '1' : '0';
166
+ this.renderer.setStyle(this.checkmarkContainer, 'opacity', opacity);
167
+ }
168
+ if (this.indeterminateContainer) {
169
+ const opacity = this._indeterminate && !this._checked ? '1' : '0';
170
+ this.renderer.setStyle(this.indeterminateContainer, 'opacity', opacity);
171
+ }
172
+ }
173
+ setupEventListeners() {
174
+ const input = this.elementRef.nativeElement;
175
+ // Input change listener (native checkbox change)
176
+ const changeListener = this.renderer.listen(input, 'change', () => {
177
+ this.onValueChange();
178
+ });
179
+ this.listeners.push(changeListener);
180
+ // Listen for label clicks to ensure focus is maintained
181
+ const parent = input.parentElement;
182
+ if (parent) {
183
+ const labelClickListener = this.renderer.listen(parent, 'click', (event) => {
184
+ const target = event.target;
185
+ // If clicking on a label that targets our input, ensure focus
186
+ if (target.tagName === 'LABEL' && target.getAttribute('for') === this.name) {
187
+ // Small delay to ensure the label click is processed first
188
+ setTimeout(() => {
189
+ input.focus();
190
+ }, 0);
191
+ }
192
+ });
193
+ this.listeners.push(labelClickListener);
194
+ }
195
+ }
196
+ applyCheckboxStyles() {
197
+ // Style the input directly without moving DOM elements
198
+ const styles = `
199
+ /* Complete reset and custom styling for our checkbox */
200
+ input[type="checkbox"].ap-checkbox-styled {
201
+ /* Targeted reset of problematic properties */
202
+ appearance: none !important;
203
+ -webkit-appearance: none !important;
204
+ -moz-appearance: none !important;
205
+
206
+ /* Our custom styling - use !important to override any global styles */
207
+ display: inline-block !important;
208
+ width: 16px !important;
209
+ height: 16px !important;
210
+ min-width: 16px !important;
211
+ min-height: 16px !important;
212
+ margin: 0 !important;
213
+ padding: 0 !important;
214
+ border: 1px solid var(--ref-color-grey-60);
215
+ border-radius: var(--sys-border-radius-sm);
216
+ background: var(--ref-color-white);
217
+ background-color: var(--ref-color-white);
218
+ box-sizing: border-box;
219
+ position: relative;
220
+ cursor: pointer;
221
+ vertical-align: middle;
222
+
223
+ /* Ensure no other styles can interfere */
224
+ box-shadow: none;
225
+ text-decoration: none;
226
+ font: inherit;
227
+ color: inherit;
228
+ letter-spacing: normal;
229
+ word-spacing: normal;
230
+ text-transform: none;
231
+ text-indent: 0;
232
+ text-shadow: none;
233
+ text-align: start;
234
+ }
235
+
236
+ /* Hover state */
237
+ input[type="checkbox"].ap-checkbox-styled:hover {
238
+ border-color: var(--ref-color-grey-80);
239
+ }
240
+
241
+ /* Active/pressed state */
242
+ input[type="checkbox"].ap-checkbox-styled:active {
243
+ border-color: var(--ref-color-grey-100);
244
+ }
245
+
246
+ /* Checked state */
247
+ input[type="checkbox"].ap-checkbox-styled:checked {
248
+ background: var(--ref-color-electric-blue-100);
249
+ border-color: var(--ref-color-electric-blue-100);
250
+ }
251
+
252
+ /* Checked hover state */
253
+ input[type="checkbox"].ap-checkbox-styled:checked:hover {
254
+ background: var(--ref-color-electric-blue-80);
255
+ border-color: var(--ref-color-electric-blue-100);
256
+ }
257
+
258
+ /* Checked active/pressed state */
259
+ input[type="checkbox"].ap-checkbox-styled:checked:active {
260
+ background: var(--ref-color-electric-blue-60);
261
+ border-color: var(--ref-color-electric-blue-100);
262
+ }
263
+
264
+ /* Indeterminate state */
265
+ input[type="checkbox"].ap-checkbox-styled:indeterminate {
266
+ background: var(--ref-color-electric-blue-100);
267
+ border-color: var(--ref-color-electric-blue-100);
268
+ }
269
+
270
+ /* Disabled state */
271
+ input[type="checkbox"].ap-checkbox-styled:disabled {
272
+ border-color: var(--ref-color-grey-20);
273
+ background: var(--ref-color-grey-10);
274
+ cursor: default;
275
+ }
276
+
277
+ input[type="checkbox"].ap-checkbox-styled:disabled:checked {
278
+ background: var(--ref-color-grey-20);
279
+ }
280
+
281
+ /* Focus state - only show on hover-capable devices like the component */
282
+ @media (hover: hover) {
283
+ input[type="checkbox"].ap-checkbox-styled:focus:not(.disabled) {
284
+ outline: 3px solid var(--ref-color-electric-blue-100) !important;
285
+ outline-offset: 1px !important;
286
+ }
287
+ }
288
+
289
+ /* Label styling - targets labels that follow our wrapper containing styled checkboxes */
290
+ span:has(input[type="checkbox"].ap-checkbox-styled) + label {
291
+ display: flex;
292
+ align-items: center;
293
+ font-family: var(--comp-forms-label-font-family);
294
+ font-size: var(--comp-forms-label-size);
295
+ font-weight: var(--comp-forms-label-font-weight);
296
+ line-height: var(--comp-forms-label-line-height);
297
+ color: var(--comp-forms-label-text-color);
298
+ }
299
+
300
+ /* Empty label styling */
301
+ span:has(input[type="checkbox"].ap-checkbox-styled) + label:empty {
302
+ display: none;
303
+ }
304
+
305
+ /* Disabled label styling */
306
+ span:has(input[type="checkbox"].ap-checkbox-styled:disabled) + label {
307
+ color: var(--ref-color-grey-60);
308
+ }
309
+
310
+ /* Label hover styling */
311
+ span:has(input[type="checkbox"].ap-checkbox-styled) + label:hover:not(.disabled) {
312
+ cursor: pointer;
313
+ }
314
+
315
+ /* Disabled label hover */
316
+ span:has(input[type="checkbox"].ap-checkbox-styled:disabled) + label:hover {
317
+ cursor: default;
318
+ }
319
+ `;
320
+ // Create and append style element
321
+ this.styleElement = this.renderer.createElement('style');
322
+ this.renderer.appendChild(this.styleElement, this.renderer.createText(styles));
323
+ this.renderer.appendChild(document.head, this.styleElement);
324
+ }
325
+ onBlur() {
326
+ this._onTouched();
327
+ }
328
+ onValueChange() {
329
+ if (!this.disabled) {
330
+ const input = this.elementRef.nativeElement;
331
+ if (this._indeterminate) {
332
+ // When indeterminate, clicking should go to checked state
333
+ this._checked = true;
334
+ this._indeterminate = false;
335
+ input.checked = true;
336
+ input.indeterminate = false;
337
+ }
338
+ else {
339
+ // Normal toggle behavior
340
+ this._checked = input.checked;
341
+ }
342
+ this.updateCheckmarkVisibility();
343
+ this.change.emit(this._checked);
344
+ this._controlValueAccessorChangeFn(this._checked);
345
+ }
346
+ }
347
+ // ControlValueAccessor implementation
348
+ writeValue(value) {
349
+ this._checked = value;
350
+ const input = this.elementRef.nativeElement;
351
+ input.checked = value;
352
+ // Ensure indeterminate state is properly set
353
+ input.indeterminate = this._indeterminate;
354
+ this.updateCheckmarkVisibility();
355
+ }
356
+ registerOnChange(fn) {
357
+ this._controlValueAccessorChangeFn = fn;
358
+ }
359
+ registerOnTouched(fn) {
360
+ this._onTouched = fn;
361
+ }
362
+ setDisabledState(isDisabled) {
363
+ this.disabled = isDisabled;
364
+ const input = this.elementRef.nativeElement;
365
+ input.disabled = isDisabled;
366
+ }
367
+ validate() {
368
+ const isNotValid = !this._checked && this.required;
369
+ return (isNotValid && {
370
+ invalid: true,
371
+ });
372
+ }
373
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: CheckboxDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
374
+ static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "16.1.0", version: "18.2.9", type: CheckboxDirective, isStandalone: true, selector: "input[type=\"checkbox\"][apCheckbox]", inputs: { ariaLabel: ["aria-label", "ariaLabel"], ariaLabelledby: ["aria-labelledby", "ariaLabelledby"], ariaDescribedby: ["aria-describedby", "ariaDescribedby"], disabled: ["disabled", "disabled", booleanAttribute], indeterminate: ["indeterminate", "indeterminate", booleanAttribute], checked: "checked", required: ["required", "required", booleanAttribute], name: "name" }, outputs: { change: "change" }, host: { listeners: { "blur": "onBlur()" }, properties: { "disabled": "disabled", "required": "required", "checked": "checked", "attr.aria-label": "ariaLabel", "attr.aria-labelledby": "ariaLabelledby", "attr.aria-describedby": "ariaDescribedby", "attr.data-test": "name", "id": "name" } }, providers: [
375
+ AP_CHECKBOX_DIRECTIVE_CONTROL_VALUE_ACCESSOR,
376
+ {
377
+ provide: NG_VALIDATORS,
378
+ useExisting: CheckboxDirective,
379
+ multi: true,
380
+ },
381
+ ], ngImport: i0 });
382
+ }
383
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: CheckboxDirective, decorators: [{
384
+ type: Directive,
385
+ args: [{
386
+ selector: 'input[type="checkbox"][apCheckbox]',
387
+ standalone: true,
388
+ providers: [
389
+ AP_CHECKBOX_DIRECTIVE_CONTROL_VALUE_ACCESSOR,
390
+ {
391
+ provide: NG_VALIDATORS,
392
+ useExisting: CheckboxDirective,
393
+ multi: true,
394
+ },
395
+ ],
396
+ host: {
397
+ '(blur)': 'onBlur()',
398
+ '[disabled]': 'disabled',
399
+ '[required]': 'required',
400
+ '[checked]': 'checked',
401
+ '[attr.aria-label]': 'ariaLabel',
402
+ '[attr.aria-labelledby]': 'ariaLabelledby',
403
+ '[attr.aria-describedby]': 'ariaDescribedby',
404
+ '[attr.data-test]': 'name',
405
+ '[id]': 'name',
406
+ },
407
+ }]
408
+ }], propDecorators: { ariaLabel: [{
409
+ type: Input,
410
+ args: ['aria-label']
411
+ }], ariaLabelledby: [{
412
+ type: Input,
413
+ args: ['aria-labelledby']
414
+ }], ariaDescribedby: [{
415
+ type: Input,
416
+ args: ['aria-describedby']
417
+ }], disabled: [{
418
+ type: Input,
419
+ args: [{
420
+ transform: booleanAttribute,
421
+ }]
422
+ }], indeterminate: [{
423
+ type: Input,
424
+ args: [{
425
+ transform: booleanAttribute,
426
+ }]
427
+ }], checked: [{
428
+ type: Input
429
+ }], required: [{
430
+ type: Input,
431
+ args: [{
432
+ transform: booleanAttribute,
433
+ }]
434
+ }], name: [{
435
+ type: Input,
436
+ args: [{
437
+ required: true,
438
+ }]
439
+ }], change: [{
440
+ type: Output
441
+ }] } });
442
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"checkbox.directive.js","sourceRoot":"","sources":["../../../../libs/ui-components/directives/src/checkbox.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { apCheck, SymbolComponent, SymbolRegistry } from '@agorapulse/ui-symbol';\nimport {\n    booleanAttribute,\n    ComponentRef,\n    Directive,\n    ElementRef,\n    EventEmitter,\n    forwardRef,\n    inject,\n    Input,\n    OnDestroy,\n    OnInit,\n    Output,\n    Renderer2,\n    ViewContainerRef,\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALIDATORS, NG_VALUE_ACCESSOR } from '@angular/forms';\n\nexport const AP_CHECKBOX_DIRECTIVE_CONTROL_VALUE_ACCESSOR = {\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: forwardRef(() => CheckboxDirective),\n    multi: true,\n};\n\n/*\n    Host bindings is important here:\n    - This provides encapsulation and reactivity regardless of how the directive is used in templates.\n    - It guarantees that properties like checked, disabled, required, and ARIA attributes always reflect\n    only the directive's logic, not just consumer bindings.\n    - So we need to have host bindings for all the properties that we want to control.\n    - We could also use @HostListener.\n*/\n@Directive({\n    selector: 'input[type=\"checkbox\"][apCheckbox]',\n    standalone: true,\n    providers: [\n        AP_CHECKBOX_DIRECTIVE_CONTROL_VALUE_ACCESSOR,\n        {\n            provide: NG_VALIDATORS,\n            useExisting: CheckboxDirective,\n            multi: true,\n        },\n    ],\n    host: {\n        '(blur)': 'onBlur()',\n        '[disabled]': 'disabled',\n        '[required]': 'required',\n        '[checked]': 'checked',\n        '[attr.aria-label]': 'ariaLabel',\n        '[attr.aria-labelledby]': 'ariaLabelledby',\n        '[attr.aria-describedby]': 'ariaDescribedby',\n        '[attr.data-test]': 'name',\n        '[id]': 'name',\n    },\n})\nexport class CheckboxDirective implements ControlValueAccessor, OnInit, OnDestroy {\n    private readonly symbolRegistry = inject(SymbolRegistry);\n    private readonly elementRef = inject(ElementRef<HTMLInputElement>);\n    private readonly renderer = inject(Renderer2);\n    private readonly viewContainer = inject(ViewContainerRef);\n\n    @Input('aria-label') ariaLabel?: string;\n    @Input('aria-labelledby') ariaLabelledby?: string;\n    @Input('aria-describedby') ariaDescribedby?: string;\n    \n    @Input({\n        transform: booleanAttribute,\n    })\n    disabled = false;\n    \n    @Input({\n        transform: booleanAttribute,\n    })\n    set indeterminate(indeterminate: boolean) {\n        if (indeterminate) {\n            this._checked = false;\n        }\n        this._indeterminate = indeterminate;\n        const input = this.elementRef.nativeElement;\n        if (input) {\n            input.indeterminate = indeterminate;\n        }\n        // Only update visibility if containers are ready\n        if (this.checkmarkContainer && this.indeterminateContainer) {\n            this.updateCheckmarkVisibility();\n        }\n    }\n\n    get indeterminate(): boolean {\n        return this._indeterminate;\n    }\n\n    @Input() \n    set checked(checked: boolean) {\n        this._checked = checked;\n        // Only update visibility if containers are ready\n        if (this.checkmarkContainer && this.indeterminateContainer) {\n            this.updateCheckmarkVisibility();\n        }\n    }\n    \n    get checked(): boolean {\n        return this._checked;\n    }\n\n    @Input({\n        transform: booleanAttribute,\n    })\n    required = false;\n\n    @Input({\n        required: true,\n    })\n    set name(name: string) {\n        this._name = name;\n    }\n    get name(): string {\n        return this._name;\n    }\n\n    // eslint-disable-next-line @angular-eslint/no-output-native\n    @Output() readonly change: EventEmitter<boolean> = new EventEmitter<boolean>();\n\n    private _checked = false;\n    private _indeterminate = false;\n    private _name = '';\n    private _controlValueAccessorChangeFn: (value: boolean) => void = () => {};\n    private _onTouched: () => void = () => {};\n    \n    private listeners: (() => void)[] = [];\n    private styleElement!: HTMLStyleElement;\n    private wrapper!: HTMLElement;\n    private checkmarkContainer!: HTMLElement;\n    private indeterminateContainer!: HTMLElement;\n    private symbolComponent?: ComponentRef<SymbolComponent>;\n\n    ngOnInit() {\n        this.symbolRegistry.registerSymbols([apCheck]);\n        this.createCheckboxStructure();\n        this.setupEventListeners();\n    }\n\n    ngOnDestroy(): void {\n        this.listeners.forEach(unlisten => unlisten());\n        if (this.styleElement && this.styleElement.parentNode) {\n            this.styleElement.parentNode.removeChild(this.styleElement);\n        }\n        if (this.symbolComponent) {\n            this.symbolComponent.destroy();\n        }\n        if (this.checkmarkContainer && this.checkmarkContainer.parentNode) {\n            this.checkmarkContainer.parentNode.removeChild(this.checkmarkContainer);\n        }\n        if (this.indeterminateContainer && this.indeterminateContainer.parentNode) {\n            this.indeterminateContainer.parentNode.removeChild(this.indeterminateContainer);\n        }\n        // Move input back out of wrapper and remove wrapper\n        if (this.wrapper && this.wrapper.parentNode) {\n            const input = this.elementRef.nativeElement;\n            this.renderer.insertBefore(this.wrapper.parentNode, input, this.wrapper);\n            this.wrapper.parentNode.removeChild(this.wrapper);\n        }\n    }\n\n    private createCheckboxStructure(): void {\n        const input = this.elementRef.nativeElement;\n        const parent = input.parentElement;\n        \n        // Hot take - Input doesn't need positioning since it will be wrapped\n        \n        // Make input's parent use inline-flex for alignment\n        if (parent) {\n            this.renderer.setStyle(parent, 'display', 'inline-flex');\n            this.renderer.setStyle(parent, 'align-items', 'center');\n            this.renderer.setStyle(parent, 'gap', 'var(--ref-spacing-xxs)');\n        }\n        \n        this.renderer.addClass(input, 'ap-checkbox-styled');\n        \n        this.checkmarkContainer = this.createOverlayContainer('ap-checkbox-checkmark');\n        \n        this.wrapper = this.renderer.createElement('span');\n        this.renderer.setStyle(this.wrapper, 'position', 'relative');\n        this.renderer.setStyle(this.wrapper, 'display', 'inline-flex');\n        this.renderer.setStyle(this.wrapper, 'align-items', 'center');\n        this.renderer.setStyle(this.wrapper, 'vertical-align', 'middle');\n        \n        this.renderer.insertBefore(parent, this.wrapper, input);\n        this.renderer.appendChild(this.wrapper, input);\n        \n        this.renderer.appendChild(this.wrapper, this.checkmarkContainer);\n        \n        this.indeterminateContainer = this.createOverlayContainer('ap-checkbox-indeterminate');\n        \n        this.renderer.appendChild(this.wrapper, this.indeterminateContainer);\n        \n        this.createCheckmarkSymbol();\n        this.createIndeterminateBar();\n        \n        this.applyCheckboxStyles();\n        \n        this.updateCheckmarkVisibility();\n    }\n\n    private createOverlayContainer(className: string): HTMLElement {\n        const container = this.renderer.createElement('span');\n        this.renderer.addClass(container, className);\n        this.renderer.setStyle(container, 'position', 'absolute');\n        this.renderer.setStyle(container, 'top', '50%'); \n        this.renderer.setStyle(container, 'left', '50%');   \n        this.renderer.setStyle(container, 'transform', 'translate(-50%, -50%)');\n        this.renderer.setStyle(container, 'width', 'auto'); \n        this.renderer.setStyle(container, 'height', 'auto'); \n        this.renderer.setStyle(container, 'display', 'flex');\n        this.renderer.setStyle(container, 'justify-content', 'center');\n        this.renderer.setStyle(container, 'align-items', 'center');\n        this.renderer.setStyle(container, 'pointer-events', 'none');\n        this.renderer.setStyle(container, 'opacity', '0');\n        this.renderer.setStyle(container, 'z-index', '1');\n        return container;\n    }\n\n    private createCheckmarkSymbol(): void {\n        // Create the symbol component\n        this.symbolComponent = this.viewContainer.createComponent(SymbolComponent);\n        \n        // Set inputs using setInput method for signal-based inputs\n        this.symbolComponent.setInput('symbolId', 'check');\n        this.symbolComponent.setInput('color', 'white');\n        this.symbolComponent.setInput('size', 10);\n        \n        // Append the symbol to our checkmark container\n        this.renderer.appendChild(this.checkmarkContainer, this.symbolComponent.location.nativeElement);\n    }\n\n    private createIndeterminateBar(): void {\n        // Create the indeterminate bar element exactly like the component\n        const bar = this.renderer.createElement('span');\n        this.renderer.setStyle(bar, 'height', '1.5px');\n        this.renderer.setStyle(bar, 'background', 'var(--ref-color-white)');\n        this.renderer.setStyle(bar, 'width', '8px');\n        \n        // Append the bar to the indeterminate container\n        this.renderer.appendChild(this.indeterminateContainer, bar);\n    }\n\n    private updateCheckmarkVisibility(): void {\n        if (this.checkmarkContainer) {\n            const opacity = this._checked && !this._indeterminate ? '1' : '0';\n            this.renderer.setStyle(this.checkmarkContainer, 'opacity', opacity);\n        }\n        if (this.indeterminateContainer) {\n            const opacity = this._indeterminate && !this._checked ? '1' : '0';\n            this.renderer.setStyle(this.indeterminateContainer, 'opacity', opacity);\n        }\n    }\n\n    private setupEventListeners(): void {\n        const input = this.elementRef.nativeElement;\n        \n        // Input change listener (native checkbox change)\n        const changeListener = this.renderer.listen(input, 'change', () => {\n            this.onValueChange();\n        });\n        this.listeners.push(changeListener);\n        \n        // Listen for label clicks to ensure focus is maintained\n        const parent = input.parentElement;\n        if (parent) {\n            const labelClickListener = this.renderer.listen(parent, 'click', (event: MouseEvent) => {\n                const target = event.target as HTMLElement;\n                // If clicking on a label that targets our input, ensure focus\n                if (target.tagName === 'LABEL' && target.getAttribute('for') === this.name) {\n                    // Small delay to ensure the label click is processed first\n                    setTimeout(() => {\n                        input.focus();\n                    }, 0);\n                }\n            });\n            this.listeners.push(labelClickListener);\n        }\n    }\n\n    private applyCheckboxStyles(): void {\n        // Style the input directly without moving DOM elements\n        const styles = `\n            /* Complete reset and custom styling for our checkbox */\n            input[type=\"checkbox\"].ap-checkbox-styled {\n                /* Targeted reset of problematic properties */\n                appearance: none !important;\n                -webkit-appearance: none !important;\n                -moz-appearance: none !important;\n                \n                /* Our custom styling - use !important to override any global styles */\n                display: inline-block !important;\n                width: 16px !important;\n                height: 16px !important;\n                min-width: 16px !important;\n                min-height: 16px !important;\n                margin: 0 !important;\n                padding: 0 !important;\n                border: 1px solid var(--ref-color-grey-60);\n                border-radius: var(--sys-border-radius-sm);\n                background: var(--ref-color-white);\n                background-color: var(--ref-color-white);\n                box-sizing: border-box;\n                position: relative;\n                cursor: pointer;\n                vertical-align: middle;\n                \n                /* Ensure no other styles can interfere */\n                box-shadow: none;\n                text-decoration: none;\n                font: inherit;\n                color: inherit;\n                letter-spacing: normal;\n                word-spacing: normal;\n                text-transform: none;\n                text-indent: 0;\n                text-shadow: none;\n                text-align: start;\n            }\n            \n            /* Hover state */\n            input[type=\"checkbox\"].ap-checkbox-styled:hover {\n                border-color: var(--ref-color-grey-80);\n            }\n            \n            /* Active/pressed state */\n            input[type=\"checkbox\"].ap-checkbox-styled:active {\n                border-color: var(--ref-color-grey-100);\n            }\n            \n            /* Checked state */\n            input[type=\"checkbox\"].ap-checkbox-styled:checked {\n                background: var(--ref-color-electric-blue-100);\n                border-color: var(--ref-color-electric-blue-100);\n            }\n            \n            /* Checked hover state */\n            input[type=\"checkbox\"].ap-checkbox-styled:checked:hover {\n                background: var(--ref-color-electric-blue-80);\n                border-color: var(--ref-color-electric-blue-100);\n            }\n            \n            /* Checked active/pressed state */\n            input[type=\"checkbox\"].ap-checkbox-styled:checked:active {\n                background: var(--ref-color-electric-blue-60);\n                border-color: var(--ref-color-electric-blue-100);\n            }\n            \n            /* Indeterminate state */\n            input[type=\"checkbox\"].ap-checkbox-styled:indeterminate {\n                background: var(--ref-color-electric-blue-100);\n                border-color: var(--ref-color-electric-blue-100);\n            }\n            \n            /* Disabled state */\n            input[type=\"checkbox\"].ap-checkbox-styled:disabled {\n                border-color: var(--ref-color-grey-20);\n                background: var(--ref-color-grey-10);\n                cursor: default;\n            }\n            \n            input[type=\"checkbox\"].ap-checkbox-styled:disabled:checked {\n                background: var(--ref-color-grey-20);\n            }\n            \n            /* Focus state - only show on hover-capable devices like the component */\n            @media (hover: hover) {\n                input[type=\"checkbox\"].ap-checkbox-styled:focus:not(.disabled) {\n                    outline: 3px solid var(--ref-color-electric-blue-100) !important;\n                    outline-offset: 1px !important;\n                }\n            }\n            \n            /* Label styling - targets labels that follow our wrapper containing styled checkboxes */\n            span:has(input[type=\"checkbox\"].ap-checkbox-styled) + label {\n                display: flex;\n                align-items: center;\n                font-family: var(--comp-forms-label-font-family);\n                font-size: var(--comp-forms-label-size);\n                font-weight: var(--comp-forms-label-font-weight);\n                line-height: var(--comp-forms-label-line-height);\n                color: var(--comp-forms-label-text-color);\n            }\n            \n            /* Empty label styling */\n            span:has(input[type=\"checkbox\"].ap-checkbox-styled) + label:empty {\n                display: none;\n            }\n            \n            /* Disabled label styling */\n            span:has(input[type=\"checkbox\"].ap-checkbox-styled:disabled) + label {\n                color: var(--ref-color-grey-60);\n            }\n            \n            /* Label hover styling */\n            span:has(input[type=\"checkbox\"].ap-checkbox-styled) + label:hover:not(.disabled) {\n                cursor: pointer;\n            }\n            \n            /* Disabled label hover */\n            span:has(input[type=\"checkbox\"].ap-checkbox-styled:disabled) + label:hover {\n                cursor: default;\n            }\n        `;\n        \n        // Create and append style element\n        this.styleElement = this.renderer.createElement('style');\n        this.renderer.appendChild(this.styleElement, this.renderer.createText(styles));\n        this.renderer.appendChild(document.head, this.styleElement);\n    }\n\n\n    onBlur(): void {\n        this._onTouched();\n    }\n\n    private onValueChange(): void {\n        if (!this.disabled) {\n            const input = this.elementRef.nativeElement;\n            \n            if (this._indeterminate) {\n                // When indeterminate, clicking should go to checked state\n                this._checked = true;\n                this._indeterminate = false;\n                input.checked = true;\n                input.indeterminate = false;\n            } else {\n                // Normal toggle behavior\n                this._checked = input.checked;\n            }\n            \n            this.updateCheckmarkVisibility();\n            this.change.emit(this._checked);\n            this._controlValueAccessorChangeFn(this._checked);\n        }\n    }\n\n\n    // ControlValueAccessor implementation\n    writeValue(value: boolean): void {\n        this._checked = value;\n        const input = this.elementRef.nativeElement;\n        input.checked = value;\n        // Ensure indeterminate state is properly set\n        input.indeterminate = this._indeterminate;\n        this.updateCheckmarkVisibility();\n    }\n\n    registerOnChange(fn: (value: boolean) => void): void {\n        this._controlValueAccessorChangeFn = fn;\n    }\n\n    registerOnTouched(fn: () => void): void {\n        this._onTouched = fn;\n    }\n\n    setDisabledState(isDisabled: boolean): void {\n        this.disabled = isDisabled;\n        const input = this.elementRef.nativeElement;\n        input.disabled = isDisabled;\n    }\n\n    validate() {\n        const isNotValid = !this._checked && this.required;\n        return (\n            isNotValid && {\n                invalid: true,\n            }\n        );\n    }\n}"]}
@@ -1,8 +1,9 @@
1
1
  export * from './autosize-textarea.directive';
2
2
  export * from './base-button.directive';
3
+ export * from './checkbox.directive';
3
4
  export * from './default-image.directive';
4
5
  export * from './ellipsis.directive';
5
6
  export * from './equal-validator.directive';
6
7
  export * from './frozen-gif.directive';
7
8
  export * from './multi-style-text.directive';
8
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljX2FwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL2xpYnMvdWktY29tcG9uZW50cy9kaXJlY3RpdmVzL3NyYy9wdWJsaWNfYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsK0JBQStCLENBQUM7QUFDOUMsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxjQUFjLDJCQUEyQixDQUFDO0FBQzFDLGNBQWMsc0JBQXNCLENBQUM7QUFDckMsY0FBYyw2QkFBNkIsQ0FBQztBQUM1QyxjQUFjLHdCQUF3QixDQUFDO0FBQ3ZDLGNBQWMsOEJBQThCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2F1dG9zaXplLXRleHRhcmVhLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL2Jhc2UtYnV0dG9uLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL2RlZmF1bHQtaW1hZ2UuZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vZWxsaXBzaXMuZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vZXF1YWwtdmFsaWRhdG9yLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL2Zyb3plbi1naWYuZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vbXVsdGktc3R5bGUtdGV4dC5kaXJlY3RpdmUnO1xuIl19
9
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljX2FwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL2xpYnMvdWktY29tcG9uZW50cy9kaXJlY3RpdmVzL3NyYy9wdWJsaWNfYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsK0JBQStCLENBQUM7QUFDOUMsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxjQUFjLHNCQUFzQixDQUFDO0FBQ3JDLGNBQWMsMkJBQTJCLENBQUM7QUFDMUMsY0FBYyxzQkFBc0IsQ0FBQztBQUNyQyxjQUFjLDZCQUE2QixDQUFDO0FBQzVDLGNBQWMsd0JBQXdCLENBQUM7QUFDdkMsY0FBYyw4QkFBOEIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vYXV0b3NpemUtdGV4dGFyZWEuZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vYmFzZS1idXR0b24uZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vY2hlY2tib3guZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vZGVmYXVsdC1pbWFnZS5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9lbGxpcHNpcy5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9lcXVhbC12YWxpZGF0b3IuZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vZnJvemVuLWdpZi5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9tdWx0aS1zdHlsZS10ZXh0LmRpcmVjdGl2ZSc7XG4iXX0=
package/esm2022/index.mjs CHANGED
@@ -5,7 +5,7 @@
5
5
  export { PopmenuModule } from '@agorapulse/ui-components/popmenu';
6
6
  export { AgorapulseUiComponentsModule } from './src/lib/agorapulse-ui-components.module';
7
7
  // Directive
8
- export { AutosizeTextareaDirective, DefaultImageDirective, EllipsisDirective, EqualValidatorDirective, FrozenGifDirective, MultiStyleTextDirective, } from '@agorapulse/ui-components/directives';
8
+ export { AutosizeTextareaDirective, CheckboxDirective, DefaultImageDirective, EllipsisDirective, EqualValidatorDirective, FrozenGifDirective, MultiStyleTextDirective, } from '@agorapulse/ui-components/directives';
9
9
  export { PopmenuDirective } from '@agorapulse/ui-components/popmenu';
10
10
  export { TooltipDirective } from '@agorapulse/ui-components/tooltip';
11
11
  // Component
@@ -46,4 +46,4 @@ export { ToggleComponent } from '@agorapulse/ui-components/toggle';
46
46
  // Service
47
47
  export { SnackbarsThreadService } from '@agorapulse/ui-components/snackbars-thread';
48
48
  export { CodeStatus, SnackbarTypeValues, generateCodeStatus, } from '@agorapulse/ui-components/snackbars-thread';
49
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../libs/ui-components/index.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * Public API Surface of ui\n */\n\n// Module\nexport { PopmenuModule } from '@agorapulse/ui-components/popmenu';\nexport { AgorapulseUiComponentsModule } from './src/lib/agorapulse-ui-components.module';\n\n// Directive\nexport {\n    AutosizeTextareaDirective,\n    DefaultImageDirective,\n    EllipsisDirective,\n    EqualValidatorDirective,\n    FrozenGifDirective,\n    MultiStyleTextDirective,\n} from '@agorapulse/ui-components/directives';\nexport { PopmenuDirective } from '@agorapulse/ui-components/popmenu';\nexport { TooltipDirective } from '@agorapulse/ui-components/tooltip';\n\n// Component\nexport { AddCommentComponent } from '@agorapulse/ui-components/add-comment';\nexport { AutocompleteComponent } from '@agorapulse/ui-components/autocomplete';\nexport { AvatarComponent } from '@agorapulse/ui-components/avatar';\nexport { BadgeComponent } from '@agorapulse/ui-components/badge';\nexport { ButtonComponent } from '@agorapulse/ui-components/button';\nexport { CheckboxComponent } from '@agorapulse/ui-components/checkbox';\nexport { ConfirmModalComponent } from '@agorapulse/ui-components/confirm-modal';\nexport { CounterComponent } from '@agorapulse/ui-components/counter';\nexport { DatepickerComponent, DatepickerMode, I18nDatePicker, Period } from '@agorapulse/ui-components/datepicker';\nexport { DotStepperComponent } from '@agorapulse/ui-components/dot-stepper';\nexport { IconButtonComponent } from '@agorapulse/ui-components/icon-button';\nexport { InfoboxComponent } from '@agorapulse/ui-components/infobox';\nexport { LabelComponent, LabelListComponent } from '@agorapulse/ui-components/labels';\nexport { LabelsSelectorComponent } from '@agorapulse/ui-components/labels-selector';\nexport { InputComponent } from '@agorapulse/ui-components/legacy/input';\nexport { SelectComponent } from '@agorapulse/ui-components/legacy/select';\nexport { TextareaComponent } from '@agorapulse/ui-components/legacy/textarea';\nexport { MediaDisplayOverlayDialogComponent } from '@agorapulse/ui-components/media-display-overlay';\nexport { ModalComponent, ModalConfig } from '@agorapulse/ui-components/modal';\nexport { NavSelectorComponent } from '@agorapulse/ui-components/nav-selector'\nexport {\n    DayDisabledPipe,\n    NeoDatePickerLocale,\n    NeoDatePickerMode,\n    NeoDatePickerStartsOn,\n    NeoDatepickerComponent,\n} from '@agorapulse/ui-components/neo-datepicker';\nexport { NotificationComponent } from '@agorapulse/ui-components/notification';\nexport { PaginatorButtonComponent, PaginatorComponent } from '@agorapulse/ui-components/paginator';\nexport { PasswordInputComponent } from '@agorapulse/ui-components/password-input';\nexport { PopmenuComponent } from '@agorapulse/ui-components/popmenu';\nexport { RadioComponent } from '@agorapulse/ui-components/radio';\nexport { SlideToggleComponent } from '@agorapulse/ui-components/slide-toggle';\nexport { SnackbarsThreadComponent } from '@agorapulse/ui-components/snackbars-thread';\nexport { SocialButtonComponent } from '@agorapulse/ui-components/social-button';\nexport { StatusComponent } from '@agorapulse/ui-components/status';\nexport { StatusCardActor, StatusCardComponent } from '@agorapulse/ui-components/status-card';\nexport { StepperComponent } from '@agorapulse/ui-components/stepper';\nexport { TagComponent } from '@agorapulse/ui-components/tag';\nexport { ToggleComponent } from '@agorapulse/ui-components/toggle';\n\n// Service\nexport { SnackbarsThreadService } from '@agorapulse/ui-components/snackbars-thread';\n\n// Model\nexport { ConfirmModalTexts } from '@agorapulse/ui-components/confirm-modal';\nexport {\n    CodeStatus,\n    SnackbarTypeValues,\n    SnackbarsThreadBase,\n    externalSnackbarTypeAllowed,\n    generateCodeStatus,\n} from '@agorapulse/ui-components/snackbars-thread';\nexport { Step } from '@agorapulse/ui-components/stepper';\n"]}
49
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../libs/ui-components/index.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,SAAS;AACT,OAAO,EAAE,aAAa,EAAE,MAAM,mCAAmC,CAAC;AAClE,OAAO,EAAE,4BAA4B,EAAE,MAAM,2CAA2C,CAAC;AAEzF,YAAY;AACZ,OAAO,EACH,yBAAyB,EACzB,iBAAiB,EACjB,qBAAqB,EACrB,iBAAiB,EACjB,uBAAuB,EACvB,kBAAkB,EAClB,uBAAuB,GAC1B,MAAM,sCAAsC,CAAC;AAC9C,OAAO,EAAE,gBAAgB,EAAE,MAAM,mCAAmC,CAAC;AACrE,OAAO,EAAE,gBAAgB,EAAE,MAAM,mCAAmC,CAAC;AAErE,YAAY;AACZ,OAAO,EAAE,mBAAmB,EAAE,MAAM,uCAAuC,CAAC;AAC5E,OAAO,EAAE,qBAAqB,EAAE,MAAM,wCAAwC,CAAC;AAC/E,OAAO,EAAE,eAAe,EAAE,MAAM,kCAAkC,CAAC;AACnE,OAAO,EAAE,cAAc,EAAE,MAAM,iCAAiC,CAAC;AACjE,OAAO,EAAE,eAAe,EAAE,MAAM,kCAAkC,CAAC;AACnE,OAAO,EAAE,iBAAiB,EAAE,MAAM,oCAAoC,CAAC;AACvE,OAAO,EAAE,qBAAqB,EAAE,MAAM,yCAAyC,CAAC;AAChF,OAAO,EAAE,gBAAgB,EAAE,MAAM,mCAAmC,CAAC;AACrE,OAAO,EAAE,mBAAmB,EAAE,cAAc,EAA0B,MAAM,sCAAsC,CAAC;AACnH,OAAO,EAAE,mBAAmB,EAAE,MAAM,uCAAuC,CAAC;AAC5E,OAAO,EAAE,mBAAmB,EAAE,MAAM,uCAAuC,CAAC;AAC5E,OAAO,EAAE,gBAAgB,EAAE,MAAM,mCAAmC,CAAC;AACrE,OAAO,EAAE,cAAc,EAAE,kBAAkB,EAAE,MAAM,kCAAkC,CAAC;AACtF,OAAO,EAAE,uBAAuB,EAAE,MAAM,2CAA2C,CAAC;AACpF,OAAO,EAAE,cAAc,EAAE,MAAM,wCAAwC,CAAC;AACxE,OAAO,EAAE,eAAe,EAAE,MAAM,yCAAyC,CAAC;AAC1E,OAAO,EAAE,iBAAiB,EAAE,MAAM,2CAA2C,CAAC;AAC9E,OAAO,EAAE,kCAAkC,EAAE,MAAM,iDAAiD,CAAC;AACrG,OAAO,EAAE,cAAc,EAAe,MAAM,iCAAiC,CAAC;AAC9E,OAAO,EAAE,oBAAoB,EAAE,MAAM,wCAAwC,CAAA;AAC7E,OAAO,EACH,eAAe,EAIf,sBAAsB,GACzB,MAAM,0CAA0C,CAAC;AAClD,OAAO,EAAE,qBAAqB,EAAE,MAAM,wCAAwC,CAAC;AAC/E,OAAO,EAAE,wBAAwB,EAAE,kBAAkB,EAAE,MAAM,qCAAqC,CAAC;AACnG,OAAO,EAAE,sBAAsB,EAAE,MAAM,0CAA0C,CAAC;AAClF,OAAO,EAAE,gBAAgB,EAAE,MAAM,mCAAmC,CAAC;AACrE,OAAO,EAAE,cAAc,EAAE,MAAM,iCAAiC,CAAC;AACjE,OAAO,EAAE,oBAAoB,EAAE,MAAM,wCAAwC,CAAC;AAC9E,OAAO,EAAE,wBAAwB,EAAE,MAAM,4CAA4C,CAAC;AACtF,OAAO,EAAE,qBAAqB,EAAE,MAAM,yCAAyC,CAAC;AAChF,OAAO,EAAE,eAAe,EAAE,MAAM,kCAAkC,CAAC;AACnE,OAAO,EAAmB,mBAAmB,EAAE,MAAM,uCAAuC,CAAC;AAC7F,OAAO,EAAE,gBAAgB,EAAE,MAAM,mCAAmC,CAAC;AACrE,OAAO,EAAE,YAAY,EAAE,MAAM,+BAA+B,CAAC;AAC7D,OAAO,EAAE,eAAe,EAAE,MAAM,kCAAkC,CAAC;AAEnE,UAAU;AACV,OAAO,EAAE,sBAAsB,EAAE,MAAM,4CAA4C,CAAC;AAIpF,OAAO,EACH,UAAU,EACV,kBAAkB,EAGlB,kBAAkB,GACrB,MAAM,4CAA4C,CAAC","sourcesContent":["/*\n * Public API Surface of ui\n */\n\n// Module\nexport { PopmenuModule } from '@agorapulse/ui-components/popmenu';\nexport { AgorapulseUiComponentsModule } from './src/lib/agorapulse-ui-components.module';\n\n// Directive\nexport {\n    AutosizeTextareaDirective,\n    CheckboxDirective,\n    DefaultImageDirective,\n    EllipsisDirective,\n    EqualValidatorDirective,\n    FrozenGifDirective,\n    MultiStyleTextDirective,\n} from '@agorapulse/ui-components/directives';\nexport { PopmenuDirective } from '@agorapulse/ui-components/popmenu';\nexport { TooltipDirective } from '@agorapulse/ui-components/tooltip';\n\n// Component\nexport { AddCommentComponent } from '@agorapulse/ui-components/add-comment';\nexport { AutocompleteComponent } from '@agorapulse/ui-components/autocomplete';\nexport { AvatarComponent } from '@agorapulse/ui-components/avatar';\nexport { BadgeComponent } from '@agorapulse/ui-components/badge';\nexport { ButtonComponent } from '@agorapulse/ui-components/button';\nexport { CheckboxComponent } from '@agorapulse/ui-components/checkbox';\nexport { ConfirmModalComponent } from '@agorapulse/ui-components/confirm-modal';\nexport { CounterComponent } from '@agorapulse/ui-components/counter';\nexport { DatepickerComponent, DatepickerMode, I18nDatePicker, Period } from '@agorapulse/ui-components/datepicker';\nexport { DotStepperComponent } from '@agorapulse/ui-components/dot-stepper';\nexport { IconButtonComponent } from '@agorapulse/ui-components/icon-button';\nexport { InfoboxComponent } from '@agorapulse/ui-components/infobox';\nexport { LabelComponent, LabelListComponent } from '@agorapulse/ui-components/labels';\nexport { LabelsSelectorComponent } from '@agorapulse/ui-components/labels-selector';\nexport { InputComponent } from '@agorapulse/ui-components/legacy/input';\nexport { SelectComponent } from '@agorapulse/ui-components/legacy/select';\nexport { TextareaComponent } from '@agorapulse/ui-components/legacy/textarea';\nexport { MediaDisplayOverlayDialogComponent } from '@agorapulse/ui-components/media-display-overlay';\nexport { ModalComponent, ModalConfig } from '@agorapulse/ui-components/modal';\nexport { NavSelectorComponent } from '@agorapulse/ui-components/nav-selector'\nexport {\n    DayDisabledPipe,\n    NeoDatePickerLocale,\n    NeoDatePickerMode,\n    NeoDatePickerStartsOn,\n    NeoDatepickerComponent,\n} from '@agorapulse/ui-components/neo-datepicker';\nexport { NotificationComponent } from '@agorapulse/ui-components/notification';\nexport { PaginatorButtonComponent, PaginatorComponent } from '@agorapulse/ui-components/paginator';\nexport { PasswordInputComponent } from '@agorapulse/ui-components/password-input';\nexport { PopmenuComponent } from '@agorapulse/ui-components/popmenu';\nexport { RadioComponent } from '@agorapulse/ui-components/radio';\nexport { SlideToggleComponent } from '@agorapulse/ui-components/slide-toggle';\nexport { SnackbarsThreadComponent } from '@agorapulse/ui-components/snackbars-thread';\nexport { SocialButtonComponent } from '@agorapulse/ui-components/social-button';\nexport { StatusComponent } from '@agorapulse/ui-components/status';\nexport { StatusCardActor, StatusCardComponent } from '@agorapulse/ui-components/status-card';\nexport { StepperComponent } from '@agorapulse/ui-components/stepper';\nexport { TagComponent } from '@agorapulse/ui-components/tag';\nexport { ToggleComponent } from '@agorapulse/ui-components/toggle';\n\n// Service\nexport { SnackbarsThreadService } from '@agorapulse/ui-components/snackbars-thread';\n\n// Model\nexport { ConfirmModalTexts } from '@agorapulse/ui-components/confirm-modal';\nexport {\n    CodeStatus,\n    SnackbarTypeValues,\n    SnackbarsThreadBase,\n    externalSnackbarTypeAllowed,\n    generateCodeStatus,\n} from '@agorapulse/ui-components/snackbars-thread';\nexport { Step } from '@agorapulse/ui-components/stepper';\n"]}