diff --git a/src/components/Main/App.jsx b/src/components/Main/App.jsx index 2c1beba81..e75f842ab 100644 --- a/src/components/Main/App.jsx +++ b/src/components/Main/App.jsx @@ -1,4 +1,5 @@ import React from 'react' +import { withRouter } from 'react-router' import { i18n } from '../../config' import { SectionTitle, ProgressBar, ScoreCard, Navigation, NavigationToggle } from '..' import { Introduction, Show } from '../Form' @@ -38,6 +39,20 @@ class App extends React.Component { } this.showInstructions = this.showInstructions.bind(this) this.dismissInstructions = this.dismissInstructions.bind(this) + + // workaround for not having React.createRef(), introduced in React 16.3 + // https://reactjs.org/docs/refs-and-the-dom.html#dont-overuse-refs + this.sectionFocusEl = null + this.setSectionFocusEl = (el) => { + this.sectionFocusEl = el + } + } + + componentDidUpdate(prevProps) { + // for keyboard navigation accessbility, focus on the main content area after a new section is navigated to + if (this.props.location.pathname !== prevProps.location.pathname) { + this.sectionFocusEl.focus() + } } showInstructions (event) { @@ -146,7 +161,7 @@ class App extends React.Component {   - +
{this.props.children}   @@ -179,4 +194,4 @@ function mapStateToProps (state) { // Wraps the the App component with connect() which adds the dispatch() // function to the props property for this component -export default connect(mapStateToProps)(App) +export default withRouter(connect(mapStateToProps)(App)) diff --git a/src/components/Main/App.test.jsx b/src/components/Main/App.test.jsx index 062e06d2a..4eec0734b 100644 --- a/src/components/Main/App.test.jsx +++ b/src/components/Main/App.test.jsx @@ -1,4 +1,5 @@ import React from 'react' +import { MemoryRouter } from 'react-router' import App from './App' import renderer from 'react-test-renderer' import configureMockStore from 'redux-mock-store' @@ -19,9 +20,11 @@ test('Renders homepage', () => { }) const component = renderer.create( - - - + + + + + ) let tree = component.toJSON() diff --git a/src/components/Section/Section.jsx b/src/components/Section/Section.jsx index abf4e44db..a7ed9a756 100644 --- a/src/components/Section/Section.jsx +++ b/src/components/Section/Section.jsx @@ -25,22 +25,6 @@ class Section extends React.Component { this.update(this.props) } - focusOnMainSection () { - const el = window.document.querySelector('.eapp-section-focus') - if (el) { - el.focus() - } - } - - componentDidUpdate (prevProps) { - // for keyboard navigation accessbility, focus on the main content area after a new section is navigated to - if (this.props.location.pathname !== prevProps.location.pathname) { - window.setTimeout(() => { - this.focusOnMainSection() - }, 200) - } - } - update (props) { const subsection = props.subsection || 'intro' const path = `/form/${props.section}/${subsection}`