| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199 |
- <template>
- <header>
- <div class="header--wrap" :class="{ 'white': isScrolled || isMobileMenuOpen }">
- <div class="header--container">
- <NuxtLink class="logo--wrap" to="/">그린웨일글로벌</NuxtLink>
- <ul class="menu--wrap">
- <li class="menu--item">
- <NuxtLink to="/company/intro">Company</NuxtLink>
- <ul class="gnb--wrap">
- <li><NuxtLink to="/company/intro">회사소개</NuxtLink></li>
- <li><NuxtLink to="/company/history">회사연혁</NuxtLink></li>
- <li><NuxtLink to="/company/partners">협력업체</NuxtLink></li>
- <li><NuxtLink to="/company/catalog">회사소개자료</NuxtLink></li>
- </ul>
- </li>
- <li class="menu--item">
- <NuxtLink to="/products/materials">Products</NuxtLink>
- <ul class="gnb--wrap">
- <li><NuxtLink to="/products/materials">Materials</NuxtLink></li>
- <li><NuxtLink to="/products/solutions">Solutions</NuxtLink></li>
- </ul>
- </li>
- <li class="menu--item">
- <NuxtLink to="/technology/facilities">Technology</NuxtLink>
- <ul class="gnb--wrap">
- <li><NuxtLink to="/technology/facilities">시설</NuxtLink></li>
- <li><NuxtLink to="/technology/patents">특허 / 인증</NuxtLink></li>
- </ul>
- </li>
- <li class="menu--item">
- <NuxtLink to="/media/news">Media</NuxtLink>
- <ul class="gnb--wrap">
- <li><NuxtLink to="/media/news">환경뉴스</NuxtLink></li>
- <li><NuxtLink to="/media/press">보도자료</NuxtLink></li>
- </ul>
- </li>
- <li class="menu--item">
- <NuxtLink to="/contact/notice">Contact</NuxtLink>
- <ul class="gnb--wrap">
- <li><NuxtLink to="/contact/notice">공지사항</NuxtLink></li>
- <li><NuxtLink to="/contact/faq">FAQ</NuxtLink></li>
- <li><NuxtLink to="/contact/support">고객센터</NuxtLink></li>
- <li><NuxtLink to="/contact/location">오시는길</NuxtLink></li>
- </ul>
- </li>
- </ul>
- <div class="lang--wrap" :class="{ 'active': isLangOpen }" @click="toggleLang" ref="langWrap">
- <i class="ico"></i>
- <p>KR</p>
- <ul class="select--wrap">
- <li>Arabic</li>
- <li>Chinese (Simplified)</li>
- <li>Chinese (Traditional)</li>
- <li>English</li>
- <li>Esperanto</li>
- <li>French</li>
- </ul>
- </div>
- <div class="ham--wrap" :class="{ 'active': isMobileMenuOpen }">
- <UButton @click="toggleMobileMenu"></UButton>
- </div>
- </div>
- </div>
- <div class="mobile--header--wrap" :class="{ 'active': isMobileMenuOpen }">
- <div class="mobile--menu--wrap">
- <ul>
- <li>
- <div @click="toggleAccordion('company')" :class="{ 'active': activeAccordion === 'company' }">
- Company<i class="ico"></i>
- </div>
- <ul :class="{ 'active': activeAccordion === 'company' }">
- <li><NuxtLink to="/company/intro">회사소개</NuxtLink></li>
- <li><NuxtLink to="/company/history">회사연혁</NuxtLink></li>
- <li><NuxtLink to="/company/partners">협력업체</NuxtLink></li>
- <li><NuxtLink to="/company/catalog">회사소개자료</NuxtLink></li>
- </ul>
- </li>
- <li>
- <div @click="toggleAccordion('products')" :class="{ 'active': activeAccordion === 'products' }">
- Products<i class="ico"></i>
- </div>
- <ul :class="{ 'active': activeAccordion === 'products' }">
- <li><NuxtLink to="/products/materials">Materials</NuxtLink></li>
- <li><NuxtLink to="/products/solutions">Solutions</NuxtLink></li>
- </ul>
- </li>
- <li>
- <div @click="toggleAccordion('technology')" :class="{ 'active': activeAccordion === 'technology' }">
- Technology<i class="ico"></i>
- </div>
- <ul :class="{ 'active': activeAccordion === 'technology' }">
- <li><NuxtLink to="/technology/facilities">시설</NuxtLink></li>
- <li><NuxtLink to="/technology/patents">특허 / 인증</NuxtLink></li>
- </ul>
- </li>
- <li>
- <div @click="toggleAccordion('media')" :class="{ 'active': activeAccordion === 'media' }">
- Media<i class="ico"></i>
- </div>
- <ul :class="{ 'active': activeAccordion === 'media' }">
- <li><NuxtLink to="/media/news">환경뉴스</NuxtLink></li>
- <li><NuxtLink to="/media/press">보도자료</NuxtLink></li>
- </ul>
- </li>
- <li>
- <div @click="toggleAccordion('contact')" :class="{ 'active': activeAccordion === 'contact' }">
- Contact<i class="ico"></i>
- </div>
- <ul :class="{ 'active': activeAccordion === 'contact' }">
- <li><NuxtLink to="/contact/notice">공지사항</NuxtLink></li>
- <li><NuxtLink to="/contact/faq">FAQ</NuxtLink></li>
- <li><NuxtLink to="/contact/support">고객센터</NuxtLink></li>
- <li><NuxtLink to="/contact/location">오시는길</NuxtLink></li>
- </ul>
- </li>
- </ul>
- </div>
- <div class="mobile--lang--wrap">
- <div class="lang--wrap" :class="{ 'active': isLangOpen2 }" @click="toggleLang2" ref="langWrap2">
- <i class="ico"></i>
- <p>KR</p>
- <ul class="select--wrap">
- <li>Arabic</li>
- <li>Chinese (Simplified)</li>
- <li>Chinese (Traditional)</li>
- <li>English</li>
- <li>Esperanto</li>
- <li>French</li>
- </ul>
- </div>
- </div>
- </div>
- </header>
- </template>
- <script setup>
- import { ref, onMounted, onUnmounted } from 'vue'
- const isScrolled = ref(false)
- const isLangOpen = ref(false)
- const isLangOpen2 = ref(false)
- const isMobileMenuOpen = ref(false)
- const activeAccordion = ref(null)
- const langWrap = ref(null)
- const langWrap2 = ref(null)
- const handleScroll = () => {
- // 모바일 메뉴가 열려있으면 스크롤 위치와 상관없이 white 클래스 유지
- if (isMobileMenuOpen.value) {
- isScrolled.value = true
- } else {
- isScrolled.value = window.scrollY > 0
- }
- }
- const toggleLang = () => {
- isLangOpen.value = !isLangOpen.value
- }
- const toggleLang2 = () => {
- isLangOpen2.value = !isLangOpen2.value
- }
- const toggleMobileMenu = () => {
- isMobileMenuOpen.value = !isMobileMenuOpen.value;
- }
- const toggleAccordion = (section) => {
- if (activeAccordion.value === section) {
- activeAccordion.value = null
- } else {
- activeAccordion.value = section
- }
- }
- const handleClickOutside = (event) => {
- if (langWrap.value && !langWrap.value.contains(event.target)) {
- isLangOpen.value = false
- }
- }
- const handleClickOutside2 = (event) => {
- if (langWrap2.value && !langWrap2.value.contains(event.target)) {
- isLangOpen2.value = false
- }
- }
- onMounted(() => {
- window.addEventListener('scroll', handleScroll)
- document.addEventListener('click', handleClickOutside)
- document.addEventListener('click', handleClickOutside2)
- })
- onUnmounted(() => {
- window.removeEventListener('scroll', handleScroll)
- document.removeEventListener('click', handleClickOutside)
- document.removeEventListener('click', handleClickOutside2)
- })
- </script>
|