-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.js
102 lines (90 loc) · 2.84 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
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
function toggleMenu() {
const $navMenu = document.getElementById('nav__menu');
$navMenu.classList.toggle('show');
}
function handleFloatingButton() {
const $floatingButton = document.getElementById('floating-button');
$floatingButton.addEventListener('click', () => {
window.scrollTo({
top: 0,
behavior: 'smooth',
});
});
}
function init() {
const $navToggle = document.getElementById('nav-toggle');
$navToggle.addEventListener('click', () => {
// Menu Toggle
toggleMenu();
});
const $navLinkList = document.querySelectorAll('.nav__link ');
$navLinkList.forEach((el) => el.addEventListener('click', toggleMenu));
handleFloatingButton();
}
init();
/*
const options = {
threshold: 1, //0~1까지 값이 있고, 화면상에서 감지되는 value를 측정해줌.
};
const observer = new IntersectionObserver((entries) => {
entries.forEach((entry) => {
const sectionId = entry.target.id;
if (entry.isIntersecting) {
document
.querySelector(`.nav__link[href*=${sectionId}]`)
.classList.add('active-link');
const $items = document.querySelectorAll(
`.nav__link:not([href*=${sectionId}])`
);
$items.forEach((el) => el.classList.remove('active-link'));
} // active-link < nav__link에서의 홈.
});
}, options);
const $sectionList = document.querySelectorAll('.section');
$sectionList.forEach((el) => observer.observe(el));
// observer.observe($workSection);
*/
const scrollReveal = ScrollReveal({
origin: 'top',
distance: '60px',
duration: 2000,
delay: 200,
});
scrollReveal.reveal('.home__data, .about__img, .skills__text');
scrollReveal.reveal(
'.home__img, .about__data, .skills__img, .work__title__description',
{ delay: 400 }
);
scrollReveal.reveal('.skills__data, .work__link, .contact__input', {
interval: 200,
});
// type-It 라이브러리
new TypeIt('#typeit', {
speed: 70,
startDelay: 1300,
waitUntilVisible: true,
})
.type('안녕하세요!<br/>')
.type('<strong class="home__title-color">이 페이지는</strong><br/>')
.type('<strong class="home__title-color">Portfolio</strong>', { delay: 300 })
.delete(9, { delay: 400 })
.type('<strong class="home__title-color">포트폴리오 사이트</strong>입니다!')
.go();
// 이메일 클라이언트 열기
const $contactForm = document.getElementById('contactForm');
$contactForm.addEventListener('submit', function (event) {
event.preventDefault();
// 폼 하위 정보를 갖고!
const name = $contactForm.name.value;
const subject = $contactForm.subject.value;
const message = $contactForm.message.value;
const to = '[email protected]';
// 이메일 클라이언트를 열기!
location.href =
'mailto:' +
encodeURIComponent(to) +
'?subject=' +
encodeURIComponent(`[${name}님 문의] ${subject}`) +
'&body=' +
encodeURIComponent(message);
});