woocommerce-paypal-payments/modules/ppcp-settings/resources/js/data/onboarding/hooks.js

91 lines
2.2 KiB
JavaScript
Raw Normal View History

2024-11-18 18:51:11 +01:00
/**
* Hooks: Provide the main API for components to interact with the store.
*
* These encapsulate store interactions, offering a consistent interface.
* Hooks simplify data access and manipulation for components.
*
* @file
*/
2024-10-22 18:56:37 +02:00
import { useSelect, useDispatch } from '@wordpress/data';
import { PRODUCT_TYPES } from '../constants';
import { STORE_NAME } from './constants';
const useTransient = ( key ) =>
useSelect(
( select ) => select( STORE_NAME ).transientData()?.[ key ],
[ key ]
);
const usePersistent = ( key ) =>
useSelect(
( select ) => select( STORE_NAME ).persistentData()?.[ key ],
[ key ]
);
2024-10-22 18:56:37 +02:00
const useHooks = () => {
const { persist, setStep, setCompleted, setIsCasualSeller, setProducts } =
useDispatch( STORE_NAME );
2024-10-22 18:56:37 +02:00
// Read-only flags.
const flags = useSelect( ( select ) => select( STORE_NAME ).flags(), [] );
// Transient accessors.
const isReady = useTransient( 'isReady' );
// Persistent accessors.
const step = usePersistent( 'step' );
const completed = usePersistent( 'completed' );
const isCasualSeller = usePersistent( 'isCasualSeller' );
const products = usePersistent( 'products' );
2024-10-30 17:17:36 +01:00
const savePersistent = async ( setter, value ) => {
setter( value );
await persist();
};
2024-10-22 18:56:37 +02:00
return {
flags,
2024-10-30 17:19:47 +01:00
isReady,
step,
setStep: ( value ) => {
return savePersistent( setStep, value );
},
2024-10-30 17:19:47 +01:00
completed,
setCompleted: ( state ) => {
return savePersistent( setCompleted, state );
},
2024-10-30 17:17:36 +01:00
isCasualSeller,
setIsCasualSeller: ( value ) => {
return savePersistent( setIsCasualSeller, value );
},
2024-10-30 17:17:36 +01:00
products,
setProducts: ( activeProducts ) => {
const validProducts = activeProducts.filter( ( item ) =>
Object.values( PRODUCT_TYPES ).includes( item )
);
return savePersistent( setProducts, validProducts );
},
};
};
export const useBusiness = () => {
const { isCasualSeller, setIsCasualSeller } = useHooks();
return { isCasualSeller, setIsCasualSeller };
};
export const useProducts = () => {
const { products, setProducts } = useHooks();
2024-10-28 18:11:04 +01:00
return { products, setProducts };
};
export const useSteps = () => {
const { flags, isReady, step, setStep, completed, setCompleted } =
useHooks();
2024-10-31 09:47:06 +02:00
return { flags, isReady, step, setStep, completed, setCompleted };
2024-10-31 09:47:06 +02:00
};