/* eslint jsx-a11y/tabindex-no-positive: 0 */ import React from 'react'; import ReactDOM from 'react-dom'; import PropTypes from 'prop-types'; import { Flexbox, ScrollRegion, KeyCommandsRegion, ListensToFluxStore, ConfigPropContainer, } from 'mailspring-component-kit'; import { PreferencesUIStore } from 'mailspring-exports'; import PreferencesTabsBar from './preferences-tabs-bar'; class PreferencesRoot extends React.Component { static displayName = 'PreferencesRoot'; static containerRequired = false; static propTypes = { tab: PropTypes.object, tabs: PropTypes.array, selection: PropTypes.object, }; componentDidMount() { ReactDOM.findDOMNode(this).focus(); this._focusContent(); } componentDidUpdate(oldProps) { if (oldProps.tab !== this.props.tab) { const scrollRegion = document.querySelector('.preferences-content .scroll-region-content'); scrollRegion.scrollTop = 0; this._focusContent(); } } _localHandlers() { const stopPropagation = e => { e.stopPropagation(); }; // This prevents some basic commands from propagating to the threads list and // producing unexpected results // TODO This is a partial/temporary solution and should go away when we do the // Keymap/Commands/Menu refactor return { 'core:next-item': stopPropagation, 'core:previous-item': stopPropagation, 'core:select-up': stopPropagation, 'core:select-down': stopPropagation, 'core:select-item': stopPropagation, 'core:messages-page-up': stopPropagation, 'core:messages-page-down': stopPropagation, 'core:list-page-up': stopPropagation, 'core:list-page-down': stopPropagation, 'core:remove-from-view': stopPropagation, 'core:gmail-remove-from-view': stopPropagation, 'core:remove-and-previous': stopPropagation, 'core:remove-and-next': stopPropagation, 'core:archive-item': stopPropagation, 'core:delete-item': stopPropagation, 'core:print-thread': stopPropagation, }; } // Focus the first thing with a tabindex when we update. // inside the content area. This makes it way easier to interact with prefs. _focusContent() { const node = ReactDOM.findDOMNode(this._contentComponent).querySelector('[tabindex]'); if (node) { node.focus(); } } render() { const { tab, selection, tabs } = this.props; const TabComponent = tab && tab.componentClassFn(); return ( { this._contentComponent = el; }} > {tab ? : false} ); } } export default ListensToFluxStore(PreferencesRoot, { stores: [PreferencesUIStore], getStateFromStores() { const tabs = PreferencesUIStore.tabs(); const selection = PreferencesUIStore.selection(); const tab = tabs.find(t => t.tabId === selection.tabId); return { tabs, selection, tab }; }, });