import React, { CSSProperties } from 'react'; import { connect } from 'react-redux'; import { Button, Toolbar, Spacer } from '@redux-devtools/ui'; import pkg from '@redux-devtools/inspector-monitor-test-tab/package.json'; import { RouteComponentProps, withRouter } from 'react-router-dom'; import getOptions from './getOptions'; import { DemoAppState } from './reducers'; import { AddFunctionAction, AddHugeObjectAction, AddImmutableMapAction, AddIteratorAction, AddRecursiveAction, AddSymbolAction, ChangeImmutableNestedAction, ChangeNestedAction, HugePayloadAction, IncrementAction, PopAction, PushAction, PushHugeArrayAction, ReplaceAction, ShuffleArrayAction, TimeoutUpdateAction, ToggleTimeoutUpdateAction, } from './reducers'; const styles: { wrapper: CSSProperties; muted: CSSProperties; link: CSSProperties; } = { wrapper: { height: '100vh', width: '450px', margin: 'auto', textAlign: 'center', }, muted: { color: '#CCCCCC', }, link: { margin: '0 0.5rem', cursor: 'pointer', display: 'block', }, }; const ROOT = '/'; // process.env.NODE_ENV === 'production' ? '/' : '/'; interface Props extends Omit { toggleTimeoutUpdate: (timeoutUpdateEnabled: boolean) => void; timeoutUpdate: () => void; increment: () => void; push: () => void; pop: () => void; replace: () => void; changeNested: () => void; pushHugeArray: () => void; addIterator: () => void; addHugeObject: () => void; addRecursive: () => void; addImmutableMap: () => void; changeImmutableNested: () => void; hugePayload: () => void; addFunction: () => void; addSymbol: () => void; shuffleArray: () => void; } class DemoApp extends React.Component { timeout?: number; render() { const options = getOptions(this.props.location); return (

{pkg.name || Package Name}

{pkg.description || ( Package Description )}
{options.useExtension ? ( Disable browser extension ) : ( Use browser extension )}
); } toggleTimeoutUpdate = () => { const enabled = !this.props.timeoutUpdateEnabled; this.props.toggleTimeoutUpdate(enabled); if (enabled) { this.timeout = window.setInterval(this.props.timeoutUpdate, 1000); } else { clearTimeout(this.timeout); } }; } export default connect((state: DemoAppState) => state, { toggleTimeoutUpdate: ( timeoutUpdateEnabled: boolean ): ToggleTimeoutUpdateAction => ({ type: 'TOGGLE_TIMEOUT_UPDATE', timeoutUpdateEnabled, }), timeoutUpdate: (): TimeoutUpdateAction => ({ type: 'TIMEOUT_UPDATE' }), increment: (): IncrementAction => ({ type: 'INCREMENT' }), push: (): PushAction => ({ type: 'PUSH' }), pop: (): PopAction => ({ type: 'POP' }), replace: (): ReplaceAction => ({ type: 'REPLACE' }), changeNested: (): ChangeNestedAction => ({ type: 'CHANGE_NESTED' }), pushHugeArray: (): PushHugeArrayAction => ({ type: 'PUSH_HUGE_ARRAY' }), addIterator: (): AddIteratorAction => ({ type: 'ADD_ITERATOR' }), addHugeObject: (): AddHugeObjectAction => ({ type: 'ADD_HUGE_OBJECT' }), addRecursive: (): AddRecursiveAction => ({ type: 'ADD_RECURSIVE' }), addImmutableMap: (): AddImmutableMapAction => ({ type: 'ADD_IMMUTABLE_MAP' }), changeImmutableNested: (): ChangeImmutableNestedAction => ({ type: 'CHANGE_IMMUTABLE_NESTED', }), hugePayload: (): HugePayloadAction => ({ type: 'HUGE_PAYLOAD', payload: Array.from({ length: 10000 }).map((_, i) => i), }), addFunction: (): AddFunctionAction => ({ type: 'ADD_FUNCTION' }), addSymbol: (): AddSymbolAction => ({ type: 'ADD_SYMBOL' }), shuffleArray: (): ShuffleArrayAction => ({ type: 'SHUFFLE_ARRAY' }), })(withRouter(DemoApp));