forked from kubowania/flight-widget-vanilla-javascript
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathapp.js
119 lines (104 loc) · 2.82 KB
/
app.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
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
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
const tableBody = document.getElementById('table-body')
let flights = [
{
time: "08:11",
destination: "OMAN",
flight: "OX 203",
gate: "A 01",
remarks: "ON TIME"
},
{
time: "12:39",
destination: "LONDON",
flight: "CL 320",
gate: "C 31",
remarks: "CANCELLED"
},
{
time: "13:21",
destination: "DUBAI",
flight: "DXB 201",
gate: "A 19",
remarks: "CANCELLED"
},
{
time: "14:01",
destination: "FRANKFURT",
flight: "FR 402",
gate: "B 02",
remarks: "ON TIME"
},
{
time: "15:22",
destination: "TOKYO",
flight: "TK 211",
gate: "A 32",
remarks: "DELAYED"
}
]
const destinations = ["TOKYO", "FRANKFURT", "DUBAI", "LONDON", "OMAN", "BEIRUT"]
const remarks = ["ON TIME", "DELAYED", "CANCELLED"]
let hour = 15
function populateTable() {
for (const flight of flights) {
const tableRow = document.createElement("tr")
const tableIcon = document.createElement("td")
tableIcon.textContent = "✈"
tableRow.append(tableIcon)
for (const flightDetail in flight) {
const tableCell = document.createElement("td")
const word = Array.from(flight[flightDetail])
for (const [index, letter] of word.entries()) {
const letterElement = document.createElement("div")
setTimeout(() => {
letterElement.classList.add('flip')
letterElement.textContent = letter
tableCell.append(letterElement)
}, 100 * index)
}
tableRow.append(tableCell)
}
tableBody.append(tableRow)
}
}
populateTable()
function generateRandomLetter() {
const alphabet = "ABCDEFGHIJKLMNOPQRSTUVWXYZ"
return alphabet.charAt(Math.floor(Math.random() * alphabet.length))
}
function generateRandomNumber(maxNumber) {
const numbers = "0123456789"
if (maxNumber) {
const newNumbers = numbers.slice(0, maxNumber)
return newNumbers.charAt(Math.floor(Math.random() * newNumbers.length))
} else {
return numbers.charAt(Math.floor(Math.random() * numbers.length))
}
}
function generateTime() {
let displayHour = hour
if (hour < 24) {
hour++
}
if (hour >= 24) {
hour = 1
displayHour = hour
}
if (hour < 10) {
displayHour = "0" + hour
}
return displayHour + ":" + generateRandomNumber(5) + generateRandomNumber()
}
function shuffleUp() {
flights.shift()
flights.push({
time: generateTime(),
destination: destinations[Math.floor(Math.random() * destinations.length)],
flight: generateRandomLetter() + generateRandomLetter() + " " + generateRandomNumber() + generateRandomNumber() + generateRandomNumber(),
gate: generateRandomLetter() + " " + generateRandomLetter() + generateRandomLetter(),
remarks: remarks[Math.floor(Math.random() * remarks.length)]
})
tableBody.textContent = ""
populateTable()
}
setInterval(shuffleUp, 5000)