-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathmain.js
44 lines (35 loc) · 1.09 KB
/
main.js
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
'use strict';
function sleep(ms) {
return new Promise(resolve => setTimeout(resolve, ms));
}
const textArray = ['SH3LL', 'R3V3R53', 'W3B', 'CRYP70', 'P4WN', '@DHBW Mannheim'];
const elementId = typewriterText;
const charTime = 100; // ms
const sleepTime = 2000; // ms
async function typeWriter() {
while(true) {
for (let i = 0; i < textArray.length; i++) {
elementId.innerHTML = '';
let charArray = textArray[i].split('');
charArray.forEach((letter, j) =>
setTimeout(() => (elementId.innerHTML += letter), charTime * j)
);
// need to wait for all characters to appear, then sleep
let totalSleepTime = sleepTime + charArray.length * charTime;
await sleep(totalSleepTime);
charArray.forEach((letter, j) => {
setTimeout(() => {
elementId.innerHTML = elementId.innerHTML.slice(0, -1);
}, charTime * j);
}
);
await sleep(totalSleepTime);
}
}
}
const prefersReducedMotion = window.matchMedia('(prefers-reduced-motion: reduce)').matches;
if (!prefersReducedMotion) {
typeWriter();
} else {
elementId.innerHTML += textArray[textArray.length-1];
}