import cn from 'classnames'; import { connect } from 'react-redux'; import { connectPlayer, STORAGE_TYPES, selectStorageType, selectStorageListNow, } from 'Player/store'; import LiveTag from 'Shared/LiveTag'; import { Popup, Icon } from 'UI'; import { toggleInspectorMode } from 'Player'; import { fullscreenOn, fullscreenOff, toggleBottomBlock, CONSOLE, NETWORK, STACKEVENTS, STORAGE, PROFILER, PERFORMANCE, GRAPHQL, FETCH, EXCEPTIONS, LONGTASKS, INSPECTOR, } from 'Duck/components/player'; import { ReduxTime } from './Time'; import Timeline from './Timeline'; import ControlButton from './ControlButton'; import styles from './controls.css'; function getStorageIconName(type) { switch(type) { case STORAGE_TYPES.REDUX: return "vendors/redux"; case STORAGE_TYPES.MOBX: return "vendors/mobx" case STORAGE_TYPES.VUEX: return "vendors/vuex"; case STORAGE_TYPES.NGRX: return "vendors/ngrx"; case STORAGE_TYPES.NONE: return "store" } } function getStorageName(type) { switch(type) { case STORAGE_TYPES.REDUX: return "Redux"; case STORAGE_TYPES.MOBX: return "MobX"; case STORAGE_TYPES.VUEX: return "Vuex"; case STORAGE_TYPES.NGRX: return "NgRx"; case STORAGE_TYPES.NONE: return "State"; } } @connectPlayer(state => ({ time: state.time, endTime: state.endTime, live: state.live, livePlay: state.livePlay, playing: state.playing, completed: state.completed, skip: state.skip, skipToIssue: state.skipToIssue, speed: state.speed, disabled: state.cssLoading || state.messagesLoading || state.inspectorMode || state.markedTargets, inspectorMode: state.inspectorMode, fullscreenDisabled: state.messagesLoading, logCount: state.logListNow.length, logRedCount: state.logRedCountNow, // resourceCount: state.resourceCountNow, resourceRedCount: state.resourceRedCountNow, fetchRedCount: state.fetchRedCountNow, showStack: state.stackList.length > 0, stackCount: state.stackListNow.length, stackRedCount: state.stackRedCountNow, profilesCount: state.profilesListNow.length, storageCount: selectStorageListNow(state).length, storageType: selectStorageType(state), showStorage: selectStorageType(state) !== STORAGE_TYPES.NONE, showProfiler: state.profilesList.length > 0, showGraphql: state.graphqlList.length > 0, showFetch: state.fetchCount > 0, fetchCount: state.fetchCountNow, graphqlCount: state.graphqlListNow.length, exceptionsCount: state.exceptionsListNow.length, showExceptions: state.exceptionsList.length > 0, showLongtasks: state.longtasksList.length > 0, })) @connect((state, props) => { const permissions = state.getIn([ 'user', 'account', 'permissions' ]) || []; const isEnterprise = state.getIn([ 'user', 'client', 'edition' ]) === 'ee'; return { disabled: props.disabled || (isEnterprise && !permissions.includes('DEV_TOOLS')), fullscreen: state.getIn([ 'components', 'player', 'fullscreen' ]), bottomBlock: state.getIn([ 'components', 'player', 'bottomBlock' ]), showStorage: props.showStorage || !state.getIn(['components', 'player', 'hiddenHints', 'storage']), showStack: props.showStack || !state.getIn(['components', 'player', 'hiddenHints', 'stack']), } }, { fullscreenOn, fullscreenOff, toggleBottomBlock, }) export default class Controls extends React.Component { componentDidMount() { document.addEventListener('keydown', this.onKeyDown); } componentWillUnmount() { document.removeEventListener('keydown', this.onKeyDown); //this.props.toggleInspectorMode(false); } shouldComponentUpdate(nextProps) { if ( nextProps.fullscreen !== this.props.fullscreen || nextProps.bottomBlock !== this.props.bottomBlock || nextProps.endTime !== this.props.endTime || nextProps.live !== this.props.live || nextProps.livePlay !== this.props.livePlay || nextProps.playing !== this.props.playing || nextProps.completed !== this.props.completed || nextProps.skip !== this.props.skip || nextProps.skipToIssue !== this.props.skipToIssue || nextProps.speed !== this.props.speed || nextProps.disabled !== this.props.disabled || nextProps.fullscreenDisabled !== this.props.fullscreenDisabled || // nextProps.inspectorMode !== this.props.inspectorMode || nextProps.logCount !== this.props.logCount || nextProps.logRedCount !== this.props.logRedCount || nextProps.resourceRedCount !== this.props.resourceRedCount || nextProps.fetchRedCount !== this.props.fetchRedCount || nextProps.showStack !== this.props.showStack || nextProps.stackCount !== this.props.stackCount || nextProps.stackRedCount !== this.props.stackRedCount || nextProps.profilesCount !== this.props.profilesCount || nextProps.storageCount !== this.props.storageCount || nextProps.storageType !== this.props.storageType || nextProps.showStorage !== this.props.showStorage || nextProps.showProfiler !== this.props.showProfiler || nextProps.showGraphql !== this.props.showGraphql || nextProps.showFetch !== this.props.showFetch || nextProps.fetchCount !== this.props.fetchCount || nextProps.graphqlCount !== this.props.graphqlCount || nextProps.showExceptions !== this.props.showExceptions || nextProps.exceptionsCount !== this.props.exceptionsCount || nextProps.showLongtasks !== this.props.showLongtasks ) return true; return false; } onKeyDown = (e) => { if (e.target instanceof HTMLInputElement || e.target instanceof HTMLTextAreaElement) { return; } if (this.props.inspectorMode) return; if (e.key === ' ') { document.activeElement.blur(); this.props.togglePlay(); } if (e.key === 'Esc' || e.key === 'Escape') { this.props.fullscreenOff(); } if (e.key === "ArrowRight") { this.forthTenSeconds(); } if (e.key === "ArrowLeft") { this.backTenSeconds(); } if (e.key === "ArrowDown") { this.props.speedDown(); } if (e.key === "ArrowUp") { this.props.speedUp(); } } forthTenSeconds = () => { const { time, endTime, jump } = this.props; jump(Math.min(endTime, time + 1e4)) } backTenSeconds = () => { //shouldComponentUpdate const { time, jump } = this.props; jump(Math.max(0, time - 1e4)); } goLive =() => this.props.jump(this.props.endTime) renderPlayBtn = () => { const { completed, playing, disabled } = this.props; let label; let icon; if (completed) { label = 'Replay'; icon = 'redo'; } else if (playing) { label = 'Pause'; icon = 'pause'; } else { label = 'Play'; icon = 'play'; } return ( ); } render() { const { bottomBlock, toggleBottomBlock, live, livePlay, skip, speed, disabled, fullscreenDisabled, logCount, logRedCount, resourceRedCount, fetchRedCount, showStack, stackCount, stackRedCount, profilesCount, storageCount, showStorage, storageType, showProfiler, showGraphql, showFetch, fetchCount, graphqlCount, showLongtasks, exceptionsCount, showExceptions, fullscreen, skipToIssue, inspectorMode } = this.props; // const inspectorMode = bottomBlock === INSPECTOR; return (
{ !live && } { !fullscreen &&
{ !live ?
{ this.renderPlayBtn() }
:
{'Elapsed'}
}
{!live &&
}
{ !live && toggleBottomBlock(NETWORK) } active={ bottomBlock === NETWORK } label="Network" // count={ redResourceCount } hasErrors={ resourceRedCount > 0 } icon="wifi" /> } { showFetch && toggleBottomBlock(FETCH) } active={ bottomBlock === FETCH } hasErrors={ fetchRedCount > 0 } count={ fetchCount } label="Fetch" icon="fetch" /> } { !live && showGraphql && toggleBottomBlock(GRAPHQL) } active={ bottomBlock === GRAPHQL } count={ graphqlCount } label="GraphQL" icon="vendors/graphql" /> } { !live && showStorage && toggleBottomBlock(STORAGE) } active={ bottomBlock === STORAGE } count={ storageCount } label={ getStorageName(storageType) } icon={ getStorageIconName(storageType) } /> } { toggleBottomBlock(CONSOLE) } active={ bottomBlock === CONSOLE } label="Console" icon="console" count={ logCount } hasErrors={ logRedCount > 0 } /> } { showExceptions && toggleBottomBlock(EXCEPTIONS) } active={ bottomBlock === EXCEPTIONS } label="Exceptions" icon="console/error" count={ exceptionsCount } hasErrors={ exceptionsCount > 0 } /> } { !live && showStack && toggleBottomBlock(STACKEVENTS) } active={ bottomBlock === STACKEVENTS } label="Events" icon="puzzle-piece" count={ stackCount } hasErrors={ stackRedCount > 0 } /> } { !live && showProfiler && toggleBottomBlock(PROFILER) } active={ bottomBlock === PROFILER } count={ profilesCount } label="Profiler" icon="code" /> } { !live && toggleBottomBlock(PERFORMANCE) } active={ bottomBlock === PERFORMANCE } label="Performance" icon="tachometer-slow" /> } {/* { !live && showLongtasks && toggleBottomBlock(LONGTASKS) } active={ bottomBlock === LONGTASKS } label="Long Tasks" icon="business-time" /> } */}
{ !live && } {!live && ( )}
}
); } }