From 60fd2bd8cf3e4a00b15275ac7a5d642c159f2916 Mon Sep 17 00:00:00 2001 From: Hristo Nedelkov Date: Wed, 27 Sep 2023 11:35:44 +0300 Subject: [PATCH] Implement search input field for "Search Validators" --- .../Dashboard/RightSideBar/ValidatorsList.tsx | 42 ++++++++++++------- 1 file changed, 28 insertions(+), 14 deletions(-) diff --git a/src/pages/Dashboard/RightSideBar/ValidatorsList.tsx b/src/pages/Dashboard/RightSideBar/ValidatorsList.tsx index e7e153f6..8f57bef6 100644 --- a/src/pages/Dashboard/RightSideBar/ValidatorsList.tsx +++ b/src/pages/Dashboard/RightSideBar/ValidatorsList.tsx @@ -1,25 +1,39 @@ -// create component for this file - -import { Stack, YStack } from "tamagui" -import ValidatorListItem from "./ValidatorListItem" -import InputSearch from "./SearchInput" -import { useState } from "react" +import { Stack, YStack } from "tamagui"; +import ValidatorListItem from "./ValidatorListItem"; +import InputSearch from "./SearchInput"; +import { useState, useEffect } from "react"; const ValidatorsList = () => { - const [searchValue, setSearchValue] = useState('') + const [searchValue, setSearchValue] = useState(''); + const validators = [ + { name: 'Validator 1', avatarKey: '37880sfsef38fsb', selected: true, isAvatarChipIncluded: true, isVerified: true }, + { name: 'Validator 2', avatarKey: 'hs880sfsef38fsb', isVerified: true }, + { name: 'Validator 3', avatarKey: '3nh880sfsef38fsb', isAvatarChipIncluded: true }, + { name: 'Validator 4', avatarKey: 'fh7880sfsef38fsb' }, + ]; + const [filteredValidators, setFilteredValidators] = useState(validators); + + useEffect(() => { + if (searchValue) { + const filtered = validators.filter(validator => + validator.name.toLowerCase().includes(searchValue.toLowerCase()) + ); + setFilteredValidators(filtered); + } else { + setFilteredValidators(validators); + } + }, [searchValue, validators]); return ( - - - - - + {filteredValidators.map(validator => ( + + ))} - ) + ); } -export default ValidatorsList \ No newline at end of file +export default ValidatorsList;