forked from grizhlieCodes/time-tracking-dashboard
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathscript.js
91 lines (81 loc) · 2.87 KB
/
script.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
const buttons = [...document.querySelectorAll('.activity-tracker__option')]
let data = []
const listenToButtons = (array) => {
array.forEach(button => {
button.addEventListener('click', () => {
activateClickedButton(button)
const clickedOption = button.dataset.option
renderCards(clickedOption)
})
})
};
const activateClickedButton = (button) => {
buttons.forEach(b => b.classList.remove('active'))
button.classList.add('active')
}
const loadData = async () => {
// Fetch data
const response = await fetch('./data.json')
const fetchedData = await response.json()
data = fetchedData
buttons[1].click()
}
const clearActivities = () => {
//Clear all activities from html
const activities = document.querySelectorAll('.activity-tracker__activity')
activities.forEach(a => a.remove())
}
const renderCards = async (clickedOption) => {
clearActivities()
const activityTracker = document.querySelector('section.activity-tracker')
const calcTimeframe = (option) => {
if (option === 'daily') {
return 'Yesterday'
} else if (option === 'weekly') {
return 'Last Week'
} else if (option === 'monthly') {
return 'Last Month'
}
}
data.forEach(activity => {
const name = activity.title
const activityClass = name.toLowerCase().replace(' ', '-')
const timeframeData = activity.timeframes[clickedOption]
const previousTimeframe = calcTimeframe(clickedOption)
const section = document.createElement('section')
section.classList.add('activity-tracker__activity', activityClass)
const stringToInject = `
<div class="activity__bg">
<img src="./images/icon-${activityClass}.svg" alt="">
</div>
<div class="activity__info">
<header class="activity__header">
<h2 class="activity__name">
${name}
</h2>
<div class="activity__options">
<svg width="21" height="5" xmlns="http://www.w3.org/2000/svg">
<path
d="M2.5 0a2.5 2.5 0 1 1 0 5 2.5 2.5 0 0 1 0-5Zm8 0a2.5 2.5 0 1 1 0 5 2.5 2.5 0 0 1 0-5Zm8 0a2.5 2.5 0 1 1 0 5 2.5 2.5 0 0 1 0-5Z"
fill="#BBC0FF" fill-rule="evenodd" />
</svg>
</div>
</header>
<div class="activity__timeframes">
<h3 class="activity__current-timeframe">
${timeframeData.current}hrs
</h3>
<div class="activity__previous-timeframe">
<p class="time-window">${previousTimeframe}</p>
<p> - </p>
<p class="time">${timeframeData.previous}hrs</p>
</div>
</div>
</div>
`
section.innerHTML = stringToInject
activityTracker.append(section)
})
};
listenToButtons(buttons)
loadData()