From 75bd46b832e7d1bd54fd6698fedacfc87931f242 Mon Sep 17 00:00:00 2001
From: Ivana Machacikova <131284389+ivamach@users.noreply.github.com>
Date: Mon, 22 Apr 2024 18:38:34 +0200
Subject: [PATCH] SMA-104: sports button filter doesn t filter nearby events
when all events are loaded (#79)
---
.../src/components/AllSportsList.tsx | 1 +
.../src/components/HostEventComponent.tsx | 1 +
.../src/components/SearchBar.tsx | 3 +-
frontend/sportsmatch-app/src/pages/Index.tsx | 45 ++++++++++---------
4 files changed, 29 insertions(+), 21 deletions(-)
diff --git a/frontend/sportsmatch-app/src/components/AllSportsList.tsx b/frontend/sportsmatch-app/src/components/AllSportsList.tsx
index 13e70b83..01d5eaba 100644
--- a/frontend/sportsmatch-app/src/components/AllSportsList.tsx
+++ b/frontend/sportsmatch-app/src/components/AllSportsList.tsx
@@ -89,6 +89,7 @@ export function AllSportsList(p: AllSportsProps) {
onChange={(query: string) => {
setSearchQuery(query)
}}
+ placeholder="Find your sport"
/>
{sportList}
diff --git a/frontend/sportsmatch-app/src/components/HostEventComponent.tsx b/frontend/sportsmatch-app/src/components/HostEventComponent.tsx
index 09d19318..65da1f7d 100644
--- a/frontend/sportsmatch-app/src/components/HostEventComponent.tsx
+++ b/frontend/sportsmatch-app/src/components/HostEventComponent.tsx
@@ -290,6 +290,7 @@ function HostEventComponent() {
onChange={(query: string) => {
setSearchQuery(query)
}}
+ placeholder="search"
/>
diff --git a/frontend/sportsmatch-app/src/components/SearchBar.tsx b/frontend/sportsmatch-app/src/components/SearchBar.tsx
index f35b87e5..88dd0ff3 100644
--- a/frontend/sportsmatch-app/src/components/SearchBar.tsx
+++ b/frontend/sportsmatch-app/src/components/SearchBar.tsx
@@ -3,6 +3,7 @@ import '../styles/Sport.css'
interface Params {
onChange: (query: string) => void
+ placeholder: string
}
export function SearchBar(p: Params) {
@@ -16,7 +17,7 @@ export function SearchBar(p: Params) {
diff --git a/frontend/sportsmatch-app/src/pages/Index.tsx b/frontend/sportsmatch-app/src/pages/Index.tsx
index e9e99f67..0edc45d2 100644
--- a/frontend/sportsmatch-app/src/pages/Index.tsx
+++ b/frontend/sportsmatch-app/src/pages/Index.tsx
@@ -3,7 +3,7 @@ import SportEvent from '../components/SportEvent'
import LoadingSpinner from '../components/LoadingSpinner'
import { SearchBar } from '../components/SearchBar'
import { useEffect, useState } from 'react'
-import { useLocation, useNavigate } from 'react-router-dom'
+import { useNavigate } from 'react-router-dom'
import '../styles/Index.css'
import {
ApiError,
@@ -17,31 +17,30 @@ import Modal from '../components/Modal'
import JoinEventComponent from '../components/JoinEventComponent'
export default function MainPage() {
- const [searchQuery, setSearchQuery] = useState('') // no implementation yet
+ const [searchQuery, setSearchQuery] = useState('')
const [filteredEvent, setFilteredEvent] = useState([])
const [selectedSports, setSelectedSports] = useState([])
const [clearFilters, setClearFilters] = useState(false)
const [selectedEvent, setSelectedEvent] = useState()
const [usersRank, setUsersRank] = useState(0)
const [userIsInRank, setUserIsInRank] = useState(false)
- const location = useLocation()
const navigate = useNavigate()
const { isOpen, toggle } = useModal()
const [page, setPage] = useState(0)
- const size = 5
-
- // search bar is not yet implemented
- useEffect(() => {
- console.log(`query`, searchQuery)
- }, [searchQuery])
+ const size = 3
// handle sports name selected from sportButtoncomponent
const handleSportSelectionChange = (selectedButtonSports: string[]) => {
setSelectedSports(selectedButtonSports)
}
+ // setting the page to 0 when selected sports change to clear the filteredEvent
+ useEffect(() => {
+ setPage(0)
+ }, [selectedSports])
+
const clear = () => {
- navigate(location.pathname, { state: undefined })
+ setPage(0)
setSelectedSports([])
setClearFilters(true)
setTimeout(() => {
@@ -83,7 +82,6 @@ export default function MainPage() {
// handle join event pop up after cliking on the event
const handleEventSelection = (e: EventDTO) => {
- window.scrollTo(0, 0)
if (isOpen) {
toggle()
}
@@ -158,6 +156,7 @@ export default function MainPage() {
onChange={(query: string) => {
setSearchQuery(query)
}}
+ placeholder="Find your place"
/>
@@ -174,15 +173,21 @@ export default function MainPage() {
{filteredEvent.length === 0 ? (
) : (
- filteredEvent.map((event, index) => (
- handleEventSelection(event)}
- >
-
-
- ))
+ filteredEvent
+ .filter((e) =>
+ e.placeDTO.name
+ .toLowerCase()
+ .includes(searchQuery.toLowerCase()),
+ )
+ .map((event, index) => (
+ handleEventSelection(event)}
+ >
+
+
+ ))
)}