/** * @license * Copyright 2025 Google LLC * SPDX-License-Identifier: Apache-2.0 */ import React, { createContext, useContext, useState, useCallback, useMemo, } from 'react'; interface OverflowState { overflowingIds: ReadonlySet; } interface OverflowActions { addOverflowingId: (id: string) => void; removeOverflowingId: (id: string) => void; } const OverflowStateContext = createContext( undefined, ); const OverflowActionsContext = createContext( undefined, ); export const useOverflowState = (): OverflowState | undefined => useContext(OverflowStateContext); export const useOverflowActions = (): OverflowActions | undefined => useContext(OverflowActionsContext); export const OverflowProvider: React.FC<{ children: React.ReactNode }> = ({ children, }) => { const [overflowingIds, setOverflowingIds] = useState(new Set()); const addOverflowingId = useCallback((id: string) => { setOverflowingIds((prevIds) => { if (prevIds.has(id)) { return prevIds; } const newIds = new Set(prevIds); newIds.add(id); return newIds; }); }, []); const removeOverflowingId = useCallback((id: string) => { setOverflowingIds((prevIds) => { if (!prevIds.has(id)) { return prevIds; } const newIds = new Set(prevIds); newIds.delete(id); return newIds; }); }, []); const stateValue = useMemo( () => ({ overflowingIds, }), [overflowingIds], ); const actionsValue = useMemo( () => ({ addOverflowingId, removeOverflowingId, }), [addOverflowingId, removeOverflowingId], ); return ( {children} ); };