diff --git a/app/packages/core/src/plugins/SchemaIO/components/TreeSelectionView.tsx b/app/packages/core/src/plugins/SchemaIO/components/TreeSelectionView.tsx index 74a187d764..e8c20164a1 100644 --- a/app/packages/core/src/plugins/SchemaIO/components/TreeSelectionView.tsx +++ b/app/packages/core/src/plugins/SchemaIO/components/TreeSelectionView.tsx @@ -39,12 +39,7 @@ export default function TreeSelectionView(props: ViewPropsType) { const { view = {} } = schema; if (data == undefined) { - const sampleIds = view?.data.flatMap(([parentId, children]) => { - return children.map((childId) => - typeof childId === "string" ? childId : childId[0] - ); - }); - onChange(path, sampleIds); + onChange(path, []); } const structure = view?.data || []; @@ -78,7 +73,7 @@ export default function TreeSelectionView(props: ViewPropsType) { const initialCollapsedState: CollapsedState = React.useMemo(() => { const state: CollapsedState = {}; structure.forEach(([parentId]) => { - state[parentId] = false; // start as expanded + state[parentId] = true; // start as folded }); return state; }, [structure]); @@ -87,7 +82,7 @@ export default function TreeSelectionView(props: ViewPropsType) { initialCollapsedState ); - const [allCollapsed, setAllCollapsed] = React.useState(false); + const [allCollapsed, setAllCollapsed] = React.useState(true); const handleExpandCollapseAll = () => { setCollapsedState((prevState) => { @@ -97,7 +92,7 @@ export default function TreeSelectionView(props: ViewPropsType) { }); return newState; }); - setAllCollapsed(!allCollapsed); // Toggle the expand/collapse state + setAllCollapsed(!allCollapsed); }; const handleCheckboxChange = (id: string, isChecked: boolean) => { @@ -183,7 +178,7 @@ export default function TreeSelectionView(props: ViewPropsType) { const isSample = !structure.some(([parentId]) => parentId === key) && key !== "selectAll"; - return isSample && updatedState[key].checked; // Only checked samples + return isSample && updatedState[key].checked; }); // We update the actual output value (ctx.params.value \ data) here. @@ -193,7 +188,6 @@ export default function TreeSelectionView(props: ViewPropsType) { }); }; - // Function to handle expand/collapse toggle const handleToggleCollapse = (id: string) => { setCollapsedState((prevState) => ({ ...prevState, @@ -209,17 +203,6 @@ export default function TreeSelectionView(props: ViewPropsType) { return idx === -1 ? 0 : idx + 1; }; - // On init, all samples are selected by default - useEffect(() => { - const sampleIds = view?.data.flatMap(([parentId, children]) => { - return children.map((childId) => - typeof childId === "string" ? childId : childId[0] - ); - }); - onChange(path, sampleIds); - // eslint-disable-next-line react-hooks/exhaustive-deps - }, []); - // this only runs when data and checkboxstate are different // meaning the user selected samples from the grid // we will handle the state change of checkedState here