forked from UKSOURCE/hailearning.edu.vn
fix: resolve conflict in HeaderTop component
This commit is contained in:
@@ -1,8 +1,56 @@
|
|||||||
import Link from 'next/link';
|
"use client";
|
||||||
import headerData from './header.json';
|
|
||||||
|
import { useEffect, useState } from "react";
|
||||||
|
import Link from "next/link";
|
||||||
|
import headerData from "./header.json";
|
||||||
|
|
||||||
|
interface HeaderData {
|
||||||
|
top: {
|
||||||
|
phone: string;
|
||||||
|
email: string;
|
||||||
|
location: string;
|
||||||
|
socialLinks: Array<{
|
||||||
|
platform: string;
|
||||||
|
url: string;
|
||||||
|
icon: string;
|
||||||
|
}>;
|
||||||
|
languages: Array<{
|
||||||
|
name: string;
|
||||||
|
value: string;
|
||||||
|
}>;
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
const HeaderTop = () => {
|
const HeaderTop = () => {
|
||||||
const { phone, email, location, socialLinks, languages } = headerData.top;
|
const [data, setData] = useState<HeaderData>(headerData);
|
||||||
|
const [loading, setLoading] = useState(true);
|
||||||
|
|
||||||
|
useEffect(() => {
|
||||||
|
const fetchHeaderData = async () => {
|
||||||
|
try {
|
||||||
|
const apiUrl = process.env.NEXT_PUBLIC_API_URL || "http://localhost:3000";
|
||||||
|
const response = await fetch(`${apiUrl}/api/header`);
|
||||||
|
|
||||||
|
if (response.ok) {
|
||||||
|
const result = await response.json();
|
||||||
|
if (result.success && result.data && result.data.top) {
|
||||||
|
setData({
|
||||||
|
top: result.data.top,
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} catch (error) {
|
||||||
|
console.warn("Failed to fetch header data from API, using fallback:", error);
|
||||||
|
// Use fallback data (already set as initial state)
|
||||||
|
} finally {
|
||||||
|
setLoading(false);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
fetchHeaderData();
|
||||||
|
}, []);
|
||||||
|
|
||||||
|
const { phone, email, location, socialLinks, languages } = data.top;
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<div className="header-top-section">
|
<div className="header-top-section">
|
||||||
@@ -13,7 +61,7 @@ const HeaderTop = () => {
|
|||||||
<li className="style-2 d-flex align-items-center me-4">
|
<li className="style-2 d-flex align-items-center me-4">
|
||||||
<span className="me-2">Help Line</span>
|
<span className="me-2">Help Line</span>
|
||||||
<i className="fa-solid fa-phone me-2"></i>
|
<i className="fa-solid fa-phone me-2"></i>
|
||||||
<a href={`tel:${phone.replace(/\s/g, '')}`}>{phone}</a>
|
<a href={`tel:${phone.replace(/\s/g, "")}`}>{phone}</a>
|
||||||
</li>
|
</li>
|
||||||
|
|
||||||
<li className="d-flex align-items-center me-4">
|
<li className="d-flex align-items-center me-4">
|
||||||
@@ -34,15 +82,13 @@ const HeaderTop = () => {
|
|||||||
<i className="fa-solid fa-globe"></i>
|
<i className="fa-solid fa-globe"></i>
|
||||||
</div>
|
</div>
|
||||||
<div className="nice-select" tabIndex={0}>
|
<div className="nice-select" tabIndex={0}>
|
||||||
<span className="current">
|
<span className="current">{languages[0]?.name || "English"}</span>
|
||||||
{languages[0]?.name || 'English'}
|
|
||||||
</span>
|
|
||||||
<ul className="list">
|
<ul className="list">
|
||||||
{languages.map((lang, index) => (
|
{languages.map((lang, index) => (
|
||||||
<li
|
<li
|
||||||
key={index}
|
key={index}
|
||||||
data-value={lang.value}
|
data-value={lang.value}
|
||||||
className={`option ${index === 0 ? 'selected focus' : ''}`}
|
className={`option ${index === 0 ? "selected focus" : ""}`}
|
||||||
>
|
>
|
||||||
{lang.name}
|
{lang.name}
|
||||||
</li>
|
</li>
|
||||||
|
|||||||
Reference in New Issue
Block a user