2018-07-20 10:07:17 -05:00
|
|
|
import React, { Fragment, PureComponent } from 'react';
|
2018-10-05 06:00:45 -05:00
|
|
|
import Highlighter from 'react-highlight-words';
|
2018-07-20 10:07:17 -05:00
|
|
|
|
2018-10-05 06:00:45 -05:00
|
|
|
import { LogsModel } from 'app/core/logs_model';
|
|
|
|
import { findHighlightChunksInText } from 'app/core/utils/text';
|
2018-07-20 10:07:17 -05:00
|
|
|
|
|
|
|
interface LogsProps {
|
|
|
|
className?: string;
|
|
|
|
data: LogsModel;
|
2018-08-04 04:07:48 -05:00
|
|
|
loading: boolean;
|
2018-07-20 10:07:17 -05:00
|
|
|
}
|
|
|
|
|
2018-10-05 06:00:45 -05:00
|
|
|
export default class Logs extends PureComponent<LogsProps, {}> {
|
2018-07-20 10:07:17 -05:00
|
|
|
render() {
|
2018-10-30 10:14:01 -05:00
|
|
|
const { className = '', data, loading = false } = this.props;
|
2018-07-20 10:07:17 -05:00
|
|
|
const hasData = data && data.rows && data.rows.length > 0;
|
|
|
|
return (
|
|
|
|
<div className={`${className} logs`}>
|
2018-10-30 10:14:01 -05:00
|
|
|
<div className="panel-container">
|
|
|
|
{loading && <div className="explore-panel__loader" />}
|
|
|
|
<div className="logs-entries">
|
|
|
|
{hasData &&
|
|
|
|
data.rows.map(row => (
|
|
|
|
<Fragment key={row.key}>
|
|
|
|
<div className={row.logLevel ? `logs-row-level logs-row-level-${row.logLevel}` : ''} />
|
|
|
|
<div title={`${row.timestamp} (${row.timeFromNow})`}>{row.timeLocal}</div>
|
|
|
|
<div>
|
|
|
|
<Highlighter
|
|
|
|
textToHighlight={row.entry}
|
|
|
|
searchWords={row.searchWords}
|
|
|
|
findChunks={findHighlightChunksInText}
|
|
|
|
highlightClassName="logs-row-match-highlight"
|
|
|
|
/>
|
|
|
|
</div>
|
|
|
|
</Fragment>
|
|
|
|
))}
|
2018-07-20 10:07:17 -05:00
|
|
|
</div>
|
2018-10-30 10:14:01 -05:00
|
|
|
{!loading && !hasData && 'No data was returned.'}
|
|
|
|
</div>
|
2018-07-20 10:07:17 -05:00
|
|
|
</div>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|