Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Consolidate accounts onboarding: Set up Google Merchant Center account via the combo card #2639

Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
87 commits
Select commit Hold shift + click to select a range
874ef00
Save WIP.
asvinb Oct 3, 2024
1ead7f9
Merge branch 'feature/2567-kickoff-mc-ads-account-creation' into upda…
asvinb Oct 3, 2024
4428639
Extract DisconnectAccount button.
asvinb Oct 3, 2024
bebfaed
Add ConnectAccountCard component.
asvinb Oct 4, 2024
872787e
Add ConnectMCBody and ConnectMCFooter component.
asvinb Oct 4, 2024
9475ec2
Save WIP.
asvinb Oct 7, 2024
3965234
Check for non connected state.
asvinb Oct 7, 2024
8a4ba4c
Add preConditionReady check.
asvinb Oct 7, 2024
8b850fd
Revert dev temp changes.
asvinb Oct 7, 2024
176a4a8
Save E2E tests,
asvinb Oct 7, 2024
b4b4347
Merge branch 'feature/2509-consolidate-google-account-cards' into upd…
asvinb Oct 7, 2024
e9626f0
Save WIP.
asvinb Oct 8, 2024
57c4693
Merge branch 'feature/2567-kickoff-mc-ads-account-creation' into upda…
asvinb Oct 8, 2024
e86de9b
Review class names.
asvinb Oct 8, 2024
9ad469a
Merge branch 'feature/2567-kickoff-mc-ads-account-creation' into upda…
asvinb Oct 8, 2024
75723e2
Fix e2e tests.
asvinb Oct 8, 2024
9923f70
Merge branch 'feature/2567-kickoff-mc-ads-account-creation' into upda…
asvinb Oct 8, 2024
406f028
Use mock functions available.
asvinb Oct 8, 2024
26ec13a
Merge branch 'feature/2567-kickoff-mc-ads-account-creation' into upda…
asvinb Oct 9, 2024
acedda6
Address CR feedback.
asvinb Oct 9, 2024
13d8d2b
Cast googleMCAccount?.id to a boolean.
asvinb Oct 9, 2024
9e8649b
Add description when connecting extra account.
asvinb Oct 9, 2024
2981067
Fix card when reclaiming URL.
asvinb Oct 9, 2024
e03f3c3
Fix E2E tests.
asvinb Oct 9, 2024
3b096ff
Add isConnected property to useGoogleMCAccount hook.
asvinb Oct 10, 2024
deaa836
Removed unused constant.
asvinb Oct 10, 2024
66d6eb9
Wrap all cards together.
asvinb Oct 10, 2024
fa5b3ea
Add more properties to useAutoCreateAdsMCAccounts.js hook.
asvinb Oct 10, 2024
8707fea
Use useState.
asvinb Oct 10, 2024
14a08e8
Add isConnected check.
asvinb Oct 10, 2024
d3c2a36
Use single hook.
asvinb Oct 10, 2024
02a607a
Merge branch 'feature/2567-kickoff-mc-ads-account-creation' into upda…
asvinb Oct 16, 2024
25d2ff3
Save WIP.
asvinb Oct 16, 2024
a8d5db1
Save WIP
asvinb Oct 16, 2024
87a2046
Changes to how we manage the state.
asvinb Oct 16, 2024
06960d9
Fix select rendering.
asvinb Oct 16, 2024
8b06ef7
Revert changes
asvinb Oct 16, 2024
96c11a2
Update JSDocs.
asvinb Oct 17, 2024
3b1fe26
Merge branch 'feature/2567-kickoff-mc-ads-account-creation' into upda…
asvinb Oct 22, 2024
cd62e71
Merge branch 'feature/2567-kickoff-mc-ads-account-creation' into upda…
asvinb Oct 23, 2024
b582447
Merge branch 'feature/2567-kickoff-mc-ads-account-creation' into upda…
asvinb Oct 23, 2024
4eb41ac
Do not use template literals.
asvinb Oct 23, 2024
eb0bfc1
Merge branch 'feature/2567-kickoff-mc-ads-account-creation' into upda…
asvinb Oct 23, 2024
6696ee6
Update hooks.
asvinb Oct 23, 2024
d2e4b57
Merge branch 'feature/2567-kickoff-mc-ads-account-creation' into upda…
asvinb Oct 23, 2024
67b8d3b
Revert change.
asvinb Oct 23, 2024
ba5c054
Revert change.
asvinb Oct 23, 2024
6fd6dc4
Remove unused file.
asvinb Oct 23, 2024
c13c524
Review changes.
asvinb Oct 23, 2024
e845ece
Merge branch 'feature/2567-kickoff-mc-ads-account-creation' into upda…
asvinb Oct 24, 2024
b64bba7
Show ID only when connected.
asvinb Oct 24, 2024
841bb90
Make app select control non interactive.
asvinb Oct 24, 2024
dc6ea40
Fix failing test.
asvinb Oct 24, 2024
881ee8c
Fix linting error.
asvinb Oct 24, 2024
b9809e1
Merge branch 'feature/2567-kickoff-mc-ads-account-creation' into upda…
asvinb Oct 24, 2024
f41df99
Fix E2E tests.
asvinb Oct 24, 2024
2cadd89
Invalidate resolution for existing accounts when reclaiming url.
asvinb Oct 24, 2024
604c5c8
Invalidate existing accounts.
asvinb Oct 24, 2024
5f4435a
Add hasAccountConnectionIssue utility function.
asvinb Oct 25, 2024
8875a28
Connected select control.
asvinb Oct 25, 2024
49f51ca
Add MerchantCenterSelect component.
asvinb Oct 25, 2024
4d41762
No need to wait for data.
asvinb Oct 25, 2024
c117be7
Merge branch 'feature/2567-kickoff-mc-ads-account-creation' into upda…
asvinb Oct 25, 2024
fa72d4e
Merge branch 'feature/2509-consolidate-google-account-cards' into upd…
asvinb Oct 28, 2024
7a4e40d
Add JS Docs.
asvinb Oct 28, 2024
53c80c5
Update AccountCard component
joemcgill Oct 30, 2024
a9ea1b1
Incorporate new AccountCard into ConnectMC
joemcgill Oct 30, 2024
cb667fd
Update docblocks to AccountCard
joemcgill Oct 30, 2024
14c653c
JSLint fix
joemcgill Oct 30, 2024
a9c8839
Delete ConnectAccountCard
joemcgill Oct 30, 2024
a8b4f8c
Remove todo
joemcgill Oct 30, 2024
9c55a39
Add missing styles.
asvinb Oct 31, 2024
c40800b
Use correct button variant.
asvinb Oct 31, 2024
7a757a2
Merge pull request #2657 from woocommerce/update/2597-connect-mc-refa…
asvinb Oct 31, 2024
cc3e804
Sync changes.
asvinb Oct 31, 2024
8c4cd7a
Merge branch 'feature/2509-consolidate-google-account-cards' into upd…
asvinb Oct 31, 2024
a3040fe
Update JSDocs.
asvinb Oct 31, 2024
e75a930
Fix E2E tests.
asvinb Oct 31, 2024
8fba3e4
Remove unused functions.
asvinb Oct 31, 2024
17e7c84
Address CR feedback.
asvinb Nov 1, 2024
0e15813
Add MerchantCenterAccountInfoCard component.
asvinb Nov 4, 2024
4e201c1
Fix linting errors.
asvinb Nov 4, 2024
65e6854
Remove unused component.
asvinb Nov 4, 2024
4b777bc
Reorder imports.
asvinb Nov 4, 2024
9a368f1
Use correcct prop name.
asvinb Nov 4, 2024
66de193
Address CR feedback.
asvinb Nov 5, 2024
dacbd04
Add condition to not render the claim components if there's no connec…
asvinb Nov 5, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -17,13 +17,13 @@ import useGoogleMCAccount from '.~/hooks/useGoogleMCAccount';
const AccountDetails = () => {
const { google } = useGoogleAccount();
const { googleAdsAccount } = useGoogleAdsAccount();
const { googleMCAccount } = useGoogleMCAccount();
const { googleMCAccount, isReady: isGoogleMCReady } = useGoogleMCAccount();

return (
<>
<p>{ google.email }</p>
<p>
{ googleMCAccount?.id > 0 &&
{ isGoogleMCReady &&
sprintf(
// Translators: %s is the Merchant Center ID
__(
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,6 @@ import useApiFetchCallback from '.~/hooks/useApiFetchCallback';
import useDispatchCoreNotices from '.~/hooks/useDispatchCoreNotices';
import useGoogleAdsAccount from '.~/hooks/useGoogleAdsAccount';
import { useAppDispatch } from '.~/data';
import useExistingGoogleAdsAccounts from '.~/hooks/useExistingGoogleAdsAccounts';
import useGoogleAdsAccountReady from '.~/hooks/useGoogleAdsAccountReady';
import AccountCard from '.~/components/account-card';
import AdsAccountSelectControl from '.~/components/ads-account-select-control';
Expand All @@ -32,14 +31,7 @@ const ConnectAds = () => {
const { createNotice } = useDispatchCoreNotices();
const { fetchGoogleAdsAccountStatus } = useAppDispatch();
const isConnected = useGoogleAdsAccountReady();
const {
existingAccounts: accounts,
hasFinishedResolution: hasFinishedResolutionForExistingAdsAccount,
} = useExistingGoogleAdsAccounts();
const {
googleAdsAccount,
hasFinishedResolution: hasFinishedResolutionForCurrentAccount,
} = useGoogleAdsAccount();
const { googleAdsAccount, hasFinishedResolution } = useGoogleAdsAccount();
const [ connectGoogleAdsAccount ] = useApiFetchCallback( {
path: '/wc/gla/ads/accounts',
method: 'POST',
Expand Down Expand Up @@ -75,16 +67,11 @@ const ConnectAds = () => {
}
};

// If the accounts are still being fetched, we don't want to show the card.
if (
! hasFinishedResolutionForExistingAdsAccount ||
! hasFinishedResolutionForCurrentAccount ||
! accounts?.length
) {
return null;
}

const getIndicator = () => {
if ( ! hasFinishedResolution ) {
return <LoadingLabel />;
}

if ( isLoading ) {
return (
<LoadingLabel
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -35,6 +35,7 @@ const ConnectGoogleComboAccountCard = ( { disabled } ) => {
appearance={ APPEARANCE.GOOGLE }
disabled={ disabled }
alignIcon="top"
className="gla-google-combo-service-account-card--google"
description={
<>
<p>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,10 @@ import Indicator from './indicator';
import getAccountCreationTexts from './getAccountCreationTexts';
import SpinnerCard from '.~/components/spinner-card';
import useAutoCreateAdsMCAccounts from '.~/hooks/useAutoCreateAdsMCAccounts';
import useGoogleMCAccount from '.~/hooks/useGoogleMCAccount';
import useExistingGoogleMCAccounts from '.~/hooks/useExistingGoogleMCAccounts';
import useCreateMCAccount from '.~/hooks/useCreateMCAccount';
import ConnectMC from '.~/components/google-mc-account-card/connect-mc';
import useGoogleAdsAccountReady from '.~/hooks/useGoogleAdsAccountReady';
import useExistingGoogleAdsAccounts from '.~/hooks/useExistingGoogleAdsAccounts';
import './connected-google-combo-account-card.scss';
Expand All @@ -17,7 +21,15 @@ import './connected-google-combo-account-card.scss';
* It will also kickoff Ads and Merchant Center account creation if the user does not have accounts.
*/
const ConnectedGoogleComboAccountCard = () => {
const { hasDetermined, creatingWhich } = useAutoCreateAdsMCAccounts();
// We use a single instance of the hook to create a MC (Merchant Center) account,
// ensuring consistent results across both the main component (ConnectedGoogleComboAccountCard) and its child component (ConnectMC).
// This approach is especially useful when an MC account is automatically created, and the URL needs to be reclaimed.
// The URL reclaim component is rendered within the ConnectMC component.
const [ createMCAccount, resultCreateMCAccount ] = useCreateMCAccount();
const { data: existingGoogleMCAccounts } = useExistingGoogleMCAccounts();
const { isReady: isGoogleMCReady } = useGoogleMCAccount();
const { hasDetermined, creatingWhich } =
useAutoCreateAdsMCAccounts( createMCAccount );
const { text, subText } = getAccountCreationTexts( creatingWhich );
const { existingAccounts: existingGoogleAdsAccounts } =
useExistingGoogleAdsAccounts();
Expand All @@ -28,7 +40,12 @@ const ConnectedGoogleComboAccountCard = () => {
}

// @TODO: edit mode implementation in 2605
const editMode = false;
const editMode = true;
const hasExistingGoogleMCAccounts = existingGoogleMCAccounts?.length > 0;
const showConnectMC =
( editMode && hasExistingGoogleMCAccounts ) ||
( ! isGoogleMCReady && hasExistingGoogleMCAccounts );

const hasExistingGoogleAdsAccounts = existingGoogleAdsAccounts?.length > 0;
const showConnectAds =
( editMode && hasExistingGoogleAdsAccounts ) ||
Expand All @@ -39,7 +56,7 @@ const ConnectedGoogleComboAccountCard = () => {
<AccountCard
appearance={ APPEARANCE.GOOGLE }
alignIcon="top"
className="gla-google-combo-account-card--connected"
className="gla-google-combo-account-card gla-google-combo-account-card--connected gla-google-combo-service-account-card--google"
description={ text || <AccountDetails /> }
helper={ subText }
indicator={
Expand All @@ -48,6 +65,14 @@ const ConnectedGoogleComboAccountCard = () => {
/>

{ showConnectAds && <ConnectAds /> }

{ showConnectMC && (
<ConnectMC
createAccount={ createMCAccount }
resultCreateAccount={ resultCreateMCAccount }
className="gla-google-combo-account-card gla-google-combo-service-account-card--mc"
/>
) }
</div>
);
};
Expand Down
58 changes: 58 additions & 0 deletions js/src/components/google-mc-account-card/connect-mc/actions.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,58 @@
/**
* External dependencies
*/
import { __ } from '@wordpress/i18n';

/**
* Internal dependencies
*/
import CreateAccountButton from '../create-account-button';
import DisconnectAccountButton from '../disconnect-account-button';

/**
* Actions component.
*
* Conditionally renders either a button to disconnect the account if already
* connected, or a button to create a new Merchant Center account.
*
* @param {Object} props
* @param {boolean} props.isConnected Whether the Merchant Center account is connected.
* @param {Object} props.resultConnectMC The result of the connection request, used to handle loading state.
* @param {Object} props.resultCreateAccount The result of the create account request.
* @param {Function} props.onCreateAccount Callback function for creating a new Merchant Center account.
*/
const Actions = ( {
isConnected,
resultConnectMC,
resultCreateAccount,
onCreateAccount,
} ) => {
if ( isConnected ) {
const handleOnDisconnected = () => {
resultConnectMC.reset();
resultCreateAccount.reset();
};

return (
<DisconnectAccountButton
onDisconnected={ handleOnDisconnected }
isTertiary
/>
);
}

return (
<CreateAccountButton
isTertiary
disabled={ resultConnectMC.loading }
onCreateAccount={ onCreateAccount }
>
{ __(
'Or, create a new Merchant Center account',
'google-listings-and-ads'
) }
</CreateAccountButton>
);
};

export default Actions;
Loading