Files
AnythingYouWant/src/components/SearchInput.js
client perkafean 69b3fe4347 ok
2024-09-27 09:07:57 +00:00

135 lines
3.7 KiB
JavaScript

import React, { useState, useEffect, useRef } from "react";
import { useNavigate, useSearchParams } from "react-router-dom";
import styled from "styled-components";
// Styled components
const SearchBox = styled.div`
display: flex;
align-items: center;
padding: 5px;
`;
const SearchContainer = styled.div`
position: relative;
display: flex;
align-items: center;
flex-grow: 1;
margin: 0px 10px;
`;
const Searchinput = styled.input`
flex-grow: 1;
border: none;
border-radius: 25px;
padding: 12px 40px;
font-size: 16px;
outline: none;
background-color: white;
border: 1px solid #ccc;
transition: background-color 0.3s ease, border-color 0.3s ease;
&:focus {
background-color: lightgray;
}
`;
const SearchIcon = styled.svg`
position: absolute;
left: 10px;
fill: #888;
width: 20px;
height: 20px;
pointer-events: none;
`;
export default function SearchInput({
shopId,
tableCode,
autofocus,
onSearchChange,
}) {
const [songName, setSongName] = useState("");
const [debouncedSongName, setDebouncedSongName] = useState("");
const navigate = useNavigate();
const [searchParams, setSearchParams] = useSearchParams();
const inputRef = useRef(null);
const [siteLoaded, setSiteLoaded] = useState(false);
// Initialize the input field with the query parameter from the URL
useEffect(() => {
setTimeout(function () {
setSiteLoaded(true);
}, 5000);
}, []);
useEffect(() => {
const query = searchParams.get("query") || "";
if (autofocus) setSongName(query);
setSiteLoaded(true);
}, [searchParams]);
useEffect(() => {
if (siteLoaded) {
//Start the timer
let url = "";
if (autofocus || songName != "") {
url = tableCode
? `/${shopId}/${tableCode}/search?query=${encodeURIComponent(
songName
)}`
: `/${shopId}/search?query=${encodeURIComponent(songName)}`;
navigate(url);
}
if (autofocus) {
if (songName == "") {
if (tableCode) navigate(`/${shopId}/${tableCode}?find=true`);
else navigate(`/${shopId}?find=true`);
}
}
if (onSearchChange) onSearchChange(songName);
}
}, [songName]);
const handleChange = (event) => {
setSongName(event.target.value);
};
// Navigate only when the debouncedSongName changes
useEffect(() => {}, [debouncedSongName, navigate]);
// Handle input change
// Focus input when component mounts
useEffect(() => {
const isFinding = searchParams.get("find") || false;
if (autofocus || isFinding) if (inputRef.current) inputRef.current.focus();
}, []);
const handleBlur = () => {
const isFinding = searchParams.get("find") || false;
if (isFinding) {
if (tableCode) navigate(`/${shopId}/${tableCode}`);
else navigate(`/${shopId}`);
}
};
return (
<SearchBox>
<SearchContainer>
<Searchinput
ref={inputRef}
type="text"
placeholder="Search..."
value={songName}
onChange={handleChange}
onBlur={handleBlur}
/>
<SearchIcon xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24">
<path d="M20.8333 18.3333H19.5167L19.05 17.8833C20.6833 15.9833 21.6667 13.5167 21.6667 10.8333C21.6667 4.85 16.8167 0 10.8333 0C4.85 0 0 4.85 0 10.8333C0 16.8167 4.85 21.6667 10.8333 21.6667C13.5167 21.6667 15.9833 20.6833 17.8833 19.05L18.3333 19.5167V20.8333L26.6667 29.15L29.15 26.6667L20.8333 18.3333ZM10.8333 18.3333C6.68333 18.3333 3.33333 14.9833 3.33333 10.8333C3.33333 6.68333 6.68333 3.33333 10.8333 3.33333C14.9833 3.33333 18.3333 6.68333 18.3333 10.8333C18.3333 14.9833 14.9833 18.3333 10.8333 18.3333Z" />
</SearchIcon>
</SearchContainer>
</SearchBox>
);
}