-
Notifications
You must be signed in to change notification settings - Fork 21
/
Copy pathdisconnect-account.js
59 lines (53 loc) · 1.73 KB
/
disconnect-account.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
/**
* External dependencies
*/
import { __ } from '@wordpress/i18n';
import { noop } from 'lodash';
import { useState } from '@wordpress/element';
/**
* Internal dependencies
*/
import { useAppDispatch } from '~/data';
import AppButton from '~/components/app-button';
import useEventPropertiesFilter from '~/hooks/useEventPropertiesFilter';
import { FILTER_ONBOARDING } from '~/utils/tracks';
/**
* Clicking on the button to disconnect the Google Ads account.
*
* @event gla_ads_account_disconnect_button_click
* @property {string} [context] Indicates the place where the button is located.
* @property {string} [step] Indicates the step in the onboarding process.
*/
/**
* Renders a button to disconnect the Google Ads account.
*
* @fires gla_ads_account_disconnect_button_click When the user clicks on the button to disconnect the Google Ads account.
*
* @param {Object} props React props.
* @param {Function} [props.onDisconnected] Callback after the account is disconnected.
*/
const DisconnectAccount = ( { onDisconnected = noop } ) => {
const { disconnectGoogleAdsAccount } = useAppDispatch();
const [ isDisconnecting, setDisconnecting ] = useState( false );
const getEventProps = useEventPropertiesFilter( FILTER_ONBOARDING );
const handleSwitch = () => {
setDisconnecting( true );
disconnectGoogleAdsAccount( true )
.then( () => onDisconnected() )
.catch( () => setDisconnecting( false ) );
};
return (
<AppButton
isTertiary
loading={ isDisconnecting }
text={ __(
'Or, connect to a different Google Ads account',
'google-listings-and-ads'
) }
eventName="gla_ads_account_disconnect_button_click"
eventProps={ getEventProps() }
onClick={ handleSwitch }
/>
);
};
export default DisconnectAccount;