|
1 |
| -import { ElementRef, Injectable, Renderer2 } from '@angular/core'; |
| 1 | +import { ElementRef, inject, Injectable, Renderer2 } from '@angular/core'; |
2 | 2 | import { Triggers } from '../coreui.types';
|
3 | 3 |
|
4 | 4 | export interface IListenersConfig {
|
5 |
| - hostElement: ElementRef, |
6 |
| - trigger?: Triggers | Triggers[], |
7 |
| - callbackOn?: () => void, |
8 |
| - callbackOff?: () => void, |
9 |
| - callbackToggle?: () => void, |
| 5 | + hostElement: ElementRef; |
| 6 | + trigger?: Triggers | Triggers[]; |
| 7 | + callbackOn?: () => void; |
| 8 | + callbackOff?: () => void; |
| 9 | + callbackToggle?: () => void; |
10 | 10 | }
|
11 | 11 |
|
12 | 12 | @Injectable()
|
13 | 13 | export class ListenersService {
|
| 14 | + readonly renderer = inject(Renderer2); |
14 | 15 |
|
15 | 16 | private listeners: Map<string, () => void> = new Map();
|
16 | 17 |
|
17 |
| - constructor( |
18 |
| - private renderer: Renderer2 |
19 |
| - ) {} |
20 |
| - |
21 |
| - setListeners({ hostElement, trigger, callbackOn, callbackOff, callbackToggle }: IListenersConfig): void { |
| 18 | + setListeners({ |
| 19 | + hostElement, |
| 20 | + trigger, |
| 21 | + callbackOn, |
| 22 | + callbackOff, |
| 23 | + callbackToggle, |
| 24 | + }: IListenersConfig): void { |
22 | 25 | const host = hostElement.nativeElement;
|
23 | 26 | const triggers = Array.isArray(trigger) ? trigger : trigger?.split(' ') ?? [];
|
24 | 27 |
|
25 | 28 | if (triggers?.includes('click')) {
|
26 |
| - typeof callbackToggle === 'function' && this.listeners.set( |
27 |
| - 'click', |
28 |
| - this.renderer.listen(host, 'click', callbackToggle) |
29 |
| - ); |
| 29 | + typeof callbackToggle === 'function' && |
| 30 | + this.listeners.set('click', this.renderer.listen(host, 'click', callbackToggle)); |
30 | 31 | }
|
31 | 32 | if (triggers?.includes('focus')) {
|
32 |
| - typeof callbackOn === 'function' && this.listeners.set( |
33 |
| - 'focus', |
34 |
| - this.renderer.listen(host, 'focus', callbackOn) |
35 |
| - ); |
| 33 | + typeof callbackOn === 'function' && |
| 34 | + this.listeners.set('focus', this.renderer.listen(host, 'focus', callbackOn)); |
| 35 | + } |
| 36 | + if (triggers?.includes('focusin')) { |
| 37 | + typeof callbackOff === 'function' && |
| 38 | + this.listeners.set('focusout', this.renderer.listen(host, 'focusout', callbackOff)); |
| 39 | + typeof callbackOn === 'function' && |
| 40 | + this.listeners.set('focusin', this.renderer.listen(host, 'focusin', callbackOn)); |
36 | 41 | }
|
37 | 42 | if (triggers?.includes('click') || triggers?.includes('focus')) {
|
38 |
| - typeof callbackOff === 'function' && this.listeners.set( |
39 |
| - 'blur', |
40 |
| - this.renderer.listen(host, 'blur', callbackOff) |
41 |
| - ); |
| 43 | + typeof callbackOff === 'function' && |
| 44 | + this.listeners.set('blur', this.renderer.listen(host, 'blur', callbackOff)); |
42 | 45 | }
|
43 | 46 | if (triggers?.includes('hover')) {
|
44 |
| - typeof callbackOn === 'function' && this.listeners.set( |
45 |
| - 'mouseenter', |
46 |
| - this.renderer.listen(host, 'mouseenter', callbackOn) |
47 |
| - ); |
48 |
| - typeof callbackOff === 'function' && this.listeners.set( |
49 |
| - 'mouseleave', |
50 |
| - this.renderer.listen(host, 'mouseleave', callbackOff) |
51 |
| - ); |
| 47 | + typeof callbackOn === 'function' && |
| 48 | + this.listeners.set('mouseenter', this.renderer.listen(host, 'mouseenter', callbackOn)); |
| 49 | + typeof callbackOff === 'function' && |
| 50 | + this.listeners.set('mouseleave', this.renderer.listen(host, 'mouseleave', callbackOff)); |
52 | 51 | }
|
53 | 52 | }
|
54 | 53 |
|
|
0 commit comments