2026-03-13 13:54:45 +07:00
|
|
|
'use client';
|
|
|
|
|
|
2025-12-23 15:29:31 +07:00
|
|
|
import { FaCaretRight } from 'react-icons/fa';
|
2026-03-13 13:54:45 +07:00
|
|
|
import Link from 'next/link';
|
2025-12-23 15:29:31 +07:00
|
|
|
import ItemArticle from './ItemArticle';
|
2026-03-13 13:54:45 +07:00
|
|
|
import { getArticles } from '@/lib/api/article';
|
|
|
|
|
import { useApiData } from '@/hooks/useApiData';
|
|
|
|
|
import type { Article } from '@/types';
|
2025-12-23 15:29:31 +07:00
|
|
|
|
|
|
|
|
const BoxArticle: React.FC = () => {
|
2026-03-13 13:54:45 +07:00
|
|
|
const { data: articles } = useApiData(
|
|
|
|
|
() => getArticles(),
|
|
|
|
|
[],
|
|
|
|
|
{ initialData: [] as Article[] },
|
|
|
|
|
);
|
|
|
|
|
|
2025-12-23 15:29:31 +07:00
|
|
|
return (
|
|
|
|
|
<div className="box-article-group boder-radius-10">
|
|
|
|
|
<div className="flex items-center justify-between">
|
|
|
|
|
<div className="title-box">
|
|
|
|
|
<h2 className="title-box font-[600]">Tin tức công nghệ</h2>
|
|
|
|
|
</div>
|
2026-03-13 13:54:45 +07:00
|
|
|
<Link href="/tin-cong-nghe" className="btn-article-group flex items-center gap-1">
|
2025-12-23 15:29:31 +07:00
|
|
|
<span>Xem tất cả</span>
|
|
|
|
|
<FaCaretRight size={16} />
|
2026-03-13 13:54:45 +07:00
|
|
|
</Link>
|
2025-12-23 15:29:31 +07:00
|
|
|
</div>
|
|
|
|
|
<div className="list-article-group flex items-center gap-10">
|
2026-03-13 13:54:45 +07:00
|
|
|
{articles.slice(0, 4).map((item) => (
|
|
|
|
|
<ItemArticle item={item} key={item.id} />
|
2025-12-23 15:29:31 +07:00
|
|
|
))}
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
);
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
export default BoxArticle;
|