-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathsite.js
More file actions
73 lines (60 loc) · 2.38 KB
/
site.js
File metadata and controls
73 lines (60 loc) · 2.38 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
const translations = window.COLTRANE_TRANSLATIONS;
const defaultLanguage = 'en';
const storageKey = 'coltrane-language';
const languageToggle = document.getElementById('languageToggle');
const hamburger = document.getElementById('hamburger');
const navMenu = document.getElementById('navMenu');
const navLinks = document.querySelectorAll('.nav-link');
function applyTranslations(language) {
const dictionary = translations[language] || translations[defaultLanguage];
document.documentElement.lang = language;
document.title = dictionary.pageTitle;
document.querySelectorAll('[data-i18n]').forEach((element) => {
const key = element.dataset.i18n;
if (dictionary[key]) {
element.textContent = dictionary[key];
}
});
document.querySelectorAll('[data-i18n-html]').forEach((element) => {
const key = element.dataset.i18nHtml;
if (dictionary[key]) {
element.innerHTML = dictionary[key];
}
});
document.querySelectorAll('[data-i18n-alt]').forEach((element) => {
const key = element.dataset.i18nAlt;
if (dictionary[key]) {
element.setAttribute('alt', dictionary[key]);
}
});
const nextLanguage = language === 'en' ? 'it' : 'en';
languageToggle.textContent = nextLanguage.toUpperCase();
languageToggle.setAttribute('aria-label', dictionary.languageToggleLabel);
hamburger.setAttribute('aria-label', dictionary.hamburgerLabel);
}
function setLanguage(language) {
applyTranslations(language);
localStorage.setItem(storageKey, language);
}
languageToggle.addEventListener('click', () => {
const currentLanguage = localStorage.getItem(storageKey) || defaultLanguage;
const nextLanguage = currentLanguage === 'en' ? 'it' : 'en';
setLanguage(nextLanguage);
});
hamburger.addEventListener('click', () => {
hamburger.classList.toggle('active');
navMenu.classList.toggle('active');
});
navLinks.forEach((link) => {
link.addEventListener('click', () => {
hamburger.classList.remove('active');
navMenu.classList.remove('active');
});
});
document.addEventListener('click', (event) => {
if (!hamburger.contains(event.target) && !navMenu.contains(event.target)) {
hamburger.classList.remove('active');
navMenu.classList.remove('active');
}
});
setLanguage(localStorage.getItem(storageKey) || defaultLanguage);