mirror of
https://github.com/grafana/grafana.git
synced 2025-02-25 18:55:37 -06:00
- use react-highlight-words - add highlighting (color and border) to the matching substring of the suggested items in the typeahead - extracted match finding from logging datasource - created new utils/text.ts class for text-related functions - added more types
48 lines
1.5 KiB
TypeScript
48 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;
|
|
}
|
|
|
|
const EXAMPLE_QUERY = '{job="default/prometheus"}';
|
|
|
|
export default class Logs extends PureComponent<LogsProps, {}> {
|
|
render() {
|
|
const { className = '', data } = this.props;
|
|
const hasData = data && data.rows && data.rows.length > 0;
|
|
return (
|
|
<div className={`${className} logs`}>
|
|
{hasData ? (
|
|
<div className="logs-entries panel-container">
|
|
{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>
|
|
) : null}
|
|
{!hasData ? (
|
|
<div className="panel-container">
|
|
Enter a query like <code>{EXAMPLE_QUERY}</code>
|
|
</div>
|
|
) : null}
|
|
</div>
|
|
);
|
|
}
|
|
}
|