2021-10-01 18:12:19 +00:00
|
|
|
import React, { ForwardedRef, forwardRef, useContext, useRef } from 'react';
|
|
|
|
|
|
|
|
import ActionSheet from './ActionSheet';
|
|
|
|
import { useTheme } from '../../theme';
|
|
|
|
|
|
|
|
interface IActionSheetProvider {
|
|
|
|
Provider: any;
|
|
|
|
Consumer: any;
|
|
|
|
}
|
|
|
|
|
|
|
|
const context: IActionSheetProvider = React.createContext({
|
|
|
|
showActionSheet: () => {},
|
|
|
|
hideActionSheet: () => {}
|
|
|
|
});
|
|
|
|
|
|
|
|
export const useActionSheet = () => useContext(context);
|
|
|
|
|
|
|
|
const { Provider, Consumer } = context;
|
|
|
|
|
2021-11-25 14:25:11 +00:00
|
|
|
export const withActionSheet = <P extends object>(Component: React.ComponentType<P>) =>
|
2021-10-01 18:12:19 +00:00
|
|
|
forwardRef((props: any, ref: ForwardedRef<any>) => (
|
|
|
|
<Consumer>{(contexts: any) => <Component {...props} {...contexts} ref={ref} />}</Consumer>
|
|
|
|
));
|
|
|
|
|
|
|
|
export const ActionSheetProvider = React.memo(({ children }: { children: JSX.Element | JSX.Element[] }) => {
|
|
|
|
const ref: ForwardedRef<any> = useRef();
|
|
|
|
const { theme }: any = useTheme();
|
|
|
|
|
|
|
|
const getContext = () => ({
|
|
|
|
showActionSheet: (options: any) => {
|
|
|
|
ref.current?.showActionSheet(options);
|
|
|
|
},
|
|
|
|
hideActionSheet: () => {
|
|
|
|
ref.current?.hideActionSheet();
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
return (
|
|
|
|
<Provider value={getContext()}>
|
|
|
|
<ActionSheet ref={ref} theme={theme}>
|
|
|
|
<>{children}</>
|
|
|
|
</ActionSheet>
|
|
|
|
</Provider>
|
|
|
|
);
|
|
|
|
});
|