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

178 lines
4.3 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.
* Exported hooks must have unique names across all store modules.
*
* @file
*/
2024-10-22 18:56:37 +02:00
import { useSelect, useDispatch } from '@wordpress/data';
import { PRODUCT_TYPES, STORE_NAME } from '../constants';
2024-10-22 18:56:37 +02:00
const useOnboardingDetails = () => {
const {
2024-10-28 18:11:04 +01:00
persist,
2024-10-30 17:19:47 +01:00
setOnboardingStep,
setCompleted,
setSandboxMode,
setManualConnectionMode,
setClientId,
setClientSecret,
2024-10-30 17:17:36 +01:00
setIsCasualSeller,
setProducts,
} = useDispatch( STORE_NAME );
2024-10-22 18:56:37 +02:00
const transientData = ( select ) =>
select( STORE_NAME ).onboardingTransientData();
const persistentData = ( select ) =>
select( STORE_NAME ).onboardingPersistentData();
// Read-only flags.
const flags = useSelect( ( select ) => {
return select( STORE_NAME ).onboardingFlags();
} );
// Transient accessors.
const isSaving = useSelect( ( select ) => {
return transientData( select ).isSaving;
}, [] );
2024-10-30 17:19:47 +01:00
const isReady = useSelect( ( select ) => {
return transientData( select ).isReady;
2024-10-30 17:19:47 +01:00
} );
const isManualConnectionBusy = useSelect( ( select ) => {
return transientData( select ).isManualConnectionBusy;
}, [] );
// Persistent accessors.
2024-10-30 17:19:47 +01:00
const step = useSelect( ( select ) => {
return persistentData( select ).step || 0;
2024-10-30 17:19:47 +01:00
} );
const completed = useSelect( ( select ) => {
return persistentData( select ).completed;
2024-10-30 17:19:47 +01:00
} );
const clientId = useSelect( ( select ) => {
return persistentData( select ).clientId;
}, [] );
const clientSecret = useSelect( ( select ) => {
return persistentData( select ).clientSecret;
}, [] );
const isSandboxMode = useSelect( ( select ) => {
return persistentData( select ).useSandbox;
}, [] );
const isManualConnectionMode = useSelect( ( select ) => {
return persistentData( select ).useManualConnection;
2024-10-22 18:56:37 +02:00
}, [] );
2024-10-30 17:17:36 +01:00
const isCasualSeller = useSelect( ( select ) => {
return persistentData( select ).isCasualSeller;
2024-10-30 17:17:36 +01:00
}, [] );
const products = useSelect( ( select ) => {
return persistentData( select ).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 );
};
const setDetailAndPersist = async ( setter, value ) => {
setter( value );
await persist();
};
2024-10-22 18:56:37 +02:00
return {
isSaving,
2024-10-30 17:19:47 +01:00
isReady,
isManualConnectionBusy,
2024-10-30 17:19:47 +01:00
step,
setStep: ( value ) => setDetailAndPersist( setOnboardingStep, value ),
completed,
setCompleted: ( state ) => setDetailAndPersist( setCompleted, state ),
isSandboxMode,
2024-10-30 17:19:47 +01:00
setSandboxMode: ( state ) =>
setDetailAndPersist( setSandboxMode, state ),
isManualConnectionMode,
2024-10-30 17:19:47 +01:00
setManualConnectionMode: ( state ) =>
setDetailAndPersist( setManualConnectionMode, state ),
clientId,
setClientId: ( value ) => setDetailAndPersist( setClientId, value ),
clientSecret,
setClientSecret: ( value ) =>
setDetailAndPersist( setClientSecret, value ),
2024-10-30 17:17:36 +01:00
isCasualSeller,
setIsCasualSeller: ( value ) =>
setDetailAndPersist( setIsCasualSeller, value ),
products,
toggleProduct,
flags,
2024-10-22 18:56:37 +02:00
};
};
export const useOnboardingStepWelcome = () => {
const {
isSaving,
isManualConnectionBusy,
isSandboxMode,
setSandboxMode,
isManualConnectionMode,
setManualConnectionMode,
clientId,
setClientId,
clientSecret,
setClientSecret,
} = useOnboardingDetails();
return {
isSaving,
isManualConnectionBusy,
isSandboxMode,
setSandboxMode,
isManualConnectionMode,
setManualConnectionMode,
clientId,
setClientId,
clientSecret,
setClientSecret,
};
};
export const useOnboardingStepBusiness = () => {
const { isCasualSeller, setIsCasualSeller } = useOnboardingDetails();
return { isCasualSeller, setIsCasualSeller };
};
export const useOnboardingStepProducts = () => {
const { products, toggleProduct } = useOnboardingDetails();
2024-10-28 18:11:04 +01:00
return { products, toggleProduct };
};
export const useOnboardingStep = () => {
const { isReady, step, setStep, completed, setCompleted, flags } =
2024-10-30 17:19:47 +01:00
useOnboardingDetails();
return { isReady, step, setStep, completed, setCompleted, flags };
};
2024-10-31 09:47:06 +02:00
export const useManualConnect = () => {
const { connectViaIdAndSecret } = useDispatch( STORE_NAME );
2024-10-31 09:47:06 +02:00
return {
connectManual: connectViaIdAndSecret,
2024-10-31 09:47:06 +02:00
};
};