UNPKG

@shopify/polaris

Version:

Shopify’s admin product component library

74 lines (61 loc) 2.47 kB
import { useState, useCallback } from 'react'; let SelectionType; (function (SelectionType) { SelectionType["All"] = "all"; SelectionType["Page"] = "page"; SelectionType["Multi"] = "multi"; SelectionType["Single"] = "single"; })(SelectionType || (SelectionType = {})); function defaultResourceIDResolver(resource) { if ('id' in resource) { return resource.id; } throw new Error('Your resource does not directly contain an `id`. Pass a `resourceIDResolver` to `useIndexResourceState`'); } function useIndexResourceState(resources, { selectedResources: initSelectedResources = [], allResourcesSelected: initAllResourcesSelected = false, resourceIDResolver = defaultResourceIDResolver } = { selectedResources: [], allResourcesSelected: false, resourceIDResolver: defaultResourceIDResolver }) { const [selectedResources, setSelectedResources] = useState(initSelectedResources); const [allResourcesSelected, setAllResourcesSelected] = useState(initAllResourcesSelected); const handleSelectionChange = useCallback((selectionType, isSelecting, selection) => { if (selectionType === SelectionType.All) { setAllResourcesSelected(isSelecting); } else if (allResourcesSelected) { setAllResourcesSelected(false); } switch (selectionType) { case SelectionType.Single: setSelectedResources(newSelectedResources => isSelecting ? [...newSelectedResources, selection] : newSelectedResources.filter(id => id !== selection)); break; case SelectionType.All: case SelectionType.Page: setSelectedResources(isSelecting ? resources.map(resourceIDResolver) : []); break; case SelectionType.Multi: if (!selection) break; setSelectedResources(newSelectedResources => { const ids = []; for (let i = selection[0]; i <= selection[1]; i++) { const id = resourceIDResolver(resources[i]); if (isSelecting && !newSelectedResources.includes(id) || !isSelecting && newSelectedResources.includes(id)) { ids.push(id); } } return isSelecting ? [...newSelectedResources, ...ids] : newSelectedResources.filter(id => !ids.includes(id)); }); break; } }, [allResourcesSelected, resources, resourceIDResolver]); return { selectedResources, allResourcesSelected, handleSelectionChange }; } export { SelectionType, useIndexResourceState };