From 494b7ce8af76899c3cd287ee786dfeac7e42a496 Mon Sep 17 00:00:00 2001 From: Tero Tikkanen Date: Thu, 17 Oct 2024 18:37:34 +0300 Subject: [PATCH] Handle CategoryTypeListBlock sorting properly --- .../contentblocks/CategoryTypeListBlock.tsx | 38 ++++++++++--------- 1 file changed, 21 insertions(+), 17 deletions(-) diff --git a/components/paths/contentblocks/CategoryTypeListBlock.tsx b/components/paths/contentblocks/CategoryTypeListBlock.tsx index 2882c478..c95c3957 100644 --- a/components/paths/contentblocks/CategoryTypeListBlock.tsx +++ b/components/paths/contentblocks/CategoryTypeListBlock.tsx @@ -32,6 +32,7 @@ const getSortOptions = (t: TFunction): SortActionsConfig[] => [ { key: 'STANDARD', label: t('actions-sort-default'), + sortKey: 'order', }, { key: 'IMPACT', @@ -181,25 +182,28 @@ const CategoryList = (props) => { //setLoadedCards(prev => ({ ...prev, [id]: impact })); }; - const handleChangeSort = (sortBy: SortActionsBy) => { - console.log('sorting', sortBy); - const selectedSorter = sortOptions.find((option) => option.key === sortBy); - setSortBy(selectedSorter ?? sortOptions[0]); - const sortedCategories = [...categoriesData].sort(sortCategories); - console.log('sorted', sortedCategories); + const handleChangeSort = (sort: SortActionsBy) => { + const selectedSorter = + sortOptions.find((option) => option.key === sort) ?? sortOptions[0]; + setSortBy(selectedSorter); + const sortedCategories = [...categoriesData].sort((a, b) => { + if (selectedSorter.key === 'IMPACT') { + const aValue = categoriesPathsData.find( + (cat) => cat.id === a.id + )?.impact; + const bValue = categoriesPathsData.find( + (cat) => cat.id === b.id + )?.impact; + return bValue - aValue; + } + if (selectedSorter.key === 'STANDARD') { + return a[selectedSorter.sortKey] - b[selectedSorter.sortKey]; + } + return 0; + }); setCategoriesData(sortedCategories); }; - const sortCategories = (a, b) => { - if (sortBy.key === 'IMPACT') { - const aValue = categoriesPathsData.find((cat) => cat.id === a.id)?.impact; - const bValue = categoriesPathsData.find((cat) => cat.id === b.id)?.impact; - console.log('aValue', aValue, 'bValue', bValue); - return aValue - bValue; - } - return 0; - }; - return ( <> @@ -213,7 +217,7 @@ const CategoryList = (props) => { onChange={(e) => handleChangeSort(e.target.value as SortActionsBy) } - value={sortBy.key} + defaultValue={sortBy.key} > {sortOptions.map( (sortOption) =>