127 lines
3.2 KiB
TypeScript
127 lines
3.2 KiB
TypeScript
|
/**
|
||
|
* External dependencies
|
||
|
*/
|
||
|
import { __ } from '@wordpress/i18n';
|
||
|
import interpolateComponents from '@automattic/interpolate-components';
|
||
|
import { Link, Plugins as PluginInstaller } from '@woocommerce/components';
|
||
|
import { OPTIONS_STORE_NAME, InstallPluginsResponse } from '@woocommerce/data';
|
||
|
import { recordEvent } from '@woocommerce/tracks';
|
||
|
import { Text } from '@woocommerce/experimental';
|
||
|
import { useDispatch, useSelect } from '@wordpress/data';
|
||
|
import { useEffect } from '@wordpress/element';
|
||
|
|
||
|
/**
|
||
|
* Internal dependencies
|
||
|
*/
|
||
|
import { createNoticesFromResponse } from '~/lib/notices';
|
||
|
|
||
|
const isWcConnectOptions = (
|
||
|
wcConnectOptions: unknown
|
||
|
): wcConnectOptions is {
|
||
|
[ key: string ]: unknown;
|
||
|
} => typeof wcConnectOptions === 'object' && wcConnectOptions !== null;
|
||
|
|
||
|
type Props = {
|
||
|
nextStep: () => void;
|
||
|
pluginsToActivate: string[];
|
||
|
};
|
||
|
|
||
|
export const Plugins: React.FC< Props > = ( {
|
||
|
nextStep,
|
||
|
pluginsToActivate,
|
||
|
} ) => {
|
||
|
const { updateOptions } = useDispatch( OPTIONS_STORE_NAME );
|
||
|
const { isResolving, tosAccepted } = useSelect( ( select ) => {
|
||
|
const { getOption, hasFinishedResolution } =
|
||
|
select( OPTIONS_STORE_NAME );
|
||
|
const wcConnectOptions = getOption( 'wc_connect_options' );
|
||
|
|
||
|
return {
|
||
|
isResolving:
|
||
|
! hasFinishedResolution( 'getOption', [
|
||
|
'woocommerce_setup_jetpack_opted_in',
|
||
|
] ) ||
|
||
|
! hasFinishedResolution( 'getOption', [
|
||
|
'wc_connect_options',
|
||
|
] ),
|
||
|
tosAccepted:
|
||
|
( isWcConnectOptions( wcConnectOptions ) &&
|
||
|
wcConnectOptions?.tos_accepted ) ||
|
||
|
getOption( 'woocommerce_setup_jetpack_opted_in' ) === '1',
|
||
|
};
|
||
|
} );
|
||
|
|
||
|
useEffect( () => {
|
||
|
if ( ! tosAccepted || pluginsToActivate.length ) {
|
||
|
return;
|
||
|
}
|
||
|
|
||
|
nextStep();
|
||
|
}, [ nextStep, pluginsToActivate, tosAccepted ] );
|
||
|
const agreementText = pluginsToActivate.includes( 'woocommerce-services' )
|
||
|
? __(
|
||
|
'By installing Jetpack and WooCommerce Shipping you agree to the {{link}}Terms of Service{{/link}}.',
|
||
|
'woocommerce'
|
||
|
)
|
||
|
: __(
|
||
|
'By installing Jetpack you agree to the {{link}}Terms of Service{{/link}}.',
|
||
|
'woocommerce'
|
||
|
);
|
||
|
|
||
|
if ( isResolving ) {
|
||
|
return null;
|
||
|
}
|
||
|
|
||
|
return (
|
||
|
<>
|
||
|
<PluginInstaller
|
||
|
// @ts-expect-error PluginInstaller has onComplete props but it is a pure js component and doesn't export the right types.
|
||
|
onComplete={ (
|
||
|
activatedPlugins: string[],
|
||
|
response: InstallPluginsResponse
|
||
|
) => {
|
||
|
createNoticesFromResponse( response );
|
||
|
recordEvent(
|
||
|
'tasklist_shipping_recommendation_install_extensions',
|
||
|
{
|
||
|
install_extensions: true,
|
||
|
}
|
||
|
);
|
||
|
updateOptions( {
|
||
|
woocommerce_setup_jetpack_opted_in: true,
|
||
|
} );
|
||
|
nextStep();
|
||
|
} }
|
||
|
onError={ ( errors: unknown, response: unknown ) =>
|
||
|
createNoticesFromResponse( response )
|
||
|
}
|
||
|
pluginSlugs={ pluginsToActivate }
|
||
|
/>
|
||
|
{ ! tosAccepted && (
|
||
|
<Text
|
||
|
variant="caption"
|
||
|
className="woocommerce-task__caption"
|
||
|
size="12"
|
||
|
lineHeight="16px"
|
||
|
style={ { display: 'block' } }
|
||
|
>
|
||
|
{ interpolateComponents( {
|
||
|
mixedString: agreementText,
|
||
|
components: {
|
||
|
link: (
|
||
|
<Link
|
||
|
href={ 'https://wordpress.com/tos/' }
|
||
|
target="_blank"
|
||
|
type="external"
|
||
|
>
|
||
|
<></>
|
||
|
</Link>
|
||
|
),
|
||
|
},
|
||
|
} ) }
|
||
|
</Text>
|
||
|
) }
|
||
|
</>
|
||
|
);
|
||
|
};
|