mirror of
https://github.com/woocommerce/woocommerce-paypal-payments.git
synced 2025-09-06 18:16:38 +08:00
♻️ Refactor onboarding actions to use controls
This commit is contained in:
parent
cf3798f610
commit
84d2af5f39
4 changed files with 105 additions and 62 deletions
|
@ -1,7 +1,10 @@
|
||||||
import { select } from '@wordpress/data';
|
|
||||||
import { apiFetch } from '@wordpress/data-controls';
|
|
||||||
import ACTION_TYPES from './action-types';
|
import ACTION_TYPES from './action-types';
|
||||||
import { NAMESPACE, STORE_NAME } from '../constants';
|
|
||||||
|
/**
|
||||||
|
* @typedef {Object} Action An action object that is handled by a reducer or control.
|
||||||
|
* @property {string} type - The action type.
|
||||||
|
* @property {Object?} payload - Optional payload for the action.
|
||||||
|
*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Special. Resets all values in the onboarding store to initial defaults.
|
* Special. Resets all values in the onboarding store to initial defaults.
|
||||||
|
@ -169,67 +172,23 @@ export const setProducts = ( products ) => {
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Attempts to establish a connection using client ID and secret via the server-side
|
* Side effect. Triggers the persistence of onboarding data to the server.
|
||||||
* connection endpoint.
|
|
||||||
*
|
*
|
||||||
* @return {Object} The server response object
|
* @return {Action} The action.
|
||||||
*/
|
*/
|
||||||
export function* connectViaIdAndSecret() {
|
export const persist = () => {
|
||||||
let result = null;
|
return {
|
||||||
|
type: ACTION_TYPES.DO_PERSIST_DATA,
|
||||||
try {
|
|
||||||
const path = `${ NAMESPACE }/connect_manual`;
|
|
||||||
const { clientId, clientSecret, useSandbox } =
|
|
||||||
yield select( STORE_NAME ).getPersistentData();
|
|
||||||
|
|
||||||
yield setManualConnectionIsBusy( true );
|
|
||||||
|
|
||||||
result = yield apiFetch( {
|
|
||||||
path,
|
|
||||||
method: 'POST',
|
|
||||||
data: {
|
|
||||||
clientId,
|
|
||||||
clientSecret,
|
|
||||||
useSandbox,
|
|
||||||
},
|
|
||||||
} );
|
|
||||||
} catch ( e ) {
|
|
||||||
result = {
|
|
||||||
success: false,
|
|
||||||
error: e,
|
|
||||||
};
|
};
|
||||||
} finally {
|
};
|
||||||
yield setManualConnectionIsBusy( false );
|
|
||||||
}
|
|
||||||
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Saves the persistent details to the WP database.
|
* Side effect. Initiates a manual connection attempt using the provided client ID and secret.
|
||||||
*
|
*
|
||||||
* @return {boolean} True, if the values were successfully saved.
|
* @return {Action} The action.
|
||||||
*/
|
*/
|
||||||
export function* persist() {
|
export const connectViaIdAndSecret = () => {
|
||||||
let error = null;
|
return {
|
||||||
|
type: ACTION_TYPES.DO_MANUAL_CONNECTION,
|
||||||
try {
|
};
|
||||||
const path = `${ NAMESPACE }/onboarding`;
|
};
|
||||||
const data = select( STORE_NAME ).getPersistentData();
|
|
||||||
|
|
||||||
yield setIsSaving( true );
|
|
||||||
|
|
||||||
yield apiFetch( {
|
|
||||||
path,
|
|
||||||
method: 'post',
|
|
||||||
data,
|
|
||||||
} );
|
|
||||||
} catch ( e ) {
|
|
||||||
error = e;
|
|
||||||
console.error( 'Error saving progress.', e );
|
|
||||||
} finally {
|
|
||||||
yield setIsSaving( false );
|
|
||||||
}
|
|
||||||
|
|
||||||
return error === null;
|
|
||||||
}
|
|
||||||
|
|
|
@ -8,3 +8,22 @@
|
||||||
*/
|
*/
|
||||||
export const STORE_KEY = 'onboarding';
|
export const STORE_KEY = 'onboarding';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* REST path to persist data of this module to the WP DB.
|
||||||
|
*
|
||||||
|
* Used by: Controls
|
||||||
|
* See: OnboardingRestEndpoint.php
|
||||||
|
*
|
||||||
|
* @type {string}
|
||||||
|
*/
|
||||||
|
export const REST_PERSIST_PATH = 'onboarding';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* REST path to perform the manual connection check, using client ID and secret,
|
||||||
|
*
|
||||||
|
* Used by: Controls
|
||||||
|
* See: ConnectManualRestEndpoint.php
|
||||||
|
*
|
||||||
|
* @type {string}
|
||||||
|
*/
|
||||||
|
export const REST_MANUAL_CONNECTION_PATH = 'connect_manual';
|
||||||
|
|
64
modules/ppcp-settings/resources/js/data/onboarding/controls.js
vendored
Normal file
64
modules/ppcp-settings/resources/js/data/onboarding/controls.js
vendored
Normal file
|
@ -0,0 +1,64 @@
|
||||||
|
import { select } from '@wordpress/data';
|
||||||
|
import { apiFetch } from '@wordpress/api-fetch';
|
||||||
|
|
||||||
|
import { NAMESPACE, STORE_NAME } from '../constants';
|
||||||
|
import { REST_PERSIST_PATH, REST_MANUAL_CONNECTION_PATH } from './constants';
|
||||||
|
import ACTION_TYPES from './action-types';
|
||||||
|
import { setIsSaving, setManualConnectionIsBusy } from './actions';
|
||||||
|
|
||||||
|
export const controls = {
|
||||||
|
[ ACTION_TYPES.DO_PERSIST_DATA ]: async ( { dispatch } ) => {
|
||||||
|
let error = null;
|
||||||
|
|
||||||
|
try {
|
||||||
|
const path = `${ NAMESPACE }/${ REST_PERSIST_PATH }`;
|
||||||
|
const data = select( STORE_NAME ).onboardingPersistentData();
|
||||||
|
|
||||||
|
dispatch( setIsSaving( true ) );
|
||||||
|
|
||||||
|
await apiFetch( {
|
||||||
|
path,
|
||||||
|
method: 'post',
|
||||||
|
data,
|
||||||
|
} );
|
||||||
|
} catch ( e ) {
|
||||||
|
error = e;
|
||||||
|
console.error( 'Error saving progress.', e );
|
||||||
|
} finally {
|
||||||
|
dispatch( setIsSaving( false ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
return error === null;
|
||||||
|
},
|
||||||
|
|
||||||
|
[ ACTION_TYPES.DO_MANUAL_CONNECTION ]: async ( { dispatch } ) => {
|
||||||
|
let result = null;
|
||||||
|
|
||||||
|
try {
|
||||||
|
const path = `${ NAMESPACE }/${ REST_MANUAL_CONNECTION_PATH }`;
|
||||||
|
const { clientId, clientSecret, useSandbox } =
|
||||||
|
select( STORE_NAME ).onboardingPersistentData();
|
||||||
|
|
||||||
|
dispatch( setManualConnectionIsBusy( true ) );
|
||||||
|
|
||||||
|
result = await apiFetch( {
|
||||||
|
path,
|
||||||
|
method: 'POST',
|
||||||
|
data: {
|
||||||
|
clientId,
|
||||||
|
clientSecret,
|
||||||
|
useSandbox,
|
||||||
|
},
|
||||||
|
} );
|
||||||
|
} catch ( e ) {
|
||||||
|
result = {
|
||||||
|
success: false,
|
||||||
|
error: e,
|
||||||
|
};
|
||||||
|
} finally {
|
||||||
|
dispatch( setManualConnectionIsBusy( false ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
return result;
|
||||||
|
},
|
||||||
|
};
|
|
@ -3,5 +3,6 @@ import reducer from './reducer';
|
||||||
import * as selectors from './selectors';
|
import * as selectors from './selectors';
|
||||||
import * as actions from './actions';
|
import * as actions from './actions';
|
||||||
import * as resolvers from './resolvers';
|
import * as resolvers from './resolvers';
|
||||||
|
import { controls } from './controls';
|
||||||
|
|
||||||
export { reducer, selectors, actions, resolvers, STORE_KEY };
|
export { reducer, selectors, actions, resolvers, controls, STORE_KEY };
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue