diff --git a/client/src/pages/FAQ/FAQ.jsx b/client/src/pages/FAQ/FAQ.jsx index f1829cde..c099ba93 100644 --- a/client/src/pages/FAQ/FAQ.jsx +++ b/client/src/pages/FAQ/FAQ.jsx @@ -1,4 +1,4 @@ -import { React, useState, useEffect, useContext } from 'react'; +import React, { useState, useEffect, useContext } from 'react'; import PropTypes from 'prop-types'; import { getQuestions } from './functions'; import './FAQ.scss'; @@ -15,7 +15,7 @@ import { SnackbarContext } from '../../util/SnackbarProvider'; import LoadingAnimation from '../../components/misc/LoadingAnimation/LoadingAnimation'; const PageFAQ = () => { - const { darkMode, setDarkModeStatus } = useContext(DarkModeContext); + const { darkMode } = useContext(DarkModeContext); const [activeIndex, setActiveIndex] = useState(0); const [isSearch, setIsSearch] = useState(false); const [isMultiSearch, setIsMultiSearch] = useState(false); @@ -31,6 +31,10 @@ const PageFAQ = () => { const [errorLoading, setErrorLoading] = useState(false); const { setSnackbar } = useContext(SnackbarContext); + // Pagination state + const [currentPage, setCurrentPage] = useState(1); + const itemsPerPage = 5; + const loadQuestions = async () => { const data = await getQuestions(setSnackbar); if (!data) { @@ -78,6 +82,29 @@ const PageFAQ = () => { loadQuestions(); }, []); + useEffect(() => { + // Reset current page to 1 when category (activeIndex) changes + setCurrentPage(1); + }, [activeIndex]); + + // Calculate total pages + const totalPages = Math.ceil((allQuestions[activeIndex]?.length || 0) / itemsPerPage); + + // Handle page change + const handlePageChange = (page) => { + setCurrentPage(page); + }; + + // Get current page questions + const currentQuestions = allQuestions[activeIndex]?.slice( + (currentPage - 1) * itemsPerPage, + currentPage * itemsPerPage, + ); + + console.log('Current Page:', currentPage); + console.log('Total Pages:', totalPages); + console.log('Current Questions:', currentQuestions); + return (