UNPKG

@gorhom/bottom-sheet

Version:

A performant interactive bottom sheet with fully configurable options 🚀

43 lines (37 loc) • 2.07 kB
"use strict"; import invariant from 'invariant'; import { useMemo } from 'react'; import { INITIAL_SNAP_POINT } from '../components/bottomSheet/constants'; /** * @todo * replace this with `prop-types`. */ export const usePropsValidator = ({ index, snapPoints, enableDynamicSizing, topInset, bottomInset }) => { useMemo(() => { //#region snap points const _snapPoints = snapPoints ? 'value' in snapPoints ? snapPoints.value : snapPoints : []; invariant(_snapPoints || enableDynamicSizing, `'snapPoints' was not provided! please provide at least one snap point.`); _snapPoints.map(snapPoint => { const _snapPoint = typeof snapPoint === 'number' ? snapPoint : Number.parseInt(snapPoint.replace('%', ''), 10); invariant(_snapPoint > 0 || _snapPoint === INITIAL_SNAP_POINT, `Snap point '${snapPoint}' is invalid. if you want to allow user to close the sheet, Please use 'enablePanDownToClose' prop.`); }); invariant('value' in _snapPoints || _snapPoints.length > 0 || enableDynamicSizing, `'snapPoints' was provided with no points! please provide at least one snap point.`); //#endregion //#region index invariant(typeof index === 'number' || typeof index === 'undefined', `'index' was provided but with wrong type ! expected type is a number.`); invariant(enableDynamicSizing || (typeof index === 'number' ? index >= -1 && index <= _snapPoints.length - 1 : true), `'index' was provided but out of the provided snap points range! expected value to be between -1, ${_snapPoints.length - 1}`); //#endregion //#region insets invariant(typeof topInset === 'number' || typeof topInset === 'undefined', `'topInset' was provided but with wrong type ! expected type is a number.`); invariant(typeof bottomInset === 'number' || typeof bottomInset === 'undefined', `'bottomInset' was provided but with wrong type ! expected type is a number.`); //#endregion // animations }, [index, snapPoints, topInset, bottomInset, enableDynamicSizing]); }; //# sourceMappingURL=usePropsValidator.js.map