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';
|
2024-11-18 18:26:10 +01:00
|
|
|
|
2024-11-20 16:54:53 +01:00
|
|
|
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
|
|
|
|
2024-10-30 17:33:48 +01:00
|
|
|
const useOnboardingDetails = () => {
|
2024-10-23 15:38:00 +02:00
|
|
|
const {
|
2024-10-28 18:11:04 +01:00
|
|
|
persist,
|
2024-11-20 16:54:53 +01:00
|
|
|
setStep,
|
2024-10-30 17:19:47 +01:00
|
|
|
setCompleted,
|
2024-10-23 15:38:00 +02:00
|
|
|
setSandboxMode,
|
|
|
|
setManualConnectionMode,
|
2024-10-23 18:15:37 +02:00
|
|
|
setClientId,
|
|
|
|
setClientSecret,
|
2024-10-30 17:17:36 +01:00
|
|
|
setIsCasualSeller,
|
|
|
|
setProducts,
|
2024-10-23 15:38:00 +02:00
|
|
|
} = useDispatch( STORE_NAME );
|
2024-10-22 18:56:37 +02:00
|
|
|
|
2024-11-18 18:26:10 +01:00
|
|
|
// Read-only flags.
|
2024-11-20 16:54:53 +01:00
|
|
|
const flags = useSelect( ( select ) => select( STORE_NAME ).flags(), [] );
|
2024-11-18 18:26:10 +01:00
|
|
|
|
2024-10-23 18:11:09 +02:00
|
|
|
// Transient accessors.
|
2024-11-20 16:54:53 +01:00
|
|
|
const isReady = useTransient( 'isReady' );
|
2024-11-04 16:50:13 +01:00
|
|
|
|
2024-10-24 12:47:30 +02:00
|
|
|
// Persistent accessors.
|
2024-11-20 16:54:53 +01:00
|
|
|
const step = usePersistent( 'step' );
|
|
|
|
const completed = usePersistent( 'completed' );
|
|
|
|
const clientId = usePersistent( 'clientId' );
|
|
|
|
const clientSecret = usePersistent( 'clientSecret' );
|
|
|
|
const isSandboxMode = usePersistent( 'useSandbox' );
|
|
|
|
const isManualConnectionMode = usePersistent( 'useManualConnection' );
|
|
|
|
const isCasualSeller = usePersistent( 'isCasualSeller' );
|
|
|
|
const products = usePersistent( 'products' );
|
2024-10-30 17:17:36 +01:00
|
|
|
|
|
|
|
const toggleProduct = ( list ) => {
|
|
|
|
const validProducts = list.filter( ( item ) =>
|
|
|
|
Object.values( PRODUCT_TYPES ).includes( item )
|
|
|
|
);
|
|
|
|
return setDetailAndPersist( setProducts, validProducts );
|
|
|
|
};
|
|
|
|
|
2024-10-23 15:38:00 +02:00
|
|
|
const setDetailAndPersist = async ( setter, value ) => {
|
|
|
|
setter( value );
|
|
|
|
await persist();
|
|
|
|
};
|
|
|
|
|
2024-10-22 18:56:37 +02:00
|
|
|
return {
|
2024-11-21 16:14:26 +01:00
|
|
|
flags,
|
2024-10-30 17:19:47 +01:00
|
|
|
isReady,
|
|
|
|
step,
|
2024-11-20 16:54:53 +01:00
|
|
|
setStep: ( value ) => setDetailAndPersist( setStep, value ),
|
2024-10-30 17:19:47 +01:00
|
|
|
completed,
|
|
|
|
setCompleted: ( state ) => setDetailAndPersist( setCompleted, state ),
|
2024-10-23 16:29:41 +02:00
|
|
|
isSandboxMode,
|
2024-10-30 17:19:47 +01:00
|
|
|
setSandboxMode: ( state ) =>
|
|
|
|
setDetailAndPersist( setSandboxMode, state ),
|
2024-10-23 16:29:41 +02:00
|
|
|
isManualConnectionMode,
|
2024-10-30 17:19:47 +01:00
|
|
|
setManualConnectionMode: ( state ) =>
|
|
|
|
setDetailAndPersist( setManualConnectionMode, state ),
|
2024-10-23 18:15:37 +02:00
|
|
|
clientId,
|
2024-10-24 12:47:30 +02:00
|
|
|
setClientId: ( value ) => setDetailAndPersist( setClientId, value ),
|
2024-10-23 18:15:37 +02:00
|
|
|
clientSecret,
|
2024-10-24 12:47:30 +02:00
|
|
|
setClientSecret: ( value ) =>
|
|
|
|
setDetailAndPersist( setClientSecret, value ),
|
2024-10-30 17:17:36 +01:00
|
|
|
isCasualSeller,
|
|
|
|
setIsCasualSeller: ( value ) =>
|
|
|
|
setDetailAndPersist( setIsCasualSeller, value ),
|
|
|
|
products,
|
|
|
|
toggleProduct,
|
2024-10-22 18:56:37 +02:00
|
|
|
};
|
|
|
|
};
|
2024-10-28 17:56:23 +01:00
|
|
|
|
2024-11-20 16:54:53 +01:00
|
|
|
export const useConnection = () => {
|
2024-10-30 17:33:48 +01:00
|
|
|
const {
|
|
|
|
isSandboxMode,
|
|
|
|
setSandboxMode,
|
|
|
|
isManualConnectionMode,
|
|
|
|
setManualConnectionMode,
|
|
|
|
clientId,
|
|
|
|
setClientId,
|
|
|
|
clientSecret,
|
|
|
|
setClientSecret,
|
|
|
|
} = useOnboardingDetails();
|
2024-10-28 17:56:23 +01:00
|
|
|
|
2024-10-30 17:33:48 +01:00
|
|
|
return {
|
|
|
|
isSandboxMode,
|
|
|
|
setSandboxMode,
|
|
|
|
isManualConnectionMode,
|
|
|
|
setManualConnectionMode,
|
|
|
|
clientId,
|
|
|
|
setClientId,
|
|
|
|
clientSecret,
|
|
|
|
setClientSecret,
|
|
|
|
};
|
|
|
|
};
|
2024-10-28 18:57:39 +01:00
|
|
|
|
2024-11-20 16:54:53 +01:00
|
|
|
export const useBusiness = () => {
|
2024-10-30 17:33:48 +01:00
|
|
|
const { isCasualSeller, setIsCasualSeller } = useOnboardingDetails();
|
2024-10-28 17:56:23 +01:00
|
|
|
|
2024-10-30 17:33:48 +01:00
|
|
|
return { isCasualSeller, setIsCasualSeller };
|
|
|
|
};
|
2024-10-28 17:56:23 +01:00
|
|
|
|
2024-11-20 16:54:53 +01:00
|
|
|
export const useProducts = () => {
|
2024-10-30 17:33:48 +01:00
|
|
|
const { products, toggleProduct } = useOnboardingDetails();
|
2024-10-28 18:11:04 +01:00
|
|
|
|
2024-10-30 17:33:48 +01:00
|
|
|
return { products, toggleProduct };
|
|
|
|
};
|
|
|
|
|
2024-11-20 16:54:53 +01:00
|
|
|
export const useSteps = () => {
|
2024-10-31 15:03:25 +01:00
|
|
|
const { isReady, step, setStep, completed, setCompleted, flags } =
|
2024-10-30 17:19:47 +01:00
|
|
|
useOnboardingDetails();
|
2024-10-28 17:56:23 +01:00
|
|
|
|
2024-10-31 15:03:25 +01:00
|
|
|
return { isReady, step, setStep, completed, setCompleted, flags };
|
2024-10-28 17:56:23 +01:00
|
|
|
};
|
2024-10-31 09:47:06 +02:00
|
|
|
|
|
|
|
export const useManualConnect = () => {
|
2024-11-04 16:50:50 +01:00
|
|
|
const { connectViaIdAndSecret } = useDispatch( STORE_NAME );
|
2024-10-31 09:47:06 +02:00
|
|
|
|
|
|
|
return {
|
2024-11-04 16:50:50 +01:00
|
|
|
connectManual: connectViaIdAndSecret,
|
2024-10-31 09:47:06 +02:00
|
|
|
};
|
|
|
|
};
|