I have a useState hook name stories.
const [stories, setStories] = useState([
{
name: "1st Story",
sid: 1,
apartmentDetails: [],
},{
name: "2nd Story",
sid: 2,
apartmentDetails: [],
}
]);
Now I want to add apartmentDetails in 1st Story. To achieve this functionality I am doing the following.
let story = stories.find((story) => story.sid == storyID);
const storyWithDetails = {
...story,
appartmentDetails: [
...story.appartmentDetails,
{
apartment_name: apratmentName,
apartment_num: apratmentNum,
apartment_type: apartmentType,
areaDetails: [],
},
],
But it's rearranging the stories by putting the 1st Story at the last of the array. I used useEffect hook to sort it
useEffect(() => {
setStories(stories.sort((a, b) => parseInt(a.sid) - parseInt(b.sid)));
console.log(stories);
}, [stories]);
the log is returning me the sorted stories but in HTML/JSX it's not working.