-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathscript.js
More file actions
60 lines (55 loc) · 1.83 KB
/
script.js
File metadata and controls
60 lines (55 loc) · 1.83 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
const text = document.querySelector('.menu__text');
const box = document.querySelector('.box');
const wrap = document.querySelector('.menu__wrap');
const fullscreen = document.querySelector('.menu__fullscreen');
const container = document.querySelector('.container');
function update(){
const html = text.value.split('').map(letter => {
if (letter.match(/[0-9]/i)){
return `<div class="box__letter number">${letter}</div>`;
} else if (letter.match(/[a-z]/i)) {
return `<div class="box__letter alpha">${letter}</div>`
} else {
return `<div class="box__letter symbol">${letter}</div>`
}
}).join('');
box.innerHTML = html;
const len = text.value.length;
if(len>4) {
[...box.children].forEach(letter => {
letter.style.setProperty('height', `${4/len*30}vw`);
letter.style.setProperty('width', `${4/len*20}vw`);
letter.style.setProperty('font-size', `${4/len*25}vw`);
letter.style.setProperty('margin', `${0.5/len}rem`);
});
}
}
function updatewrap() {
if(this.checked ===true) {
box.style.setProperty('flex-wrap', 'wrap');
update();
text.focus();
}
else {
box.style.setProperty('flex-wrap', 'nowrap');
update();
text.focus();
}
}
function toggleFullscreen() {
if(this.checked===true) {
document.documentElement.requestFullscreen();
text.focus();
}
else {
document.exitFullscreen();
text.focus();
}
}
text.addEventListener('change', update);
text.addEventListener('keyup', update);
container.addEventListener('click', () => {text.focus()});
window.addEventListener('keydown', ()=> {text.focus()});
wrap.addEventListener('click', updatewrap);
fullscreen.addEventListener('click', toggleFullscreen);
text.focus()