redux-devtools/packages/redux-devtools-log-monitor/src/LogMonitorEntryAction.tsx
Nathan Bierema 2faa16319b
feat(redux-devtools-log-monitor): convert to TypeScript (#613)
* Stash

* And that

* finish

* fix up dependencies
2020-08-27 09:19:37 -04:00

80 lines
1.8 KiB
TypeScript

import React, { Component, CSSProperties, MouseEventHandler } from 'react';
import JSONTree from 'react-json-tree';
import { Base16Theme } from 'redux-devtools-themes';
import { Action } from 'redux';
const styles = {
actionBar: {
paddingTop: 8,
paddingBottom: 7,
paddingLeft: 16,
},
payload: {
margin: 0,
paddingLeft: 16,
overflow: 'auto',
},
};
interface Props<A extends Action<unknown>> {
theme: Base16Theme;
collapsed: boolean;
action: A;
expandActionRoot: boolean;
onClick: MouseEventHandler<HTMLDivElement>;
style: CSSProperties;
}
export default class LogMonitorAction<
A extends Action<unknown>
> extends Component<Props<A>> {
renderPayload(payload: Record<string, unknown>) {
return (
<div
style={{
...styles.payload,
backgroundColor: this.props.theme.base00,
}}
>
{Object.keys(payload).length > 0 ? (
<JSONTree
theme={this.props.theme}
invertTheme={false}
keyPath={['action']}
data={payload}
shouldExpandNode={this.shouldExpandNode}
/>
) : (
''
)}
</div>
);
}
shouldExpandNode = (
keyPath: (string | number)[],
data: any,
level: number
) => {
return this.props.expandActionRoot && level === 0;
};
render() {
const { type, ...payload } = this.props.action;
return (
<div
style={{
backgroundColor: this.props.theme.base02,
color: this.props.theme.base06,
...this.props.style,
}}
>
<div style={styles.actionBar} onClick={this.props.onClick}>
{type !== null && (type as string).toString()}
</div>
{!this.props.collapsed ? this.renderPayload(payload) : ''}
</div>
);
}
}