diff --git a/src/components/GrossDepositionEnviroment/GdeSelect/GdeSelect.tsx b/src/components/GrossDepositionEnviroment/GdeSelect/GdeSelect.tsx index 541878e5..b99b7fab 100644 --- a/src/components/GrossDepositionEnviroment/GdeSelect/GdeSelect.tsx +++ b/src/components/GrossDepositionEnviroment/GdeSelect/GdeSelect.tsx @@ -3,6 +3,7 @@ import { Autocomplete, AutocompleteChanges } from '@equinor/eds-core-react'; import { GeologicalStandardDto } from '../../../api/generated'; import { useFetchGrossDepData } from '../../../hooks/useFetchGrossDepData'; import * as StyledDialog from '../../../styles/addRowDialog/AddRowDialog.styled'; +import { sortList } from '../../../utils/SortList'; import { GdeType } from '../GrossDepositionEnviromentGroup/GrossDepositionEnviromentGroup'; export const GdeSelect = ({ @@ -42,7 +43,7 @@ export const GdeSelect = ({ option.identifier} onOptionsChange={(e: AutocompleteChanges) => { setGdeObject({ @@ -56,7 +57,7 @@ export const GdeSelect = ({ option.identifier} onOptionsChange={(e: AutocompleteChanges) => { setGdeObject({ @@ -70,7 +71,7 @@ export const GdeSelect = ({ option.identifier} onOptionsChange={(e: AutocompleteChanges) => { setGdeObject({ @@ -84,7 +85,7 @@ export const GdeSelect = ({ option.identifier} onOptionsChange={(e: AutocompleteChanges) => { setGdeObject({ diff --git a/src/components/OutcropAnalogue/OutcropSelect/OutcropSelect.tsx b/src/components/OutcropAnalogue/OutcropSelect/OutcropSelect.tsx index 31d0c4ea..adb1defd 100644 --- a/src/components/OutcropAnalogue/OutcropSelect/OutcropSelect.tsx +++ b/src/components/OutcropAnalogue/OutcropSelect/OutcropSelect.tsx @@ -3,6 +3,7 @@ import { Autocomplete, AutocompleteChanges } from '@equinor/eds-core-react'; import { OutcropDto } from '../../../api/generated'; import { useFetchOutcropData } from '../../../hooks/useFetchOutcropData'; import * as StyledDialog from '../../../styles/addRowDialog/AddRowDialog.styled'; +import { sortList } from '../../../utils/SortList'; import { OutcropType } from '../OutcropAnalogueGroup/OutcropAnalogueGroup'; export const OutcropSelect = ({ @@ -29,7 +30,7 @@ export const OutcropSelect = ({ option.name} onOptionsChange={(e: AutocompleteChanges) => { const copyObject: OutcropType = { diff --git a/src/components/StrategraphicColumn/StratigraphicColumnSelect/StratigraphicColumnSelect.tsx b/src/components/StrategraphicColumn/StratigraphicColumnSelect/StratigraphicColumnSelect.tsx index f6536a7c..6fd39d63 100644 --- a/src/components/StrategraphicColumn/StratigraphicColumnSelect/StratigraphicColumnSelect.tsx +++ b/src/components/StrategraphicColumn/StratigraphicColumnSelect/StratigraphicColumnSelect.tsx @@ -14,6 +14,7 @@ import { useFetchSmdaStratigraphicColumns, } from '../../../hooks/useFetchStratColData'; import * as StyledDialog from '../../../styles/addRowDialog/AddRowDialog.styled'; +import { sortList } from '../../../utils/SortList'; export const StratigraphicColumnSelect = ({ stratColumnObject, @@ -61,9 +62,7 @@ export const StratigraphicColumnSelect = ({ - a.identifier.localeCompare(b.identifier), - )} + options={sortList(filterCountries)} optionLabel={(option) => option.identifier} onOptionsChange={(e: AutocompleteChanges) => { setStratColumnObject({ @@ -82,8 +81,10 @@ export const StratigraphicColumnSelect = ({ field.countryId === stratColumnObject.country?.countryId, + options={sortList( + fieldData.data.data.filter( + (field) => field.countryId === stratColumnObject.country?.countryId, + ), )} optionLabel={(option) => option.identifier} onOptionsChange={(e: AutocompleteChanges) => { @@ -101,13 +102,15 @@ export const StratigraphicColumnSelect = ({ - stratColumnObject.country !== undefined && - c.countries.filter( - (country) => - country.countryId === stratColumnObject.country?.countryId, - ).length !== 0, + options={sortList( + stratColumnData.data.data.filter( + (c) => + stratColumnObject.country !== undefined && + c.countries.filter( + (country) => + country.countryId === stratColumnObject.country?.countryId, + ).length !== 0, + ), )} optionLabel={(option) => option.identifier} onOptionsChange={(e: AutocompleteChanges) => { @@ -128,12 +131,15 @@ export const StratigraphicColumnSelect = ({ s.level === 1) - .filter( - (c) => - c.stratColumnId === stratColumnObject.stratColumn?.stratColumnId, - )} + options={sortList( + stratUnitData.data.data + .filter((s) => s.level === 1) + .filter( + (c) => + c.stratColumnId === + stratColumnObject.stratColumn?.stratColumnId, + ), + )} optionLabel={(option) => option.identifier} onOptionsChange={(e: AutocompleteChanges) => setStratColumnObject({ @@ -152,16 +158,19 @@ export const StratigraphicColumnSelect = ({ s.level === 2) - .filter( - (c) => - c.stratColumnId === stratColumnObject.stratColumn?.stratColumnId, - ) - .filter( - (x) => - x.stratUnitParentId === stratColumnObject.level1?.stratUnitId, - )} + options={sortList( + stratUnitData.data.data + .filter((s) => s.level === 2) + .filter( + (c) => + c.stratColumnId === + stratColumnObject.stratColumn?.stratColumnId, + ) + .filter( + (x) => + x.stratUnitParentId === stratColumnObject.level1?.stratUnitId, + ), + )} optionLabel={(option) => option.identifier} onOptionsChange={(e: AutocompleteChanges) => setStratColumnObject({ @@ -179,16 +188,19 @@ export const StratigraphicColumnSelect = ({ s.level === 3) - .filter( - (c) => - c.stratColumnId === stratColumnObject.stratColumn?.stratColumnId, - ) - .filter( - (x) => - x.stratUnitParentId === stratColumnObject.level2?.stratUnitId, - )} + options={sortList( + stratUnitData.data.data + .filter((s) => s.level === 3) + .filter( + (c) => + c.stratColumnId === + stratColumnObject.stratColumn?.stratColumnId, + ) + .filter( + (x) => + x.stratUnitParentId === stratColumnObject.level2?.stratUnitId, + ), + )} optionLabel={(option) => option.identifier} onOptionsChange={(e: AutocompleteChanges) => setStratColumnObject({ diff --git a/src/utils/SortList.ts b/src/utils/SortList.ts new file mode 100644 index 00000000..de0f0cb6 --- /dev/null +++ b/src/utils/SortList.ts @@ -0,0 +1,15 @@ +/* eslint-disable @typescript-eslint/no-explicit-any */ +export const sortList = (data: any) => { + if (data.length === 0) { + return data; + } else if (data.length !== 0 && data[0]['identifier'] !== undefined) { + return data.sort((a: any, b: any) => + a.identifier.localeCompare(b.identifier), + ); + } else if (data[0]['name'] !== undefined) { + return data.sort((a: any, b: any) => a.name.localeCompare(b.name)); + } else { + console.log('Data has no identifier or name'); + return data; + } +};