2024-11-18 18:58:54 +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-11-20 17:21:09 +01:00
|
|
|
|
2024-11-21 16:16:20 +01:00
|
|
|
import { useDispatch, useSelect } from '@wordpress/data';
|
2024-11-21 18:04:11 +01:00
|
|
|
import { useCallback } from '@wordpress/element';
|
2024-11-20 17:21:09 +01:00
|
|
|
|
|
|
|
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-11-21 16:14:26 +01:00
|
|
|
|
2024-11-21 16:16:20 +01:00
|
|
|
const useHooks = () => {
|
|
|
|
const {
|
|
|
|
persist,
|
|
|
|
setSandboxMode,
|
|
|
|
setManualConnectionMode,
|
|
|
|
setClientId,
|
|
|
|
setClientSecret,
|
2024-12-03 17:54:09 +01:00
|
|
|
connectToSandbox,
|
2024-12-05 15:06:34 +01:00
|
|
|
connectToProduction,
|
2024-11-21 16:16:20 +01:00
|
|
|
connectViaIdAndSecret,
|
|
|
|
} = useDispatch( STORE_NAME );
|
|
|
|
|
|
|
|
// Transient accessors.
|
|
|
|
const isReady = useTransient( 'isReady' );
|
|
|
|
|
|
|
|
// Persistent accessors.
|
|
|
|
const clientId = usePersistent( 'clientId' );
|
|
|
|
const clientSecret = usePersistent( 'clientSecret' );
|
|
|
|
const isSandboxMode = usePersistent( 'useSandbox' );
|
|
|
|
const isManualConnectionMode = usePersistent( 'useManualConnection' );
|
2024-12-03 15:24:49 -04:00
|
|
|
|
|
|
|
const wooSettings = useSelect(
|
|
|
|
( select ) => select( STORE_NAME ).wooSettings(),
|
|
|
|
[]
|
|
|
|
);
|
2024-11-21 16:16:20 +01:00
|
|
|
|
|
|
|
const savePersistent = async ( setter, value ) => {
|
|
|
|
setter( value );
|
|
|
|
await persist();
|
|
|
|
};
|
|
|
|
|
|
|
|
return {
|
|
|
|
isReady,
|
|
|
|
isSandboxMode,
|
|
|
|
setSandboxMode: ( state ) => {
|
|
|
|
return savePersistent( setSandboxMode, state );
|
|
|
|
},
|
|
|
|
isManualConnectionMode,
|
|
|
|
setManualConnectionMode: ( state ) => {
|
|
|
|
return savePersistent( setManualConnectionMode, state );
|
|
|
|
},
|
|
|
|
clientId,
|
|
|
|
setClientId: ( value ) => {
|
|
|
|
return savePersistent( setClientId, value );
|
|
|
|
},
|
|
|
|
clientSecret,
|
|
|
|
setClientSecret: ( value ) => {
|
|
|
|
return savePersistent( setClientSecret, value );
|
|
|
|
},
|
2024-12-03 17:54:09 +01:00
|
|
|
connectToSandbox,
|
2024-12-05 15:06:34 +01:00
|
|
|
connectToProduction,
|
2024-11-21 16:16:20 +01:00
|
|
|
connectViaIdAndSecret,
|
2024-12-03 15:24:49 -04:00
|
|
|
wooSettings,
|
2024-11-21 16:16:20 +01:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export const useSandbox = () => {
|
2024-12-03 17:54:09 +01:00
|
|
|
const { isSandboxMode, setSandboxMode, connectToSandbox } = useHooks();
|
2024-11-21 16:16:20 +01:00
|
|
|
|
2024-12-03 17:54:09 +01:00
|
|
|
return { isSandboxMode, setSandboxMode, connectToSandbox };
|
2024-11-21 16:16:20 +01:00
|
|
|
};
|
|
|
|
|
2024-12-05 15:06:34 +01:00
|
|
|
export const useProduction = () => {
|
|
|
|
const { connectToProduction } = useHooks();
|
|
|
|
|
|
|
|
return { connectToProduction };
|
|
|
|
};
|
|
|
|
|
2024-11-21 16:16:20 +01:00
|
|
|
export const useManualConnection = () => {
|
|
|
|
const {
|
|
|
|
isManualConnectionMode,
|
|
|
|
setManualConnectionMode,
|
|
|
|
clientId,
|
|
|
|
setClientId,
|
|
|
|
clientSecret,
|
|
|
|
setClientSecret,
|
|
|
|
connectViaIdAndSecret,
|
|
|
|
} = useHooks();
|
|
|
|
|
|
|
|
return {
|
|
|
|
isManualConnectionMode,
|
|
|
|
setManualConnectionMode,
|
|
|
|
clientId,
|
|
|
|
setClientId,
|
|
|
|
clientSecret,
|
|
|
|
setClientSecret,
|
|
|
|
connectViaIdAndSecret,
|
|
|
|
};
|
|
|
|
};
|
2024-12-02 18:15:07 -04:00
|
|
|
|
|
|
|
export const useWooSettings = () => {
|
2024-12-03 15:24:49 -04:00
|
|
|
const { wooSettings } = useHooks();
|
2024-12-06 15:49:37 +01:00
|
|
|
|
2024-12-03 15:24:49 -04:00
|
|
|
return wooSettings;
|
2024-12-02 18:15:07 -04:00
|
|
|
};
|
2024-12-06 15:49:37 +01:00
|
|
|
|
|
|
|
// -- Not using the `useHooks()` data provider --
|
|
|
|
|
|
|
|
export const useBusyState = () => {
|
|
|
|
const { startActivity, stopActivity } = useDispatch( STORE_NAME );
|
|
|
|
|
|
|
|
// Resolved value (object), contains a list of all running actions.
|
|
|
|
const activities = useSelect(
|
|
|
|
( select ) => select( STORE_NAME ).getActivityList(),
|
|
|
|
[]
|
|
|
|
);
|
|
|
|
|
|
|
|
// Derive isBusy state from activities
|
|
|
|
const isBusy = Object.keys( activities ).length > 0;
|
|
|
|
|
|
|
|
// HOC that starts and stops an activity while the callback is executed.
|
|
|
|
const withActivity = useCallback(
|
|
|
|
async ( id, description, asyncFn ) => {
|
|
|
|
startActivity( id, description );
|
|
|
|
try {
|
|
|
|
return await asyncFn();
|
|
|
|
} finally {
|
|
|
|
stopActivity( id );
|
|
|
|
}
|
|
|
|
},
|
|
|
|
[ startActivity, stopActivity ]
|
|
|
|
);
|
|
|
|
|
|
|
|
return {
|
|
|
|
withActivity, // HOC
|
|
|
|
isBusy, // Boolean.
|
|
|
|
activities, // Object.
|
|
|
|
};
|
|
|
|
};
|