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

85 lines
2.2 KiB
JavaScript
Raw Normal View History

2024-10-22 18:56:37 +02:00
import { useSelect, useDispatch } from '@wordpress/data';
import { STORE_NAME } from '../constants';
export const useOnboardingDetails = () => {
const {
2024-10-28 18:11:04 +01:00
persist,
setSandboxMode,
setManualConnectionMode,
setClientId,
setClientSecret,
} = useDispatch( STORE_NAME );
2024-10-22 18:56:37 +02:00
// Transient accessors.
const isSaving = useSelect( ( select ) => {
return select( STORE_NAME ).getTransientData().isSaving;
}, [] );
// Persistent accessors.
const clientId = useSelect( ( select ) => {
return select( STORE_NAME ).getPersistentData().clientId;
}, [] );
const clientSecret = useSelect( ( select ) => {
return select( STORE_NAME ).getPersistentData().clientSecret;
}, [] );
const isSandboxMode = useSelect( ( select ) => {
return select( STORE_NAME ).getPersistentData().useSandbox;
}, [] );
const isManualConnectionMode = useSelect( ( select ) => {
return select( STORE_NAME ).getPersistentData().useManualConnection;
2024-10-22 18:56:37 +02:00
}, [] );
const setDetailAndPersist = async ( setter, value ) => {
setter( value );
await persist();
};
2024-10-22 18:56:37 +02:00
return {
isSaving,
isSandboxMode,
isManualConnectionMode,
clientId,
setClientId: ( value ) => setDetailAndPersist( setClientId, value ),
clientSecret,
setClientSecret: ( value ) =>
setDetailAndPersist( setClientSecret, value ),
setSandboxMode: ( state ) =>
setDetailAndPersist( setSandboxMode, state ),
setManualConnectionMode: ( state ) =>
setDetailAndPersist( setManualConnectionMode, state ),
2024-10-22 18:56:37 +02:00
};
};
export const useOnboardingStep = () => {
2024-10-28 18:11:04 +01:00
const { persist, setOnboardingStep, setCompleted } =
useDispatch( STORE_NAME );
const isReady = useSelect( ( select ) => {
return select( STORE_NAME ).getTransientData().isReady;
} );
2024-10-28 18:11:04 +01:00
const step = useSelect( ( select ) => {
return select( STORE_NAME ).getPersistentData().step || 0;
} );
const completed = useSelect( ( select ) => {
return select( STORE_NAME ).getPersistentData().completed;
} );
2024-10-28 18:11:04 +01:00
const setDetailAndPersist = async ( setter, value ) => {
setter( value );
await persist();
};
return {
isReady,
2024-10-28 18:11:04 +01:00
step,
setStep: ( value ) => setDetailAndPersist( setOnboardingStep, value ),
completed,
2024-10-28 18:11:04 +01:00
setCompleted: ( state ) => setDetailAndPersist( setCompleted, state ),
};
};