mirror of
https://github.com/grafana/grafana.git
synced 2025-02-13 00:55:47 -06:00
this is a fix-up PR that cleans up Explore Logging after the recent restructuring. - log results need to be merged since query transactions have been introduced - logging DS has its own language provider, query field, and start page (some of them based on prometheus components) - added loader animation to log viewer - removed logging logic from prometheus components
44 lines
1.5 KiB
TypeScript
44 lines
1.5 KiB
TypeScript
import React, { Fragment, PureComponent } from 'react';
|
|
import Highlighter from 'react-highlight-words';
|
|
|
|
import { LogsModel } from 'app/core/logs_model';
|
|
import { findHighlightChunksInText } from 'app/core/utils/text';
|
|
|
|
interface LogsProps {
|
|
className?: string;
|
|
data: LogsModel;
|
|
loading: boolean;
|
|
}
|
|
|
|
export default class Logs extends PureComponent<LogsProps, {}> {
|
|
render() {
|
|
const { className = '', data, loading = false } = this.props;
|
|
const hasData = data && data.rows && data.rows.length > 0;
|
|
return (
|
|
<div className={`${className} logs`}>
|
|
<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>
|
|
))}
|
|
</div>
|
|
{!loading && !hasData && 'No data was returned.'}
|
|
</div>
|
|
</div>
|
|
);
|
|
}
|
|
}
|