bigbuffet-rw/app/soapbox/components/pull-to-refresh.tsx

45 lines
1.2 KiB
TypeScript
Raw Normal View History

2022-03-21 11:09:01 -07:00
import React from 'react';
import PTRComponent from 'react-simple-pull-to-refresh';
import { Spinner } from 'soapbox/components/ui';
interface IPullToRefresh {
onRefresh?: () => Promise<any>;
refreshingContent?: JSX.Element | string;
pullingContent?: JSX.Element | string;
2023-01-10 15:03:15 -08:00
children: React.ReactNode;
2022-03-21 11:09:01 -07:00
}
/**
* PullToRefresh:
* Wrapper around a third-party PTR component with Soapbox defaults.
*/
const PullToRefresh: React.FC<IPullToRefresh> = ({ children, onRefresh, ...rest }): JSX.Element => {
2022-03-21 11:09:01 -07:00
const handleRefresh = () => {
if (onRefresh) {
return onRefresh();
} else {
// If not provided, do nothing
return Promise.resolve();
}
};
return (
<PTRComponent
onRefresh={handleRefresh}
pullingContent={<></>}
// `undefined` will fallback to the default, while `<></>` will render nothing
refreshingContent={onRefresh ? <Spinner size={30} withText={false} /> : <></>}
2022-03-21 11:09:01 -07:00
pullDownThreshold={67}
maxPullDownDistance={95}
resistance={2}
{...rest}
>
{/* This thing really wants a single JSX element as its child (TypeScript), so wrap it in one */}
<>{children}</>
2022-03-21 11:09:01 -07:00
</PTRComponent>
);
};
export default PullToRefresh;