@agorapulse/ui-components 17.0.0-beta.2 → 17.0.0-beta.4

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.
@@ -1,3 +1,2 @@
1
- export * from './radio-control.registry';
2
1
  export * from './radio.component';
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljX2FwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL2xpYnMvdWktY29tcG9uZW50cy9yYWRpby9zcmMvcHVibGljX2FwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLDBCQUEwQixDQUFDO0FBQ3pDLGNBQWMsbUJBQW1CLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL3JhZGlvLWNvbnRyb2wucmVnaXN0cnknO1xuZXhwb3J0ICogZnJvbSAnLi9yYWRpby5jb21wb25lbnQnO1xuIl19
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljX2FwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL2xpYnMvdWktY29tcG9uZW50cy9yYWRpby9zcmMvcHVibGljX2FwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLG1CQUFtQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9yYWRpby5jb21wb25lbnQnO1xuIl19
@@ -1,9 +1,105 @@
1
- import { booleanAttribute, ChangeDetectionStrategy, ChangeDetectorRef, Component, EventEmitter, inject, Injector, Input, NgZone, Output, ViewChild, ViewEncapsulation, } from '@angular/core';
2
1
  import { SymbolComponent } from '@agorapulse/ui-symbol';
3
- import { NgControl } from '@angular/forms';
2
+ import { booleanAttribute, ChangeDetectionStrategy, ChangeDetectorRef, Component, EventEmitter, forwardRef, inject, Injectable, Injector, Input, NgZone, Output, ViewChild, ViewEncapsulation, } from '@angular/core';
3
+ import { NG_VALUE_ACCESSOR, NgControl } from '@angular/forms';
4
4
  import { filter, fromEvent, Subject, takeUntil } from 'rxjs';
5
- import { RADIO_VALUE_ACCESSOR, RadioControlRegistry } from './radio-control.registry';
6
5
  import * as i0 from "@angular/core";
6
+ export const RADIO_VALUE_ACCESSOR = {
7
+ provide: NG_VALUE_ACCESSOR,
8
+ useExisting: forwardRef(() => RadioComponent),
9
+ multi: true,
10
+ };
11
+ export class RadioControlRegistry {
12
+ accessors = [];
13
+ add(control, accessor) {
14
+ this.accessors.push([control, accessor]);
15
+ }
16
+ remove(accessor) {
17
+ this.accessors = this.accessors.filter(([, radioComponent]) => {
18
+ return radioComponent !== accessor;
19
+ });
20
+ }
21
+ select(accessor) {
22
+ this.accessors.forEach(([ngControl, radioComponent]) => {
23
+ if (this.isSameGroup(ngControl, radioComponent, accessor) && radioComponent !== accessor) {
24
+ radioComponent.writeValue(accessor.value);
25
+ }
26
+ });
27
+ }
28
+ getIndex(accessor) {
29
+ return this.accessors.findIndex(([, radioComponent]) => {
30
+ return radioComponent === accessor;
31
+ });
32
+ }
33
+ getNextRadio(accessor) {
34
+ const index = this.getIndex(accessor);
35
+ const nextIndex = index + 1;
36
+ if (nextIndex >= this.accessors.length) {
37
+ return this.accessors[0][1];
38
+ }
39
+ const nextRadio = this.accessors[nextIndex];
40
+ return nextRadio ? nextRadio[1] : null;
41
+ }
42
+ getPreviousRadio(accessor) {
43
+ const index = this.getIndex(accessor);
44
+ if (index === 0) {
45
+ return this.accessors[this.accessors.length - 1][1];
46
+ }
47
+ const previousIndex = index - 1;
48
+ const previousRadio = this.accessors[previousIndex];
49
+ return previousRadio ? previousRadio[1] : null;
50
+ }
51
+ blurAllGroup(accessor) {
52
+ this.accessors.forEach(([, radioComponent]) => {
53
+ if (this.isSameGroup(accessor.control, radioComponent, accessor)) {
54
+ radioComponent.inputElement.nativeElement.blur();
55
+ }
56
+ });
57
+ }
58
+ setNegativeTabIndexToAllExcept(accessor) {
59
+ this.accessors.forEach(([, radioComponent]) => {
60
+ if (this.isSameGroup(accessor.control, radioComponent, accessor)) {
61
+ if (accessor.radioId !== radioComponent.radioId) {
62
+ radioComponent.inputElement.nativeElement.tabIndex = -1;
63
+ }
64
+ else {
65
+ radioComponent.inputElement.nativeElement.tabIndex = 0;
66
+ }
67
+ }
68
+ });
69
+ }
70
+ focusPrevious(accessor) {
71
+ const previousRadio = this.getPreviousRadio(accessor);
72
+ if (previousRadio) {
73
+ previousRadio.inputElement.nativeElement.focus();
74
+ }
75
+ }
76
+ focusNext(accessor) {
77
+ const nextRadio = this.getNextRadio(accessor);
78
+ if (nextRadio) {
79
+ nextRadio.inputElement.nativeElement.focus();
80
+ }
81
+ }
82
+ getFirstCheckedRadio() {
83
+ const checkedRadio = this.accessors.find(([, radioComponent]) => {
84
+ return radioComponent.checked;
85
+ });
86
+ return checkedRadio ? checkedRadio[1] : null;
87
+ }
88
+ isSameGroup(ngControl, radioComponent, accessor) {
89
+ if (!ngControl.control) {
90
+ return false;
91
+ }
92
+ return radioComponent.name === accessor.name;
93
+ }
94
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.3", ngImport: i0, type: RadioControlRegistry, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
95
+ static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.3", ngImport: i0, type: RadioControlRegistry, providedIn: 'root' });
96
+ }
97
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.3", ngImport: i0, type: RadioControlRegistry, decorators: [{
98
+ type: Injectable,
99
+ args: [{
100
+ providedIn: 'root',
101
+ }]
102
+ }] });
7
103
  export class RadioComponent {
8
104
  elementRef;
9
105
  injector = inject(Injector);
@@ -220,4 +316,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.3", ngImpor
220
316
  }], onBlur: [{
221
317
  type: Output
222
318
  }] } });
223
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"radio.component.js","sourceRoot":"","sources":["../../../../libs/ui-components/radio/src/radio.component.ts","../../../../libs/ui-components/radio/src/radio.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterContentInit,\n    booleanAttribute,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    EventEmitter,\n    inject,\n    Injector,\n    Input,\n    NgZone,\n    OnChanges,\n    OnDestroy,\n    OnInit,\n    Output,\n    ViewChild,\n    ViewEncapsulation,\n} from '@angular/core';\n\nimport { SymbolComponent } from '@agorapulse/ui-symbol';\nimport { ControlValueAccessor, NgControl } from '@angular/forms';\nimport { filter, fromEvent, Subject, takeUntil } from 'rxjs';\nimport { RADIO_VALUE_ACCESSOR, RadioControlRegistry } from './radio-control.registry';\n\n@Component({\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    selector: 'ap-radio',\n    styleUrls: ['./radio.component.scss'],\n    standalone: true,\n    imports: [SymbolComponent],\n    providers: [RADIO_VALUE_ACCESSOR],\n    templateUrl: './radio.component.html',\n    encapsulation: ViewEncapsulation.None,\n})\nexport class RadioComponent implements ControlValueAccessor, AfterContentInit, OnChanges, OnInit, OnDestroy {\n    public readonly injector: Injector = inject(Injector);\n    private readonly changeDetectorRef: ChangeDetectorRef = inject(ChangeDetectorRef);\n    private readonly radioControlRegistry: RadioControlRegistry = inject(RadioControlRegistry);\n    private readonly ngZone: NgZone = inject(NgZone);\n\n    @ViewChild('input', { static: true }) inputElement!: ElementRef<HTMLInputElement>;\n    @ViewChild('label', { static: true }) labelElement!: ElementRef<HTMLInputElement>;\n    @Input('aria-label') ariaLabel = '';\n    @Input('aria-labelledby') ariaLabelledby: string | null = null;\n    @Input('aria-describedby') ariaDescribedby = '';\n    @Input({\n        transform: booleanAttribute,\n    })\n    set disabled(disabled: boolean) {\n        this._disabled = disabled;\n    }\n\n    get disabled(): boolean {\n        return this._disabled;\n    }\n    @Input() labelPosition: 'left' | 'right' = 'right';\n    @Input({\n        required: true,\n    })\n    radioId = '';\n    @Input() formControlName!: string;\n    @Input({\n        required: true,\n    })\n    value: unknown;\n    @Input({\n        transform: booleanAttribute,\n    })\n    required = false;\n    @Input() name = '';\n\n    // eslint-disable-next-line @angular-eslint/no-output-on-prefix\n    @Output() onClick: EventEmitter<{\n        originalEvent: Event;\n        value: unknown;\n    }> = new EventEmitter();\n\n    // eslint-disable-next-line @angular-eslint/no-output-on-prefix\n    @Output() onFocus: EventEmitter<FocusEvent> = new EventEmitter();\n\n    // eslint-disable-next-line @angular-eslint/no-output-on-prefix\n    @Output() onBlur: EventEmitter<FocusEvent> = new EventEmitter();\n\n    inputId = '';\n    _disabled = false;\n    hasLabel = false;\n    hostDataTest: string | undefined;\n    control!: NgControl;\n    checked = false;\n    focused = false;\n    radioIndex = 0;\n    private readonly destroy$: Subject<void> = new Subject<void>();\n\n    public onModelChange: (value: unknown) => void = () => {\n        // ignore\n    };\n\n    public onModelTouched: () => void = () => {\n        // ignore\n    };\n\n    constructor(private elementRef: ElementRef) {\n        this.hostDataTest = elementRef.nativeElement.getAttribute('data-test');\n\n        this.ngZone.runOutsideAngular(() => {\n            fromEvent(window, 'keydown')\n                .pipe(\n                    filter((event): event is KeyboardEvent => 'key' in event),\n                    takeUntil(this.destroy$)\n                )\n                .subscribe((event: KeyboardEvent) => {\n                    // Handle keydown event\n                    switch (event.key) {\n                        case 'ArrowDown':\n                        case 'ArrowRight':\n                            this.ngZone.run(() => {\n                                if (this.focused) {\n                                    event.stopImmediatePropagation();\n                                    this.radioControlRegistry.blurAllGroup(this);\n                                    this.radioControlRegistry.focusNext(this);\n                                }\n                            });\n                            break;\n                        case 'ArrowUp':\n                        case 'ArrowLeft':\n                            this.ngZone.run(() => {\n                                event.preventDefault();\n                                if (this.focused) {\n                                    event.stopImmediatePropagation();\n                                    this.radioControlRegistry.blurAllGroup(this);\n                                    this.radioControlRegistry.focusPrevious(this);\n                                }\n                            });\n                            break;\n                        default:\n                            return;\n                    }\n                });\n        });\n    }\n\n    ngOnChanges(): void {\n        if (this.labelElement) {\n            this.hasLabel = !!this.labelElement.nativeElement.textContent?.trim();\n        }\n    }\n\n    ngOnInit() {\n        this.control = this.injector.get(NgControl);\n        this.checkName();\n        this.radioControlRegistry.add(this.control, this);\n        this.radioIndex = this.radioControlRegistry.getIndex(this);\n        this.inputId = `${this.radioId}-${this.radioIndex}`;\n    }\n\n    ngAfterContentInit(): void {\n        if (this.labelElement) {\n            this.hasLabel = !!this.labelElement.nativeElement.textContent?.trim();\n        }\n    }\n\n    ngOnDestroy() {\n        this.radioControlRegistry.remove(this);\n        this.destroy$.next();\n        this.destroy$.complete();\n    }\n\n    handleClick(event: MouseEvent, radioButton: HTMLInputElement) {\n        event.preventDefault();\n\n        if (this.disabled) {\n            return;\n        }\n        this.select(event);\n        radioButton.focus();\n    }\n\n    select(event: Event) {\n        if (!this.disabled) {\n            this.inputElement.nativeElement.checked = true;\n            this.checked = true;\n            this.onModelChange(this.value);\n            this.radioControlRegistry.select(this);\n            this.onClick.emit({ originalEvent: event, value: this.value });\n        }\n    }\n\n    writeValue(value: unknown): void {\n        this.checked = value == this.value;\n\n        if (this.inputElement?.nativeElement) {\n            this.inputElement.nativeElement.checked = this.checked;\n        }\n\n        this.changeDetectorRef.markForCheck();\n    }\n\n    registerOnChange(fn: () => void): void {\n        this.onModelChange = fn;\n    }\n\n    registerOnTouched(fn: () => void): void {\n        this.onModelTouched = fn;\n    }\n\n    onInputFocus(event: FocusEvent) {\n        this.radioControlRegistry.setNegativeTabIndexToAllExcept(this);\n        this.inputElement.nativeElement.checked = true;\n        this.checked = true;\n        this.onModelChange(this.value);\n        this.focused = true;\n        this.onFocus.emit(event);\n    }\n\n    onInputBlur(event: FocusEvent) {\n        this.focused = false;\n        this.onModelTouched();\n        this.onBlur.emit(event);\n    }\n\n    onChange(event: Event) {\n        this.select(event);\n    }\n\n    private checkName() {\n        if (this.name && this.formControlName && this.name !== this.formControlName) {\n            this.throwNameError();\n        }\n        if (!this.name && this.formControlName) {\n            this.name = this.formControlName;\n        }\n    }\n\n    private throwNameError() {\n        throw new Error(`\n          If you define both a name and a formControlName attribute on your radio button, their values\n          must match. Ex: <p-radioButton formControlName=\"food\" name=\"food\"></p-radioButton>\n        `);\n    }\n}\n","<div\n    class=\"radio-button-container\"\n    [class.label-left]=\"labelPosition === 'left'\">\n    <input\n        #input\n        type=\"radio\"\n        tabindex=\"0\"\n        [attr.id]=\"inputId\"\n        [attr.name]=\"name + '-radio-' + radioIndex\"\n        [attr.value]=\"value\"\n        [attr.aria-checked]=\"checked\"\n        [attr.aria-label]=\"ariaLabel || null\"\n        [attr.aria-labelledby]=\"ariaLabelledby\"\n        [attr.aria-describedby]=\"ariaDescribedby\"\n        [attr.data-test]=\"hostDataTest ?? name\"\n        [checked]=\"checked\"\n        [class.disabled]=\"disabled\"\n        (change)=\"onChange($event)\"\n        (blur)=\"onInputBlur($event)\"\n        (focus)=\"onInputFocus($event)\" />\n    <div\n        class=\"radio-button\"\n        [class.disabled]=\"disabled\"\n        (click)=\"select($event)\"></div>\n    <label\n        [for]=\"inputId\"\n        (click)=\"select($event)\">\n        <ng-content />\n    </label>\n</div>\n"]}
319
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"radio.component.js","sourceRoot":"","sources":["../../../../libs/ui-components/radio/src/radio.component.ts","../../../../libs/ui-components/radio/src/radio.component.html"],"names":[],"mappings":"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","sourcesContent":["import { SymbolComponent } from '@agorapulse/ui-symbol';\nimport {\n    AfterContentInit,\n    booleanAttribute,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    EventEmitter,\n    forwardRef,\n    inject,\n    Injectable,\n    Injector,\n    Input,\n    NgZone,\n    OnChanges,\n    OnDestroy,\n    OnInit,\n    Output,\n    Provider,\n    ViewChild,\n    ViewEncapsulation,\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR, NgControl } from '@angular/forms';\nimport { filter, fromEvent, Subject, takeUntil } from 'rxjs';\n\nexport const RADIO_VALUE_ACCESSOR: Provider = {\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: forwardRef(() => RadioComponent),\n    multi: true,\n};\n\n@Injectable({\n    providedIn: 'root',\n})\nexport class RadioControlRegistry {\n    private accessors: [NgControl, RadioComponent][] = [];\n\n    add(control: NgControl, accessor: RadioComponent) {\n        this.accessors.push([control, accessor]);\n    }\n\n    remove(accessor: RadioComponent) {\n        this.accessors = this.accessors.filter(([, radioComponent]) => {\n            return radioComponent !== accessor;\n        });\n    }\n\n    select(accessor: RadioComponent) {\n        this.accessors.forEach(([ngControl, radioComponent]) => {\n            if (this.isSameGroup(ngControl, radioComponent, accessor) && radioComponent !== accessor) {\n                radioComponent.writeValue(accessor.value);\n            }\n        });\n    }\n\n    getIndex(accessor: RadioComponent): number {\n        return this.accessors.findIndex(([, radioComponent]) => {\n            return radioComponent === accessor;\n        });\n    }\n\n    getNextRadio(accessor: RadioComponent): RadioComponent | null {\n        const index = this.getIndex(accessor);\n        const nextIndex = index + 1;\n        if (nextIndex >= this.accessors.length) {\n            return this.accessors[0][1];\n        }\n        const nextRadio = this.accessors[nextIndex];\n        return nextRadio ? nextRadio[1] : null;\n    }\n\n    getPreviousRadio(accessor: RadioComponent): RadioComponent | null {\n        const index = this.getIndex(accessor);\n        if (index === 0) {\n            return this.accessors[this.accessors.length - 1][1];\n        }\n        const previousIndex = index - 1;\n        const previousRadio = this.accessors[previousIndex];\n        return previousRadio ? previousRadio[1] : null;\n    }\n\n    blurAllGroup(accessor: RadioComponent): void {\n        this.accessors.forEach(([, radioComponent]) => {\n            if (this.isSameGroup(accessor.control, radioComponent, accessor)) {\n                radioComponent.inputElement.nativeElement.blur();\n            }\n        });\n    }\n\n    setNegativeTabIndexToAllExcept(accessor: RadioComponent): void {\n        this.accessors.forEach(([, radioComponent]) => {\n            if (this.isSameGroup(accessor.control, radioComponent, accessor)) {\n                if (accessor.radioId !== radioComponent.radioId) {\n                    radioComponent.inputElement.nativeElement.tabIndex = -1;\n                } else {\n                    radioComponent.inputElement.nativeElement.tabIndex = 0;\n                }\n            }\n        });\n    }\n\n    focusPrevious(accessor: RadioComponent): void {\n        const previousRadio = this.getPreviousRadio(accessor);\n        if (previousRadio) {\n            previousRadio.inputElement.nativeElement.focus();\n        }\n    }\n\n    focusNext(accessor: RadioComponent): void {\n        const nextRadio = this.getNextRadio(accessor);\n        if (nextRadio) {\n            nextRadio.inputElement.nativeElement.focus();\n        }\n    }\n\n    getFirstCheckedRadio(): RadioComponent | null {\n        const checkedRadio = this.accessors.find(([, radioComponent]) => {\n            return radioComponent.checked;\n        });\n        return checkedRadio ? checkedRadio[1] : null;\n    }\n\n    private isSameGroup(ngControl: NgControl, radioComponent: RadioComponent, accessor: RadioComponent): boolean {\n        if (!ngControl.control) {\n            return false;\n        }\n        return radioComponent.name === accessor.name;\n    }\n}\n\n@Component({\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    selector: 'ap-radio',\n    styleUrls: ['./radio.component.scss'],\n    standalone: true,\n    imports: [SymbolComponent],\n    providers: [RADIO_VALUE_ACCESSOR],\n    templateUrl: './radio.component.html',\n    encapsulation: ViewEncapsulation.None,\n})\nexport class RadioComponent implements ControlValueAccessor, AfterContentInit, OnChanges, OnInit, OnDestroy {\n    public readonly injector: Injector = inject(Injector);\n    private readonly changeDetectorRef: ChangeDetectorRef = inject(ChangeDetectorRef);\n    private readonly radioControlRegistry: RadioControlRegistry = inject(RadioControlRegistry);\n    private readonly ngZone: NgZone = inject(NgZone);\n\n    @ViewChild('input', { static: true }) inputElement!: ElementRef<HTMLInputElement>;\n    @ViewChild('label', { static: true }) labelElement!: ElementRef<HTMLInputElement>;\n    @Input('aria-label') ariaLabel = '';\n    @Input('aria-labelledby') ariaLabelledby: string | null = null;\n    @Input('aria-describedby') ariaDescribedby = '';\n    @Input({\n        transform: booleanAttribute,\n    })\n    set disabled(disabled: boolean) {\n        this._disabled = disabled;\n    }\n\n    get disabled(): boolean {\n        return this._disabled;\n    }\n    @Input() labelPosition: 'left' | 'right' = 'right';\n    @Input({\n        required: true,\n    })\n    radioId = '';\n    @Input() formControlName!: string;\n    @Input({\n        required: true,\n    })\n    value: unknown;\n    @Input({\n        transform: booleanAttribute,\n    })\n    required = false;\n    @Input() name = '';\n\n    // eslint-disable-next-line @angular-eslint/no-output-on-prefix\n    @Output() onClick: EventEmitter<{\n        originalEvent: Event;\n        value: unknown;\n    }> = new EventEmitter();\n\n    // eslint-disable-next-line @angular-eslint/no-output-on-prefix\n    @Output() onFocus: EventEmitter<FocusEvent> = new EventEmitter();\n\n    // eslint-disable-next-line @angular-eslint/no-output-on-prefix\n    @Output() onBlur: EventEmitter<FocusEvent> = new EventEmitter();\n\n    inputId = '';\n    _disabled = false;\n    hasLabel = false;\n    hostDataTest: string | undefined;\n    control!: NgControl;\n    checked = false;\n    focused = false;\n    radioIndex = 0;\n    private readonly destroy$: Subject<void> = new Subject<void>();\n\n    public onModelChange: (value: unknown) => void = () => {\n        // ignore\n    };\n\n    public onModelTouched: () => void = () => {\n        // ignore\n    };\n\n    constructor(private elementRef: ElementRef) {\n        this.hostDataTest = elementRef.nativeElement.getAttribute('data-test');\n\n        this.ngZone.runOutsideAngular(() => {\n            fromEvent(window, 'keydown')\n                .pipe(\n                    filter((event): event is KeyboardEvent => 'key' in event),\n                    takeUntil(this.destroy$)\n                )\n                .subscribe((event: KeyboardEvent) => {\n                    // Handle keydown event\n                    switch (event.key) {\n                        case 'ArrowDown':\n                        case 'ArrowRight':\n                            this.ngZone.run(() => {\n                                if (this.focused) {\n                                    event.stopImmediatePropagation();\n                                    this.radioControlRegistry.blurAllGroup(this);\n                                    this.radioControlRegistry.focusNext(this);\n                                }\n                            });\n                            break;\n                        case 'ArrowUp':\n                        case 'ArrowLeft':\n                            this.ngZone.run(() => {\n                                event.preventDefault();\n                                if (this.focused) {\n                                    event.stopImmediatePropagation();\n                                    this.radioControlRegistry.blurAllGroup(this);\n                                    this.radioControlRegistry.focusPrevious(this);\n                                }\n                            });\n                            break;\n                        default:\n                            return;\n                    }\n                });\n        });\n    }\n\n    ngOnChanges(): void {\n        if (this.labelElement) {\n            this.hasLabel = !!this.labelElement.nativeElement.textContent?.trim();\n        }\n    }\n\n    ngOnInit() {\n        this.control = this.injector.get(NgControl);\n        this.checkName();\n        this.radioControlRegistry.add(this.control, this);\n        this.radioIndex = this.radioControlRegistry.getIndex(this);\n        this.inputId = `${this.radioId}-${this.radioIndex}`;\n    }\n\n    ngAfterContentInit(): void {\n        if (this.labelElement) {\n            this.hasLabel = !!this.labelElement.nativeElement.textContent?.trim();\n        }\n    }\n\n    ngOnDestroy() {\n        this.radioControlRegistry.remove(this);\n        this.destroy$.next();\n        this.destroy$.complete();\n    }\n\n    handleClick(event: MouseEvent, radioButton: HTMLInputElement) {\n        event.preventDefault();\n\n        if (this.disabled) {\n            return;\n        }\n        this.select(event);\n        radioButton.focus();\n    }\n\n    select(event: Event) {\n        if (!this.disabled) {\n            this.inputElement.nativeElement.checked = true;\n            this.checked = true;\n            this.onModelChange(this.value);\n            this.radioControlRegistry.select(this);\n            this.onClick.emit({ originalEvent: event, value: this.value });\n        }\n    }\n\n    writeValue(value: unknown): void {\n        this.checked = value == this.value;\n\n        if (this.inputElement?.nativeElement) {\n            this.inputElement.nativeElement.checked = this.checked;\n        }\n\n        this.changeDetectorRef.markForCheck();\n    }\n\n    registerOnChange(fn: () => void): void {\n        this.onModelChange = fn;\n    }\n\n    registerOnTouched(fn: () => void): void {\n        this.onModelTouched = fn;\n    }\n\n    onInputFocus(event: FocusEvent) {\n        this.radioControlRegistry.setNegativeTabIndexToAllExcept(this);\n        this.inputElement.nativeElement.checked = true;\n        this.checked = true;\n        this.onModelChange(this.value);\n        this.focused = true;\n        this.onFocus.emit(event);\n    }\n\n    onInputBlur(event: FocusEvent) {\n        this.focused = false;\n        this.onModelTouched();\n        this.onBlur.emit(event);\n    }\n\n    onChange(event: Event) {\n        this.select(event);\n    }\n\n    private checkName() {\n        if (this.name && this.formControlName && this.name !== this.formControlName) {\n            this.throwNameError();\n        }\n        if (!this.name && this.formControlName) {\n            this.name = this.formControlName;\n        }\n    }\n\n    private throwNameError() {\n        throw new Error(`\n          If you define both a name and a formControlName attribute on your radio button, their values\n          must match. Ex: <p-radioButton formControlName=\"food\" name=\"food\"></p-radioButton>\n        `);\n    }\n}\n","<div\n    class=\"radio-button-container\"\n    [class.label-left]=\"labelPosition === 'left'\">\n    <input\n        #input\n        type=\"radio\"\n        tabindex=\"0\"\n        [attr.id]=\"inputId\"\n        [attr.name]=\"name + '-radio-' + radioIndex\"\n        [attr.value]=\"value\"\n        [attr.aria-checked]=\"checked\"\n        [attr.aria-label]=\"ariaLabel || null\"\n        [attr.aria-labelledby]=\"ariaLabelledby\"\n        [attr.aria-describedby]=\"ariaDescribedby\"\n        [attr.data-test]=\"hostDataTest ?? name\"\n        [checked]=\"checked\"\n        [class.disabled]=\"disabled\"\n        (change)=\"onChange($event)\"\n        (blur)=\"onInputBlur($event)\"\n        (focus)=\"onInputFocus($event)\" />\n    <div\n        class=\"radio-button\"\n        [class.disabled]=\"disabled\"\n        (click)=\"select($event)\"></div>\n    <label\n        [for]=\"inputId\"\n        (click)=\"select($event)\">\n        <ng-content />\n    </label>\n</div>\n"]}
@@ -4,7 +4,7 @@ import { AsyncPipe } from '@angular/common';
4
4
  import { ChangeDetectionStrategy, Component } from '@angular/core';
5
5
  import { snackbarIconsMap, snackbarTypesMap } from '../utils/const/snackbars-thread.const';
6
6
  import * as i0 from "@angular/core";
7
- import * as i1 from "../public_api";
7
+ import * as i1 from "../service/snackbars-thread.service";
8
8
  import * as i2 from "@agorapulse/ui-symbol";
9
9
  import * as i3 from "@angular/router";
10
10
  export class SnackbarsThreadComponent {
@@ -81,4 +81,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.3", ngImpor
81
81
  ]),
82
82
  ], template: "<div class=\"thread-container\">\n @for (el of snackbarsThreadService.snackbarList | async; track el) {\n <div\n @fadeAnimation\n class=\"item {{ SnackbarTypesMap[el.snackbarType] }}\">\n <div class=\"left\">\n <div class=\"icon {{ SnackbarTypesMap[el.snackbarType] }}\">\n <ap-symbol\n size=\"micro\"\n [attr.aria-label]=\"SnackbarTypesMap[el.snackbarType]\"\n [symbolId]=\"SnackbarIconsMap[el.snackbarType]\" />\n </div>\n <div class=\"text\">\n <div [innerHTML]=\"el.snackbarText\"></div>\n </div>\n </div>\n <div class=\"right\">\n <ng-container *ngIf=\"el.navigateInternalUrl?.length && el.actionName?.length\">\n <a\n class=\"standalone link\"\n role=\"link\"\n tabindex=\"0\"\n (click)=\"onActionClick(el.navigateInternalUrl ?? '', el.id)\"\n (keyup)=\"onActionClick(el.navigateInternalUrl ?? '', el.id)\">\n {{ el.actionName }}\n </a>\n </ng-container>\n <div\n class=\"close\"\n tabindex=\"0\"\n (click)=\"remove(el.id)\"\n (keyup)=\"remove(el.id)\">\n <ap-symbol\n aria-label=\"close-snackbar\"\n size=\"20px\"\n symbolId=\"delete-no-circle\" />\n </div>\n </div>\n </div>\n }\n</div>\n", styles: ["[color=facebook]{color:#0866ff}[bgcolor=facebook],[hcolor=facebook]:hover{background-color:#0866ff}[border=facebook]{border:1px solid #0866ff}[color=google]{color:#4e85e8}[bgcolor=google],[hcolor=google]:hover{background-color:#4e85e8}[border=google]{border:1px solid #4e85e8}[color=instagram]{color:#e1306c}[bgcolor=instagram],[hcolor=instagram]:hover{background-color:#e1306c}[border=instagram]{border:1px solid #e1306c}[color=instagrammagenta]{color:#c13584}[bgcolor=instagrammagenta],[hcolor=instagrammagenta]:hover{background-color:#c13584}[border=instagrammagenta]{border:1px solid #c13584}[color=instagramblue]{color:#5851db}[bgcolor=instagramblue],[hcolor=instagramblue]:hover{background-color:#5851db}[border=instagramblue]{border:1px solid #5851db}[color=instagrampurple]{color:#833ab4}[bgcolor=instagrampurple],[hcolor=instagrampurple]:hover{background-color:#833ab4}[border=instagrampurple]{border:1px solid #833ab4}[color=instagramorange]{color:#f56040}[bgcolor=instagramorange],[hcolor=instagramorange]:hover{background-color:#f56040}[border=instagramorange]{border:1px solid #f56040}[color=instagramyellow]{color:#ffdc80}[bgcolor=instagramyellow],[hcolor=instagramyellow]:hover{background-color:#ffdc80}[border=instagramyellow]{border:1px solid #ffdc80}[color=linkedin]{color:#2c67bc}[bgcolor=linkedin],[hcolor=linkedin]:hover{background-color:#2c67bc}[border=linkedin]{border:1px solid #2c67bc}[color=twitter]{color:#55acee}[bgcolor=twitter],[hcolor=twitter]:hover{background-color:#55acee}[border=twitter]{border:1px solid #55acee}[color=youtube]{color:red}[bgcolor=youtube],[hcolor=youtube]:hover{background-color:red}[border=youtube]{border:1px solid #ff0000}[color=blood-orange]{color:#ff4d00}[bgcolor=blood-orange],[hcolor=blood-orange]:hover{background-color:#ff4d00}[border=blood-orange]{border:1px solid #ff4d00}[color=pinkish-orange]{color:#ff7b49}[bgcolor=pinkish-orange],[hcolor=pinkish-orange]:hover{background-color:#ff7b49}[border=pinkish-orange]{border:1px solid #ff7b49}[color=charcoal-grey]{color:#2a2f34}[bgcolor=charcoal-grey],[hcolor=charcoal-grey]:hover{background-color:#2a2f34}[border=charcoal-grey]{border:1px solid #2a2f34}[color=azure]{color:#00aeef}[bgcolor=azure],[hcolor=azure]:hover{background-color:#00aeef}[border=azure]{border:1px solid #00aeef}[color=light-azure]{color:#eaf5fd}[bgcolor=light-azure],[hcolor=light-azure]:hover{background-color:#eaf5fd}[border=light-azure]{border:1px solid #eaf5fd}[color=blue-grey]{color:#8d98a9}[bgcolor=blue-grey],[hcolor=blue-grey]:hover{background-color:#8d98a9}[border=blue-grey]{border:1px solid #8d98a9}[color=silver]{color:#ced0da}[bgcolor=silver],[hcolor=silver]:hover{background-color:#ced0da}[border=silver]{border:1px solid #ced0da}[color=pale-grey]{color:#dfe3e9}[bgcolor=pale-grey],[hcolor=pale-grey]:hover{background-color:#dfe3e9}[border=pale-grey]{border:1px solid #dfe3e9}[color=grey-white]{color:#f5f7f8}[bgcolor=grey-white],[hcolor=grey-white]:hover{background-color:#f5f7f8}[border=grey-white]{border:1px solid #f5f7f8}[color=cool-grey]{color:#b4bbc6}[bgcolor=cool-grey],[hcolor=cool-grey]:hover{background-color:#b4bbc6}[border=cool-grey]{border:1px solid #b4bbc6}[color=black]{color:#344563}[bgcolor=black],[hcolor=black]:hover{background-color:#344563}[border=black]{border:1px solid #344563}[color=grey-blue]{color:#68768c}[bgcolor=grey-blue],[hcolor=grey-blue]:hover{background-color:#68768c}[border=grey-blue]{border:1px solid #68768c}[color=strawberry]{color:#f4282d}[bgcolor=strawberry],[hcolor=strawberry]:hover{background-color:#f4282d}[border=strawberry]{border:1px solid #f4282d}[color=light-strawberry]{color:#f8eded}[bgcolor=light-strawberry],[hcolor=light-strawberry]:hover{background-color:#f8eded}[border=light-strawberry]{border:1px solid #f8eded}[color=white]{color:#fff}[bgcolor=white],[hcolor=white]:hover{background-color:#fff}[border=white]{border:1px solid #ffffff}[color=cool-green]{color:#33c15d}[bgcolor=cool-green],[hcolor=cool-green]:hover{background-color:#33c15d}[border=cool-green]{border:1px solid #33c15d}[color=light-green]{color:#ebfaef}[bgcolor=light-green],[hcolor=light-green]:hover{background-color:#ebfaef}[border=light-green]{border:1px solid #ebfaef}[color=transparent]{color:transparent}[bgcolor=transparent],[hcolor=transparent]:hover{background-color:transparent}[border=transparent]{border:1px solid transparent}[color=c0]{color:#a566a5}[bgcolor=c0],[hcolor=c0]:hover{background-color:#a566a5}[border=c0]{border:1px solid #a566a5}[color=c1]{color:#c7ab82}[bgcolor=c1],[hcolor=c1]:hover{background-color:#c7ab82}[border=c1]{border:1px solid #c7ab82}[color=c2]{color:#f2713c}[bgcolor=c2],[hcolor=c2]:hover{background-color:#f2713c}[border=c2]{border:1px solid #f2713c}[color=c3]{color:#ffd006}[bgcolor=c3],[hcolor=c3]:hover{background-color:#ffd006}[border=c3]{border:1px solid #ffd006}[color=c4]{color:#94c5aa}[bgcolor=c4],[hcolor=c4]:hover{background-color:#94c5aa}[border=c4]{border:1px solid #94c5aa}[color=c5]{color:#2a9d8f}[bgcolor=c5],[hcolor=c5]:hover{background-color:#2a9d8f}[border=c5]{border:1px solid #2a9d8f}[color=c6]{color:#78acd8}[bgcolor=c6],[hcolor=c6]:hover{background-color:#78acd8}[border=c6]{border:1px solid #78acd8}[color=c7]{color:#525a9e}[bgcolor=c7],[hcolor=c7]:hover{background-color:#525a9e}[border=c7]{border:1px solid #525a9e}[color=c8]{color:#6a2459}[bgcolor=c8],[hcolor=c8]:hover{background-color:#6a2459}[border=c8]{border:1px solid #6a2459}[color=c9]{color:#74729e}[bgcolor=c9],[hcolor=c9]:hover{background-color:#74729e}[border=c9]{border:1px solid #74729e}.thread-container{position:absolute;top:68px;right:var(--ref-spacing-lg);width:var(--comp-snackbar-width);z-index:999999999;gap:var(--comp-snackbar-spacing);display:flex;flex-direction:column}.thread-container .item{align-items:center;height:auto;padding:var(--comp-snackbar-padding-vertical) var(--comp-snackbar-padding-horizontal);box-sizing:border-box;box-shadow:var(--comp-snackbar-shadow);border-radius:var(--comp-snackbar-border-radius);display:flex;flex-direction:row;justify-content:space-between;gap:var(--comp-snackbar-spacing)}.thread-container .item.success{background-color:var(--comp-snackbar-success-background-color)}.thread-container .item.error{background-color:var(--comp-snackbar-error-background-color)}.thread-container .item .left,.thread-container .item .right{display:flex;gap:var(--comp-snackbar-spacing)}.thread-container .item .left .icon{display:flex;justify-content:center;align-items:center}.thread-container .item .left .icon.success{color:var(--comp-snackbar-success-icon-color)}.thread-container .item .left .icon.error{color:var(--comp-snackbar-error-icon-color)}.thread-container .item .left .text{width:auto;display:flex;font-family:var(--comp-snackbar-text-style-font-family);font-size:var(--comp-snackbar-text-style-size);font-weight:var(--comp-snackbar-text-style-font-weight);line-height:var(--comp-snackbar-text-style-line-height);justify-content:flex-start;align-items:center;overflow-wrap:anywhere;color:var(--comp-snackbar-text-color)}.thread-container .item .right .link{width:max-content}.thread-container .item .right .close{height:20px;width:20px;display:flex;justify-content:center;align-items:center}.thread-container .item .right .close ap-symbol{color:var(--ref-color-grey-100)}.thread-container .item .right .close:hover{background:#3445631a;border-radius:50%;cursor:pointer}\n"] }]
83
83
  }], ctorParameters: () => [{ type: i1.SnackbarsThreadService }, { type: i2.SymbolRegistry }, { type: i3.Router }] });
84
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"snackbars-thread.component.js","sourceRoot":"","sources":["../../../../../libs/ui-components/snackbars-thread/src/component/snackbars-thread.component.ts","../../../../../libs/ui-components/snackbars-thread/src/component/snackbars-thread.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    SymbolComponent,\n    SymbolRegistry,\n    apAlertCircle,\n    apCheckCircle,\n    apClose,\n    apDeleteNoCircle,\n    apMessagesBubbleDot,\n    apRemoveCircle,\n} from '@agorapulse/ui-symbol';\nimport { animate, style, transition, trigger } from '@angular/animations';\nimport { AsyncPipe } from '@angular/common';\nimport { ChangeDetectionStrategy, Component } from '@angular/core';\nimport { Router } from '@angular/router';\nimport { SnackbarsThreadService } from '../public_api';\nimport { snackbarIconsMap, snackbarTypesMap } from '../utils/const/snackbars-thread.const';\n\n@Component({\n    selector: 'ap-snackbars-thread',\n    templateUrl: './snackbars-thread.component.html',\n    styleUrls: ['./snackbars-thread.component.scss'],\n    standalone: true,\n    imports: [SymbolComponent, AsyncPipe],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    animations: [\n        trigger('fadeAnimation', [\n            transition(':enter', [\n                style({\n                    height: 0,\n                    minHeight: 0,\n                    opacity: 0,\n                    transform: 'translateY(25%)',\n                    padding: 0,\n                }),\n                // padding and min-height should be the same as in scss file\n                animate(\n                    '300ms ease-in',\n                    style({\n                        height: '*',\n                        minHeight: '*',\n                        padding: 'var(--comp-snackbar-padding-vertical) var(--comp-snackbar-padding-horizontal)',\n                    })\n                ),\n                animate('200ms ease-in', style({ opacity: 0.5, transform: 'translateY(0%)' })),\n                animate('200ms ease-in', style({ opacity: 1 })),\n            ]),\n            transition(':leave', [\n                animate('300ms ease-out', style({ opacity: 0.0, transform: 'translateY(-5%)' })),\n                animate('300ms ease-out', style({ height: 0, minHeight: 0, position: 'fixed' })),\n            ]),\n        ]),\n    ],\n})\nexport class SnackbarsThreadComponent {\n    SnackbarTypesMap = snackbarTypesMap;\n    SnackbarIconsMap = snackbarIconsMap;\n\n    constructor(\n        public snackbarsThreadService: SnackbarsThreadService,\n        public symbolRegistry: SymbolRegistry,\n        private readonly router: Router\n    ) {\n        this.symbolRegistry.registerSymbols([apClose, apMessagesBubbleDot, apCheckCircle, apAlertCircle, apRemoveCircle, apDeleteNoCircle]);\n    }\n\n    remove(id: string): void {\n        this.snackbarsThreadService.remove(id);\n    }\n\n    onActionClick(navigateInternalUrl: string, id: string): void {\n        this.snackbarsThreadService.remove(id);\n        this.router.navigateByUrl(navigateInternalUrl);\n    }\n}\n","<div class=\"thread-container\">\n    @for (el of snackbarsThreadService.snackbarList | async; track el) {\n    <div\n        @fadeAnimation\n        class=\"item {{ SnackbarTypesMap[el.snackbarType] }}\">\n        <div class=\"left\">\n            <div class=\"icon {{ SnackbarTypesMap[el.snackbarType] }}\">\n                <ap-symbol\n                    size=\"micro\"\n                    [attr.aria-label]=\"SnackbarTypesMap[el.snackbarType]\"\n                    [symbolId]=\"SnackbarIconsMap[el.snackbarType]\" />\n            </div>\n            <div class=\"text\">\n                <div [innerHTML]=\"el.snackbarText\"></div>\n            </div>\n        </div>\n        <div class=\"right\">\n            <ng-container *ngIf=\"el.navigateInternalUrl?.length && el.actionName?.length\">\n                <a\n                    class=\"standalone link\"\n                    role=\"link\"\n                    tabindex=\"0\"\n                    (click)=\"onActionClick(el.navigateInternalUrl ?? '', el.id)\"\n                    (keyup)=\"onActionClick(el.navigateInternalUrl ?? '', el.id)\">\n                    {{ el.actionName }}\n                </a>\n            </ng-container>\n            <div\n                class=\"close\"\n                tabindex=\"0\"\n                (click)=\"remove(el.id)\"\n                (keyup)=\"remove(el.id)\">\n                <ap-symbol\n                    aria-label=\"close-snackbar\"\n                    size=\"20px\"\n                    symbolId=\"delete-no-circle\" />\n            </div>\n        </div>\n    </div>\n    }\n</div>\n"]}
84
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"snackbars-thread.component.js","sourceRoot":"","sources":["../../../../../libs/ui-components/snackbars-thread/src/component/snackbars-thread.component.ts","../../../../../libs/ui-components/snackbars-thread/src/component/snackbars-thread.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    SymbolComponent,\n    SymbolRegistry,\n    apAlertCircle,\n    apCheckCircle,\n    apClose,\n    apDeleteNoCircle,\n    apMessagesBubbleDot,\n    apRemoveCircle,\n} from '@agorapulse/ui-symbol';\nimport { animate, style, transition, trigger } from '@angular/animations';\nimport { AsyncPipe } from '@angular/common';\nimport { ChangeDetectionStrategy, Component } from '@angular/core';\nimport { Router } from '@angular/router';\nimport { SnackbarsThreadService } from '../service/snackbars-thread.service';\nimport { snackbarIconsMap, snackbarTypesMap } from '../utils/const/snackbars-thread.const';\n\n@Component({\n    selector: 'ap-snackbars-thread',\n    templateUrl: './snackbars-thread.component.html',\n    styleUrls: ['./snackbars-thread.component.scss'],\n    standalone: true,\n    imports: [SymbolComponent, AsyncPipe],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    animations: [\n        trigger('fadeAnimation', [\n            transition(':enter', [\n                style({\n                    height: 0,\n                    minHeight: 0,\n                    opacity: 0,\n                    transform: 'translateY(25%)',\n                    padding: 0,\n                }),\n                // padding and min-height should be the same as in scss file\n                animate(\n                    '300ms ease-in',\n                    style({\n                        height: '*',\n                        minHeight: '*',\n                        padding: 'var(--comp-snackbar-padding-vertical) var(--comp-snackbar-padding-horizontal)',\n                    })\n                ),\n                animate('200ms ease-in', style({ opacity: 0.5, transform: 'translateY(0%)' })),\n                animate('200ms ease-in', style({ opacity: 1 })),\n            ]),\n            transition(':leave', [\n                animate('300ms ease-out', style({ opacity: 0.0, transform: 'translateY(-5%)' })),\n                animate('300ms ease-out', style({ height: 0, minHeight: 0, position: 'fixed' })),\n            ]),\n        ]),\n    ],\n})\nexport class SnackbarsThreadComponent {\n    SnackbarTypesMap = snackbarTypesMap;\n    SnackbarIconsMap = snackbarIconsMap;\n\n    constructor(\n        public snackbarsThreadService: SnackbarsThreadService,\n        public symbolRegistry: SymbolRegistry,\n        private readonly router: Router\n    ) {\n        this.symbolRegistry.registerSymbols([apClose, apMessagesBubbleDot, apCheckCircle, apAlertCircle, apRemoveCircle, apDeleteNoCircle]);\n    }\n\n    remove(id: string): void {\n        this.snackbarsThreadService.remove(id);\n    }\n\n    onActionClick(navigateInternalUrl: string, id: string): void {\n        this.snackbarsThreadService.remove(id);\n        this.router.navigateByUrl(navigateInternalUrl);\n    }\n}\n","<div class=\"thread-container\">\n    @for (el of snackbarsThreadService.snackbarList | async; track el) {\n    <div\n        @fadeAnimation\n        class=\"item {{ SnackbarTypesMap[el.snackbarType] }}\">\n        <div class=\"left\">\n            <div class=\"icon {{ SnackbarTypesMap[el.snackbarType] }}\">\n                <ap-symbol\n                    size=\"micro\"\n                    [attr.aria-label]=\"SnackbarTypesMap[el.snackbarType]\"\n                    [symbolId]=\"SnackbarIconsMap[el.snackbarType]\" />\n            </div>\n            <div class=\"text\">\n                <div [innerHTML]=\"el.snackbarText\"></div>\n            </div>\n        </div>\n        <div class=\"right\">\n            <ng-container *ngIf=\"el.navigateInternalUrl?.length && el.actionName?.length\">\n                <a\n                    class=\"standalone link\"\n                    role=\"link\"\n                    tabindex=\"0\"\n                    (click)=\"onActionClick(el.navigateInternalUrl ?? '', el.id)\"\n                    (keyup)=\"onActionClick(el.navigateInternalUrl ?? '', el.id)\">\n                    {{ el.actionName }}\n                </a>\n            </ng-container>\n            <div\n                class=\"close\"\n                tabindex=\"0\"\n                (click)=\"remove(el.id)\"\n                (keyup)=\"remove(el.id)\">\n                <ap-symbol\n                    aria-label=\"close-snackbar\"\n                    size=\"20px\"\n                    symbolId=\"delete-no-circle\" />\n            </div>\n        </div>\n    </div>\n    }\n</div>\n"]}
@@ -1,9 +1,106 @@
1
- import * as i0 from '@angular/core';
2
- import { inject, Injector, ChangeDetectorRef, NgZone, EventEmitter, booleanAttribute, Component, ChangeDetectionStrategy, ViewEncapsulation, ViewChild, Input, Output, forwardRef, Injectable } from '@angular/core';
3
- import { NgControl, NG_VALUE_ACCESSOR } from '@angular/forms';
4
1
  import { SymbolComponent } from '@agorapulse/ui-symbol';
2
+ import * as i0 from '@angular/core';
3
+ import { forwardRef, Injectable, inject, Injector, ChangeDetectorRef, NgZone, EventEmitter, booleanAttribute, Component, ChangeDetectionStrategy, ViewEncapsulation, ViewChild, Input, Output } from '@angular/core';
4
+ import { NG_VALUE_ACCESSOR, NgControl } from '@angular/forms';
5
5
  import { Subject, fromEvent, filter, takeUntil } from 'rxjs';
6
6
 
7
+ const RADIO_VALUE_ACCESSOR = {
8
+ provide: NG_VALUE_ACCESSOR,
9
+ useExisting: forwardRef(() => RadioComponent),
10
+ multi: true,
11
+ };
12
+ class RadioControlRegistry {
13
+ accessors = [];
14
+ add(control, accessor) {
15
+ this.accessors.push([control, accessor]);
16
+ }
17
+ remove(accessor) {
18
+ this.accessors = this.accessors.filter(([, radioComponent]) => {
19
+ return radioComponent !== accessor;
20
+ });
21
+ }
22
+ select(accessor) {
23
+ this.accessors.forEach(([ngControl, radioComponent]) => {
24
+ if (this.isSameGroup(ngControl, radioComponent, accessor) && radioComponent !== accessor) {
25
+ radioComponent.writeValue(accessor.value);
26
+ }
27
+ });
28
+ }
29
+ getIndex(accessor) {
30
+ return this.accessors.findIndex(([, radioComponent]) => {
31
+ return radioComponent === accessor;
32
+ });
33
+ }
34
+ getNextRadio(accessor) {
35
+ const index = this.getIndex(accessor);
36
+ const nextIndex = index + 1;
37
+ if (nextIndex >= this.accessors.length) {
38
+ return this.accessors[0][1];
39
+ }
40
+ const nextRadio = this.accessors[nextIndex];
41
+ return nextRadio ? nextRadio[1] : null;
42
+ }
43
+ getPreviousRadio(accessor) {
44
+ const index = this.getIndex(accessor);
45
+ if (index === 0) {
46
+ return this.accessors[this.accessors.length - 1][1];
47
+ }
48
+ const previousIndex = index - 1;
49
+ const previousRadio = this.accessors[previousIndex];
50
+ return previousRadio ? previousRadio[1] : null;
51
+ }
52
+ blurAllGroup(accessor) {
53
+ this.accessors.forEach(([, radioComponent]) => {
54
+ if (this.isSameGroup(accessor.control, radioComponent, accessor)) {
55
+ radioComponent.inputElement.nativeElement.blur();
56
+ }
57
+ });
58
+ }
59
+ setNegativeTabIndexToAllExcept(accessor) {
60
+ this.accessors.forEach(([, radioComponent]) => {
61
+ if (this.isSameGroup(accessor.control, radioComponent, accessor)) {
62
+ if (accessor.radioId !== radioComponent.radioId) {
63
+ radioComponent.inputElement.nativeElement.tabIndex = -1;
64
+ }
65
+ else {
66
+ radioComponent.inputElement.nativeElement.tabIndex = 0;
67
+ }
68
+ }
69
+ });
70
+ }
71
+ focusPrevious(accessor) {
72
+ const previousRadio = this.getPreviousRadio(accessor);
73
+ if (previousRadio) {
74
+ previousRadio.inputElement.nativeElement.focus();
75
+ }
76
+ }
77
+ focusNext(accessor) {
78
+ const nextRadio = this.getNextRadio(accessor);
79
+ if (nextRadio) {
80
+ nextRadio.inputElement.nativeElement.focus();
81
+ }
82
+ }
83
+ getFirstCheckedRadio() {
84
+ const checkedRadio = this.accessors.find(([, radioComponent]) => {
85
+ return radioComponent.checked;
86
+ });
87
+ return checkedRadio ? checkedRadio[1] : null;
88
+ }
89
+ isSameGroup(ngControl, radioComponent, accessor) {
90
+ if (!ngControl.control) {
91
+ return false;
92
+ }
93
+ return radioComponent.name === accessor.name;
94
+ }
95
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.3", ngImport: i0, type: RadioControlRegistry, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
96
+ static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.3", ngImport: i0, type: RadioControlRegistry, providedIn: 'root' });
97
+ }
98
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.3", ngImport: i0, type: RadioControlRegistry, decorators: [{
99
+ type: Injectable,
100
+ args: [{
101
+ providedIn: 'root',
102
+ }]
103
+ }] });
7
104
  class RadioComponent {
8
105
  elementRef;
9
106
  injector = inject(Injector);
@@ -221,104 +318,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.3", ngImpor
221
318
  type: Output
222
319
  }] } });
223
320
 
224
- const RADIO_VALUE_ACCESSOR = {
225
- provide: NG_VALUE_ACCESSOR,
226
- useExisting: forwardRef(() => RadioComponent),
227
- multi: true,
228
- };
229
- class RadioControlRegistry {
230
- accessors = [];
231
- add(control, accessor) {
232
- this.accessors.push([control, accessor]);
233
- }
234
- remove(accessor) {
235
- this.accessors = this.accessors.filter(([, radioComponent]) => {
236
- return radioComponent !== accessor;
237
- });
238
- }
239
- select(accessor) {
240
- this.accessors.forEach(([ngControl, radioComponent]) => {
241
- if (this.isSameGroup(ngControl, radioComponent, accessor) && radioComponent !== accessor) {
242
- radioComponent.writeValue(accessor.value);
243
- }
244
- });
245
- }
246
- getIndex(accessor) {
247
- return this.accessors.findIndex(([, radioComponent]) => {
248
- return radioComponent === accessor;
249
- });
250
- }
251
- getNextRadio(accessor) {
252
- const index = this.getIndex(accessor);
253
- const nextIndex = index + 1;
254
- if (nextIndex >= this.accessors.length) {
255
- return this.accessors[0][1];
256
- }
257
- const nextRadio = this.accessors[nextIndex];
258
- return nextRadio ? nextRadio[1] : null;
259
- }
260
- getPreviousRadio(accessor) {
261
- const index = this.getIndex(accessor);
262
- if (index === 0) {
263
- return this.accessors[this.accessors.length - 1][1];
264
- }
265
- const previousIndex = index - 1;
266
- const previousRadio = this.accessors[previousIndex];
267
- return previousRadio ? previousRadio[1] : null;
268
- }
269
- blurAllGroup(accessor) {
270
- this.accessors.forEach(([, radioComponent]) => {
271
- if (this.isSameGroup(accessor.control, radioComponent, accessor)) {
272
- radioComponent.inputElement.nativeElement.blur();
273
- }
274
- });
275
- }
276
- setNegativeTabIndexToAllExcept(accessor) {
277
- this.accessors.forEach(([, radioComponent]) => {
278
- if (this.isSameGroup(accessor.control, radioComponent, accessor)) {
279
- if (accessor.radioId !== radioComponent.radioId) {
280
- radioComponent.inputElement.nativeElement.tabIndex = -1;
281
- }
282
- else {
283
- radioComponent.inputElement.nativeElement.tabIndex = 0;
284
- }
285
- }
286
- });
287
- }
288
- focusPrevious(accessor) {
289
- const previousRadio = this.getPreviousRadio(accessor);
290
- if (previousRadio) {
291
- previousRadio.inputElement.nativeElement.focus();
292
- }
293
- }
294
- focusNext(accessor) {
295
- const nextRadio = this.getNextRadio(accessor);
296
- if (nextRadio) {
297
- nextRadio.inputElement.nativeElement.focus();
298
- }
299
- }
300
- getFirstCheckedRadio() {
301
- const checkedRadio = this.accessors.find(([, radioComponent]) => {
302
- return radioComponent.checked;
303
- });
304
- return checkedRadio ? checkedRadio[1] : null;
305
- }
306
- isSameGroup(ngControl, radioComponent, accessor) {
307
- if (!ngControl.control) {
308
- return false;
309
- }
310
- return radioComponent.name === accessor.name;
311
- }
312
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.3", ngImport: i0, type: RadioControlRegistry, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
313
- static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.3", ngImport: i0, type: RadioControlRegistry, providedIn: 'root' });
314
- }
315
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.3", ngImport: i0, type: RadioControlRegistry, decorators: [{
316
- type: Injectable,
317
- args: [{
318
- providedIn: 'root',
319
- }]
320
- }] });
321
-
322
321
  /**
323
322
  * Generated bundle index. Do not edit.
324
323
  */