/** * External dependencies */ import { __ } from '@wordpress/i18n'; import { Button } from '@wordpress/components'; import { COUNTRIES_STORE_NAME } from '@woocommerce/data'; import { Fragment, useState } from '@wordpress/element'; import { Form, FormContextType, Spinner } from '@woocommerce/components'; import { useSelect } from '@wordpress/data'; import { Status, Options } from 'wordpress__notices'; /** * Internal dependencies */ import { StoreAddress, getStoreAddressValidator, } from '../../../dashboard/components/settings/general/store-address'; export type FormValues = { addressLine1: string; addressLine2: string; countryState: string; city: string; postCode: string; }; type StoreLocationProps = { onComplete: ( values: FormValues ) => void; createNotice: ( status: Status | undefined, content: string, options?: Partial< Options > ) => void; isSettingsRequesting: boolean; buttonText?: string; updateAndPersistSettingsForGroup: ( group: string, data: { [ key: string ]: unknown; } & { general?: { [ key: string ]: string; }; tax?: { [ key: string ]: string; }; } ) => void; settings?: { [ key: string ]: string; }; validate?: ( values: FormValues ) => { [ key: string ]: string }; }; export const defaultValidate = ( values: FormValues ) => { const validator = getStoreAddressValidator(); return validator( values ); }; const StoreLocation = ( { onComplete, createNotice, isSettingsRequesting, updateAndPersistSettingsForGroup, settings, buttonText = __( 'Continue', 'woocommerce' ), validate = defaultValidate, }: StoreLocationProps ) => { const { hasFinishedResolution } = useSelect( ( select ) => { const countryStore = select( COUNTRIES_STORE_NAME ); countryStore.getCountries(); return { getLocale: countryStore.getLocale, locales: countryStore.getLocales(), hasFinishedResolution: countryStore.hasFinishedResolution( 'getLocales' ) && countryStore.hasFinishedResolution( 'getCountries' ), }; } ); const [ isSubmitting, setSubmitting ] = useState( false ); const onSubmit = async ( values: FormValues ) => { setSubmitting( true ); try { await updateAndPersistSettingsForGroup( 'general', { general: { ...settings, woocommerce_store_address: values.addressLine1, woocommerce_store_address_2: values.addressLine2, woocommerce_default_country: values.countryState, woocommerce_store_city: values.city, woocommerce_store_postcode: values.postCode, }, } ); setSubmitting( false ); onComplete( values ); } catch ( e ) { setSubmitting( false ); createNotice( 'error', __( 'There was a problem saving your store location', 'woocommerce' ) ); } }; const getInitialValues = () => { return { addressLine1: settings?.woocommerce_store_address || '', addressLine2: settings?.woocommerce_store_address_2 || '', city: settings?.woocommerce_store_city || '', countryState: settings?.woocommerce_default_country || '', postCode: settings?.woocommerce_store_postcode || '', }; }; if ( isSettingsRequesting || ! hasFinishedResolution ) { return ; } return (
{ ( { getInputProps, handleSubmit, setValue, }: FormContextType< FormValues > ) => ( ) }
); }; export default StoreLocation;