/** @format */ /** * External dependencies */ import { __ } from '@wordpress/i18n'; import { Component, Fragment } from '@wordpress/element'; import { Button, CheckboxControl } from 'newspack-components'; import { includes, filter } from 'lodash'; import { compose } from '@wordpress/compose'; import { withDispatch } from '@wordpress/data'; /** * WooCommerce Dependencies */ import { getSetting } from '@woocommerce/wc-admin-settings'; /** * Internal dependencies */ import { H, Card } from '@woocommerce/components'; import withSelect from 'wc-api/with-select'; import { recordEvent } from 'lib/tracks'; const onboarding = getSetting( 'onboarding', {} ); class Industry extends Component { constructor() { super(); this.state = { error: null, selected: [], }; this.onContinue = this.onContinue.bind( this ); this.onChange = this.onChange.bind( this ); } async onContinue() { await this.validateField(); if ( this.state.error ) { return; } const { createNotice, goToNextStep, isError, updateProfileItems } = this.props; recordEvent( 'storeprofiler_store_industry_continue', { store_industry: this.state.selected } ); await updateProfileItems( { industry: this.state.selected } ); if ( ! isError ) { goToNextStep(); } else { createNotice( 'error', __( 'There was a problem updating your industries.', 'woocommerce-admin' ) ); } } async validateField() { const error = this.state.selected.length ? null : __( 'Please select at least one industry', 'woocommerce-admin' ); this.setState( { error } ); } onChange( slug ) { this.setState( state => { if ( includes( state.selected, slug ) ) { return { selected: filter( state.selected, value => { return value !== slug; } ) || [], }; } const newSelected = state.selected; newSelected.push( slug ); return { selected: newSelected, }; }, () => this.validateField() ); } render() { const { industries } = onboarding; const { error } = this.state; return ( { __( 'In which industry does the store operate?', 'woocommerce-admin' ) }

{ __( 'Choose any that apply' ) }

{ Object.keys( industries ).map( slug => { return ( this.onChange( slug ) } /> ); } ) } { error && { error } }
); } } export default compose( withSelect( select => { const { getProfileItemsError } = select( 'wc-api' ); const isError = Boolean( getProfileItemsError() ); return { isError }; } ), withDispatch( dispatch => { const { updateProfileItems } = dispatch( 'wc-api' ); const { createNotice } = dispatch( 'core/notices' ); return { createNotice, updateProfileItems, }; } ) )( Industry );