/* GoToSocial Copyright (C) GoToSocial Authors admin@gotosocial.org SPDX-License-Identifier: AGPL-3.0-or-later This program is free software: you can redistribute it and/or modify it under the terms of the GNU Affero General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more details. You should have received a copy of the GNU Affero General Public License along with this program. If not, see . */ import React, { memo, useDeferredValue, useCallback, useMemo } from "react"; import type { Checkable, ChecklistInputHook } from "../lib/form/types"; interface CheckListProps { field: ChecklistInputHook; header: string | React.JSX.Element; EntryComponent: React.FunctionComponent; getExtraProps; } export default function CheckList({ field, header = "All", EntryComponent, getExtraProps }: CheckListProps) { return (
{header}
); } function CheckListHeader({ toggleAll, children }) { return ( ); } interface CheckListEntriesProps { entries: { [_: string]: Checkable }, updateValue, EntryComponent, getExtraProps, } const CheckListEntries = memo( function CheckListEntries({ entries, updateValue, EntryComponent, getExtraProps }: CheckListEntriesProps) { const deferredEntries = useDeferredValue(entries); return Object.values(deferredEntries).map((entry) => ( )); }, ); interface CheckListEntryProps { entry: Checkable, updateValue, getExtraProps, EntryComponent, } /* React.memo is a performance optimization that only re-renders a CheckListEntry when it's props actually change, instead of every time anything in the list (CheckListEntries) updates */ const CheckListEntry = memo( function CheckListEntry({ entry, updateValue, getExtraProps, EntryComponent }: CheckListEntryProps) { const onChange = useCallback( (value) => updateValue(entry.key, value), [updateValue, entry.key], ); const extraProps = useMemo(() => getExtraProps?.(entry), [getExtraProps, entry]); return ( ); }, );