import { useEffect, useState, useCallback } from "react"; import { NavLink } from "react-router-dom"; import axios from "axios"; import Navbar from "./Navbar"; import Footer from "./Footer"; import "../searchmysqlresults.css"; const SearchMysql = () => { const [properties, setProperties] = useState([]); const [totalRecords, setTotalRecords] = useState(0); const [page, setPage] = useState(0); // Page number const [limit] = useState(10); // Items per page const [search, setSearch] = useState(""); // Search query state const [loading, setLoading] = useState(false); // Loader state // Fetch properties from API const fetchProperties = async () => { setLoading(true); try { const res = await axios.get( `${import.meta.env.VITE_REACT_APP_SECRET}/mysql/searchmysql`, { params: { limit, offset: page * limit, search }, headers: { "Cache-Control": "no-cache" }, // Disable caching } ); setProperties(res.data.data); // Set properties setTotalRecords(res.data.totalRecords); // Set total records } catch (err) { console.log("Error fetching data:", err); } finally { setLoading(false); } }; // Debounce the search input const debounce = (func, delay) => { let timer; return (...args) => { clearTimeout(timer); timer = setTimeout(() => func(...args), delay); }; }; // Debounced fetch properties const debouncedFetchProperties = useCallback( debounce(() => { if (search.trim() === "") { fetchProperties(); // Fetch default properties when search is empty } else { fetchProperties(); // Fetch properties with new search term } }, 3000), // 3 seconds delay [search, page] ); // Handle search input change const handleSearchChange = (e) => { setSearch(e.target.value); // Trigger search only if input is non-empty if (e.target.value.trim() === "") { setPage(0); // Reset to first page fetchProperties(); // Fetch default properties immediately } }; // Handle key press events (Enter) const handleKeyPress = (e) => { if (e.key === "Enter") { e.preventDefault(); if (search.trim()) { debouncedFetchProperties(); // Fetch properties on Enter key } } }; // Handle input blur to fetch results after typing const handleBlur = () => { if (search.trim() !== "") { debouncedFetchProperties(); // Fetch properties after typing is complete } }; useEffect(() => { // Fetch default properties when the component mounts or page changes if (search.trim() === "") { fetchProperties(); // Fetch default properties } }, [page]); const totalPages = Math.ceil(totalRecords / limit); return ( <>





{/* Display properties */}
{loading ? (
Loading...
// Loader component ) : (
{/* Pagination Controls */}
{" "} Page {page + 1} of {totalPages}{" "}
{/* Add table headers */} {properties.length > 0 ? ( properties.map((property, index) => ( )) ) : ( )}
Details Total Living Square Foot Year Built Cost per Square Foot
{property.address}

{property.city}, {property.county}, {property.state} {" "}

House Id: {property.house_id}

{property.total_living_sqft}

{property.year_built}

$ {property.cost_per_sqft}/sqft
No results found
{/* Pagination Controls */}
{" "} Page {page + 1} of {totalPages}{" "}
)}