Files
marketplaces/src/app/components/language-selector/language-selector.component.ts

41 lines
1.0 KiB
TypeScript
Raw Normal View History

2026-02-19 01:23:25 +04:00
import { Component, HostListener, ElementRef, ChangeDetectionStrategy } from '@angular/core';
2026-01-18 18:57:06 +04:00
import { LanguageService, Language } from '../../services/language.service';
@Component({
selector: 'app-language-selector',
2026-02-19 01:23:25 +04:00
imports: [],
2026-01-18 18:57:06 +04:00
templateUrl: './language-selector.component.html',
2026-02-19 01:23:25 +04:00
styleUrls: ['./language-selector.component.scss'],
changeDetection: ChangeDetectionStrategy.OnPush
2026-01-18 18:57:06 +04:00
})
export class LanguageSelectorComponent {
dropdownOpen = false;
constructor(
public languageService: LanguageService,
private elementRef: ElementRef
) {}
toggleDropdown(): void {
this.dropdownOpen = !this.dropdownOpen;
}
selectLanguage(lang: Language): void {
if (lang.enabled) {
this.languageService.setLanguage(lang.code);
this.dropdownOpen = false;
}
}
closeDropdown(): void {
this.dropdownOpen = false;
}
@HostListener('document:click', ['$event'])
onClickOutside(event: Event): void {
if (!this.elementRef.nativeElement.contains(event.target)) {
this.dropdownOpen = false;
}
}
}