forked from ruchikakengal/WebDevIn100_Days
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathscript.js
More file actions
118 lines (84 loc) · 2.56 KB
/
script.js
File metadata and controls
118 lines (84 loc) · 2.56 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
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
'use strict';
/**
* Add event listener on multiple elements
*/
const addEventOnElements = function (elements, eventType, callback) {
for (let i = 0, len = elements.length; i < len; i++) {
elements[i].addEventListener(eventType, callback);
}
}
/**
* MOBILE NAVBAR TOGGLER
*/
const navbar = document.querySelector("[data-navbar]");
const navToggler = document.querySelector("[data-nav-toggler]");
const toggleNav = () => {
navbar.classList.toggle("is-active");
navToggler.classList.toggle("is-active");
document.body.classList.toggle("nav-active");
}
navToggler.addEventListener("click", toggleNav);
/**
* HEADER ANIMATION
* When scrolled donw to 100px header will be active
*/
const header = document.querySelector("[data-header]");
const backTopBtn = document.querySelector("[data-back-top-btn]");
window.addEventListener("scroll", () => {
if (window.scrollY > 100) {
header.classList.add("active");
backTopBtn.classList.add("active");
} else {
header.classList.remove("active");
backTopBtn.classList.remove("active");
}
});
/**
* SLIDER
*/
const slider = document.querySelector("[data-slider]");
const sliderContainer = document.querySelector("[data-slider-container]");
const sliderPrevBtn = document.querySelector("[data-slider-prev]");
const sliderNextBtn = document.querySelector("[data-slider-next]");
let totalSliderVisibleItems = Number(getComputedStyle(slider).getPropertyValue("--slider-items"));
let totalSlidableItems = sliderContainer.childElementCount - totalSliderVisibleItems;
let currentSlidePos = 0;
const moveSliderItem = function () {
sliderContainer.style.transform = `translateX(-${sliderContainer.children[currentSlidePos].offsetLeft}px)`;
}
/**
* NEXT SLIDE
*/
const slideNext = function () {
const slideEnd = currentSlidePos >= totalSlidableItems;
if (slideEnd) {
currentSlidePos = 0;
} else {
currentSlidePos++;
}
moveSliderItem();
}
sliderNextBtn.addEventListener("click", slideNext);
/**
* PREVIOUS SLIDE
*/
const slidePrev = function () {
if (currentSlidePos <= 0) {
currentSlidePos = totalSlidableItems;
} else {
currentSlidePos--;
}
moveSliderItem();
}
sliderPrevBtn.addEventListener("click", slidePrev);
/**
* RESPONSIVE
*/
window.addEventListener("resize", function () {
totalSliderVisibleItems = Number(getComputedStyle(slider).getPropertyValue("--slider-items"));
totalSlidableItems = sliderContainer.childElementCount - totalSliderVisibleItems;
moveSliderItem();
});
document.getElementById("showMoreBtn").onclick = function(){
location.href = "blog.html";
};