Finish filter implementation for frontend

This commit is contained in:
Stedoss 2022-10-31 21:25:10 +00:00
parent 1d9ff5d67a
commit 96f409c8d8
3 changed files with 52 additions and 48 deletions

View File

@ -1,4 +1,4 @@
import { ListItemText, MenuItem, Select, SelectChangeEvent } from "@mui/material"; import { InputLabel, ListItemText, MenuItem, Select, SelectChangeEvent } from "@mui/material";
import { useState } from "react"; import { useState } from "react";
export type TFilter = { export type TFilter = {
@ -7,28 +7,53 @@ export type TFilter = {
} }
export type TDropdownFilterProps = { export type TDropdownFilterProps = {
prefillText: string;
filters: TFilter[]; filters: TFilter[];
setSelectedFilters: (filters: TFilter[]) => void;
} }
export function DropdownFilter(props: TDropdownFilterProps) { export function DropdownFilter(props: TDropdownFilterProps) {
const [selectedTags, setSelectedTags] = useState<string[]>([]); const [selectedFilterStrings, setSelectedFilterStrings] = useState<string[]>([]);
const handleChange = (event: SelectChangeEvent<typeof selectedTags>) => { const handleChange = (event: SelectChangeEvent<string[]>) => {
const { value } = event.target; const { value } = event.target;
setSelectedTags(typeof value == "string" ? value.split(",") : value);
const filterStrings = typeof value === "string" ? value.split(",") : value;
setSelectedFilterStrings(filterStrings);
updateSelectedFilters(filterStrings);
}; };
const updateSelectedFilters = (stringFilters: string[]): void => {
const currentFilters: TFilter[] = [];
stringFilters.forEach((filterString) => {
filterString = filterString.trim();
const foundFilter = props.filters.find((filter) => filter.name === filterString);
if (foundFilter) {
currentFilters.push(foundFilter);
}
});
props.setSelectedFilters(currentFilters);
}
return( return(
<Select <div>
multiple <InputLabel>{props.prefillText}</InputLabel>
value={selectedTags} <Select
onChange={handleChange} style={{ minWidth: 150, maxWidth: 300 }}
renderValue={(selected) => selected.join(', ')}> multiple
{props.filters.map((filter) => ( value={selectedFilterStrings}
<MenuItem key={filter.id} value={filter.name}> onChange={handleChange}
<ListItemText primary={filter.name} /> renderValue={(selected) => selected.join(', ')}>
</MenuItem> {props.filters.map((filter) => (
))} <MenuItem key={filter.id} value={filter.name}>
<ListItemText primary={filter.name} />
</MenuItem>
))}
</Select> </Select>
</div>
); );
} }

View File

@ -1,30 +0,0 @@
import { ListItemText, MenuItem, Select, SelectChangeEvent } from "@mui/material";
import { useState } from "react";
import { TTag } from "../lib/types";
export type TTagSelectorProps = {
tags: TTag[];
}
export function TagSelector(props: TTagSelectorProps) {
const [selectedTags, setSelectedTags] = useState<string[]>([]);
const handleChange = (event: SelectChangeEvent<typeof selectedTags>) => {
const { value } = event.target;
setSelectedTags(typeof value == "string" ? value.split(",") : value);
};
return(
<Select
multiple
value={selectedTags}
onChange={handleChange}
renderValue={(selected) => selected.join(', ')}>
{props.tags.map((tag) => (
<MenuItem key={tag.id} value={tag.name}>
<ListItemText primary={tag.name} />
</MenuItem>
))}
</Select>
);
}

View File

@ -1,21 +1,30 @@
import { useQuery, useQueryClient } from "@tanstack/react-query"; import { useQuery, useQueryClient } from "@tanstack/react-query";
import { TagSelector } from "../components/tag-selector"; import { useState } from "react";
import { DropdownFilter } from "../components/dropdown-filter";
import { VenueGrid } from "../components/venue-grid"; import { VenueGrid } from "../components/venue-grid";
import { API } from "../lib/api"; import { API } from "../lib/api";
import { Environment } from "../lib/environment"; import { Environment } from "../lib/environment";
import { TTag, TVenue } from "../lib/types"; import { TCategory, TTag, TVenue } from "../lib/types";
export function Index() { export function Index() {
const api = new API(Environment.BaseAPIUrl); const api = new API(Environment.BaseAPIUrl);
const { data: venueData } = useQuery<TVenue[], Error>(["venues"], api.getVenues); const { data: venueData } = useQuery<TVenue[], Error>(["venues"], api.getVenues);
const { data: categoryData } = useQuery<TCategory[], Error>(["categories"], api.getCategories);
const { data: tagData } = useQuery<TTag[], Error>(["tags"], api.getTags); const { data: tagData } = useQuery<TTag[], Error>(["tags"], api.getTags);
// return(<div>{data?.map(d => `${d} |`)}</div>); const [filteredTags, setFilteredTags] = useState<TTag[]>([]);
const [filteredCategories, setFilteredCategories] = useState<TCategory[]>([]);
return( return(
<> <>
<TagSelector tags={tagData ?? []}/> <h1>Leeds Beer Quest</h1>
<div style={{ display: "flex", justifyContent: "space-around" }}>
<DropdownFilter filters={tagData ?? []} setSelectedFilters={setFilteredTags} prefillText={"Tags"} />
<DropdownFilter filters={categoryData ?? []} setSelectedFilters={setFilteredCategories} prefillText={"Categories"} />
</div>
<VenueGrid venueData={venueData ?? []} /> <VenueGrid venueData={venueData ?? []} />
</> </>
); );