@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.
- package/agorapulse-ui-components-17.0.0-beta.4.tgz +0 -0
- package/esm2022/radio/public_api.mjs +1 -2
- package/esm2022/radio/radio.component.mjs +100 -4
- package/esm2022/snackbars-thread/component/snackbars-thread.component.mjs +2 -2
- package/fesm2022/agorapulse-ui-components-radio.mjs +100 -101
- package/fesm2022/agorapulse-ui-components-radio.mjs.map +1 -1
- package/fesm2022/agorapulse-ui-components-snackbars-thread.mjs +44 -44
- package/fesm2022/agorapulse-ui-components-snackbars-thread.mjs.map +1 -1
- package/package.json +93 -93
- package/radio/public_api.d.ts +0 -1
- package/radio/radio.component.d.ts +19 -1
- package/select/select-label-multiple/select-label-multiple.component.d.ts +1 -1
- package/snackbars-thread/component/snackbars-thread.component.d.ts +1 -1
- package/agorapulse-ui-components-17.0.0-beta.2.tgz +0 -0
- package/esm2022/radio/radio-control.registry.mjs +0 -102
- package/radio/radio-control.registry.d.ts +0 -22
|
Binary file
|
|
@@ -1,3 +1,2 @@
|
|
|
1
|
-
export * from './radio-control.registry';
|
|
2
1
|
export * from './radio.component';
|
|
3
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
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 {
|
|
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":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAC;AACxD,OAAO,EAEH,gBAAgB,EAChB,uBAAuB,EACvB,iBAAiB,EACjB,SAAS,EAET,YAAY,EACZ,UAAU,EACV,MAAM,EACN,UAAU,EACV,QAAQ,EACR,KAAK,EACL,MAAM,EAIN,MAAM,EAEN,SAAS,EACT,iBAAiB,GACpB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAwB,iBAAiB,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AACpF,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,OAAO,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;;AAE7D,MAAM,CAAC,MAAM,oBAAoB,GAAa;IAC1C,OAAO,EAAE,iBAAiB;IAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,cAAc,CAAC;IAC7C,KAAK,EAAE,IAAI;CACd,CAAC;AAKF,MAAM,OAAO,oBAAoB;IACrB,SAAS,GAAkC,EAAE,CAAC;IAEtD,GAAG,CAAC,OAAkB,EAAE,QAAwB;QAC5C,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAC,CAAC;IAC7C,CAAC;IAED,MAAM,CAAC,QAAwB;QAC3B,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,cAAc,CAAC,EAAE,EAAE;YAC1D,OAAO,cAAc,KAAK,QAAQ,CAAC;QACvC,CAAC,CAAC,CAAC;IACP,CAAC;IAED,MAAM,CAAC,QAAwB;QAC3B,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC,SAAS,EAAE,cAAc,CAAC,EAAE,EAAE;YACnD,IAAI,IAAI,CAAC,WAAW,CAAC,SAAS,EAAE,cAAc,EAAE,QAAQ,CAAC,IAAI,cAAc,KAAK,QAAQ,EAAE,CAAC;gBACvF,cAAc,CAAC,UAAU,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;YAC9C,CAAC;QACL,CAAC,CAAC,CAAC;IACP,CAAC;IAED,QAAQ,CAAC,QAAwB;QAC7B,OAAO,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,cAAc,CAAC,EAAE,EAAE;YACnD,OAAO,cAAc,KAAK,QAAQ,CAAC;QACvC,CAAC,CAAC,CAAC;IACP,CAAC;IAED,YAAY,CAAC,QAAwB;QACjC,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;QACtC,MAAM,SAAS,GAAG,KAAK,GAAG,CAAC,CAAC;QAC5B,IAAI,SAAS,IAAI,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,CAAC;YACrC,OAAO,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAChC,CAAC;QACD,MAAM,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC;QAC5C,OAAO,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IAC3C,CAAC;IAED,gBAAgB,CAAC,QAAwB;QACrC,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;QACtC,IAAI,KAAK,KAAK,CAAC,EAAE,CAAC;YACd,OAAO,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QACxD,CAAC;QACD,MAAM,aAAa,GAAG,KAAK,GAAG,CAAC,CAAC;QAChC,MAAM,aAAa,GAAG,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,CAAC;QACpD,OAAO,aAAa,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IACnD,CAAC;IAED,YAAY,CAAC,QAAwB;QACjC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,cAAc,CAAC,EAAE,EAAE;YAC1C,IAAI,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,OAAO,EAAE,cAAc,EAAE,QAAQ,CAAC,EAAE,CAAC;gBAC/D,cAAc,CAAC,YAAY,CAAC,aAAa,CAAC,IAAI,EAAE,CAAC;YACrD,CAAC;QACL,CAAC,CAAC,CAAC;IACP,CAAC;IAED,8BAA8B,CAAC,QAAwB;QACnD,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,cAAc,CAAC,EAAE,EAAE;YAC1C,IAAI,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,OAAO,EAAE,cAAc,EAAE,QAAQ,CAAC,EAAE,CAAC;gBAC/D,IAAI,QAAQ,CAAC,OAAO,KAAK,cAAc,CAAC,OAAO,EAAE,CAAC;oBAC9C,cAAc,CAAC,YAAY,CAAC,aAAa,CAAC,QAAQ,GAAG,CAAC,CAAC,CAAC;gBAC5D,CAAC;qBAAM,CAAC;oBACJ,cAAc,CAAC,YAAY,CAAC,aAAa,CAAC,QAAQ,GAAG,CAAC,CAAC;gBAC3D,CAAC;YACL,CAAC;QACL,CAAC,CAAC,CAAC;IACP,CAAC;IAED,aAAa,CAAC,QAAwB;QAClC,MAAM,aAAa,GAAG,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAC,CAAC;QACtD,IAAI,aAAa,EAAE,CAAC;YAChB,aAAa,CAAC,YAAY,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;QACrD,CAAC;IACL,CAAC;IAED,SAAS,CAAC,QAAwB;QAC9B,MAAM,SAAS,GAAG,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC;QAC9C,IAAI,SAAS,EAAE,CAAC;YACZ,SAAS,CAAC,YAAY,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;QACjD,CAAC;IACL,CAAC;IAED,oBAAoB;QAChB,MAAM,YAAY,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,cAAc,CAAC,EAAE,EAAE;YAC5D,OAAO,cAAc,CAAC,OAAO,CAAC;QAClC,CAAC,CAAC,CAAC;QACH,OAAO,YAAY,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IACjD,CAAC;IAEO,WAAW,CAAC,SAAoB,EAAE,cAA8B,EAAE,QAAwB;QAC9F,IAAI,CAAC,SAAS,CAAC,OAAO,EAAE,CAAC;YACrB,OAAO,KAAK,CAAC;QACjB,CAAC;QACD,OAAO,cAAc,CAAC,IAAI,KAAK,QAAQ,CAAC,IAAI,CAAC;IACjD,CAAC;uGA7FQ,oBAAoB;2GAApB,oBAAoB,cAFjB,MAAM;;2FAET,oBAAoB;kBAHhC,UAAU;mBAAC;oBACR,UAAU,EAAE,MAAM;iBACrB;;AA2GD,MAAM,OAAO,cAAc;IAmEH;IAlEJ,QAAQ,GAAa,MAAM,CAAC,QAAQ,CAAC,CAAC;IACrC,iBAAiB,GAAsB,MAAM,CAAC,iBAAiB,CAAC,CAAC;IACjE,oBAAoB,GAAyB,MAAM,CAAC,oBAAoB,CAAC,CAAC;IAC1E,MAAM,GAAW,MAAM,CAAC,MAAM,CAAC,CAAC;IAEX,YAAY,CAAgC;IAC5C,YAAY,CAAgC;IAC7D,SAAS,GAAG,EAAE,CAAC;IACV,cAAc,GAAkB,IAAI,CAAC;IACpC,eAAe,GAAG,EAAE,CAAC;IAChD,IAGI,QAAQ,CAAC,QAAiB;QAC1B,IAAI,CAAC,SAAS,GAAG,QAAQ,CAAC;IAC9B,CAAC;IAED,IAAI,QAAQ;QACR,OAAO,IAAI,CAAC,SAAS,CAAC;IAC1B,CAAC;IACQ,aAAa,GAAqB,OAAO,CAAC;IAInD,OAAO,GAAG,EAAE,CAAC;IACJ,eAAe,CAAU;IAIlC,KAAK,CAAU;IAIf,QAAQ,GAAG,KAAK,CAAC;IACR,IAAI,GAAG,EAAE,CAAC;IAEnB,+DAA+D;IACrD,OAAO,GAGZ,IAAI,YAAY,EAAE,CAAC;IAExB,+DAA+D;IACrD,OAAO,GAA6B,IAAI,YAAY,EAAE,CAAC;IAEjE,+DAA+D;IACrD,MAAM,GAA6B,IAAI,YAAY,EAAE,CAAC;IAEhE,OAAO,GAAG,EAAE,CAAC;IACb,SAAS,GAAG,KAAK,CAAC;IAClB,QAAQ,GAAG,KAAK,CAAC;IACjB,YAAY,CAAqB;IACjC,OAAO,CAAa;IACpB,OAAO,GAAG,KAAK,CAAC;IAChB,OAAO,GAAG,KAAK,CAAC;IAChB,UAAU,GAAG,CAAC,CAAC;IACE,QAAQ,GAAkB,IAAI,OAAO,EAAQ,CAAC;IAExD,aAAa,GAA6B,GAAG,EAAE;QAClD,SAAS;IACb,CAAC,CAAC;IAEK,cAAc,GAAe,GAAG,EAAE;QACrC,SAAS;IACb,CAAC,CAAC;IAEF,YAAoB,UAAsB;QAAtB,eAAU,GAAV,UAAU,CAAY;QACtC,IAAI,CAAC,YAAY,GAAG,UAAU,CAAC,aAAa,CAAC,YAAY,CAAC,WAAW,CAAC,CAAC;QAEvE,IAAI,CAAC,MAAM,CAAC,iBAAiB,CAAC,GAAG,EAAE;YAC/B,SAAS,CAAC,MAAM,EAAE,SAAS,CAAC;iBACvB,IAAI,CACD,MAAM,CAAC,CAAC,KAAK,EAA0B,EAAE,CAAC,KAAK,IAAI,KAAK,CAAC,EACzD,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAC3B;iBACA,SAAS,CAAC,CAAC,KAAoB,EAAE,EAAE;gBAChC,uBAAuB;gBACvB,QAAQ,KAAK,CAAC,GAAG,EAAE,CAAC;oBAChB,KAAK,WAAW,CAAC;oBACjB,KAAK,YAAY;wBACb,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,EAAE;4BACjB,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;gCACf,KAAK,CAAC,wBAAwB,EAAE,CAAC;gCACjC,IAAI,CAAC,oBAAoB,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC;gCAC7C,IAAI,CAAC,oBAAoB,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;4BAC9C,CAAC;wBACL,CAAC,CAAC,CAAC;wBACH,MAAM;oBACV,KAAK,SAAS,CAAC;oBACf,KAAK,WAAW;wBACZ,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,EAAE;4BACjB,KAAK,CAAC,cAAc,EAAE,CAAC;4BACvB,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;gCACf,KAAK,CAAC,wBAAwB,EAAE,CAAC;gCACjC,IAAI,CAAC,oBAAoB,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC;gCAC7C,IAAI,CAAC,oBAAoB,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;4BAClD,CAAC;wBACL,CAAC,CAAC,CAAC;wBACH,MAAM;oBACV;wBACI,OAAO;gBACf,CAAC;YACL,CAAC,CAAC,CAAC;QACX,CAAC,CAAC,CAAC;IACP,CAAC;IAED,WAAW;QACP,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;YACpB,IAAI,CAAC,QAAQ,GAAG,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,WAAW,EAAE,IAAI,EAAE,CAAC;QAC1E,CAAC;IACL,CAAC;IAED,QAAQ;QACJ,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;QAC5C,IAAI,CAAC,SAAS,EAAE,CAAC;QACjB,IAAI,CAAC,oBAAoB,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;QAClD,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,oBAAoB,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;QAC3D,IAAI,CAAC,OAAO,GAAG,GAAG,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;IACxD,CAAC;IAED,kBAAkB;QACd,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;YACpB,IAAI,CAAC,QAAQ,GAAG,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,WAAW,EAAE,IAAI,EAAE,CAAC;QAC1E,CAAC;IACL,CAAC;IAED,WAAW;QACP,IAAI,CAAC,oBAAoB,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;QACvC,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;QACrB,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;IAC7B,CAAC;IAED,WAAW,CAAC,KAAiB,EAAE,WAA6B;QACxD,KAAK,CAAC,cAAc,EAAE,CAAC;QAEvB,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;YAChB,OAAO;QACX,CAAC;QACD,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;QACnB,WAAW,CAAC,KAAK,EAAE,CAAC;IACxB,CAAC;IAED,MAAM,CAAC,KAAY;QACf,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;YACjB,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,OAAO,GAAG,IAAI,CAAC;YAC/C,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;YACpB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YAC/B,IAAI,CAAC,oBAAoB,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;YACvC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,aAAa,EAAE,KAAK,EAAE,KAAK,EAAE,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC;QACnE,CAAC;IACL,CAAC;IAED,UAAU,CAAC,KAAc;QACrB,IAAI,CAAC,OAAO,GAAG,KAAK,IAAI,IAAI,CAAC,KAAK,CAAC;QAEnC,IAAI,IAAI,CAAC,YAAY,EAAE,aAAa,EAAE,CAAC;YACnC,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC;QAC3D,CAAC;QAED,IAAI,CAAC,iBAAiB,CAAC,YAAY,EAAE,CAAC;IAC1C,CAAC;IAED,gBAAgB,CAAC,EAAc;QAC3B,IAAI,CAAC,aAAa,GAAG,EAAE,CAAC;IAC5B,CAAC;IAED,iBAAiB,CAAC,EAAc;QAC5B,IAAI,CAAC,cAAc,GAAG,EAAE,CAAC;IAC7B,CAAC;IAED,YAAY,CAAC,KAAiB;QAC1B,IAAI,CAAC,oBAAoB,CAAC,8BAA8B,CAAC,IAAI,CAAC,CAAC;QAC/D,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,OAAO,GAAG,IAAI,CAAC;QAC/C,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;QACpB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC/B,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;QACpB,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC7B,CAAC;IAED,WAAW,CAAC,KAAiB;QACzB,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;QACrB,IAAI,CAAC,cAAc,EAAE,CAAC;QACtB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC5B,CAAC;IAED,QAAQ,CAAC,KAAY;QACjB,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;IACvB,CAAC;IAEO,SAAS;QACb,IAAI,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,eAAe,IAAI,IAAI,CAAC,IAAI,KAAK,IAAI,CAAC,eAAe,EAAE,CAAC;YAC1E,IAAI,CAAC,cAAc,EAAE,CAAC;QAC1B,CAAC;QACD,IAAI,CAAC,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,eAAe,EAAE,CAAC;YACrC,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,eAAe,CAAC;QACrC,CAAC;IACL,CAAC;IAEO,cAAc;QAClB,MAAM,IAAI,KAAK,CAAC;;;SAGf,CAAC,CAAC;IACP,CAAC;uGA5MQ,cAAc;2FAAd,cAAc,kPAYR,gBAAgB,8IAoBhB,gBAAgB,qGApCpB,CAAC,oBAAoB,CAAC,0QCzIrC,m9BA8BA;;2FD+Ga,cAAc;kBAV1B,SAAS;sCACW,uBAAuB,CAAC,MAAM,YACrC,UAAU,cAER,IAAI,WACP,CAAC,eAAe,CAAC,aACf,CAAC,oBAAoB,CAAC,iBAElB,iBAAiB,CAAC,IAAI;+EAQC,YAAY;sBAAjD,SAAS;uBAAC,OAAO,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;gBACE,YAAY;sBAAjD,SAAS;uBAAC,OAAO,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;gBACf,SAAS;sBAA7B,KAAK;uBAAC,YAAY;gBACO,cAAc;sBAAvC,KAAK;uBAAC,iBAAiB;gBACG,eAAe;sBAAzC,KAAK;uBAAC,kBAAkB;gBAIrB,QAAQ;sBAHX,KAAK;uBAAC;wBACH,SAAS,EAAE,gBAAgB;qBAC9B;gBAQQ,aAAa;sBAArB,KAAK;gBAIN,OAAO;sBAHN,KAAK;uBAAC;wBACH,QAAQ,EAAE,IAAI;qBACjB;gBAEQ,eAAe;sBAAvB,KAAK;gBAIN,KAAK;sBAHJ,KAAK;uBAAC;wBACH,QAAQ,EAAE,IAAI;qBACjB;gBAKD,QAAQ;sBAHP,KAAK;uBAAC;wBACH,SAAS,EAAE,gBAAgB;qBAC9B;gBAEQ,IAAI;sBAAZ,KAAK;gBAGI,OAAO;sBAAhB,MAAM;gBAMG,OAAO;sBAAhB,MAAM;gBAGG,MAAM;sBAAf,MAAM","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 "../
|
|
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,
|
|
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
|
*/
|