LogsContainer.tsx 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183
  1. import React, { PureComponent } from 'react';
  2. import { hot } from 'react-hot-loader';
  3. import { connect } from 'react-redux';
  4. import { DataSourceApi, Collapse } from '@grafana/ui';
  5. import {
  6. RawTimeRange,
  7. LogLevel,
  8. TimeZone,
  9. AbsoluteTimeRange,
  10. LogsModel,
  11. LogRowModel,
  12. LogsDedupStrategy,
  13. TimeRange,
  14. } from '@grafana/data';
  15. import { ExploreId, ExploreItemState } from 'app/types/explore';
  16. import { StoreState } from 'app/types';
  17. import { changeDedupStrategy, updateTimeRange } from './state/actions';
  18. import { toggleLogLevelAction, changeRefreshIntervalAction } from 'app/features/explore/state/actionTypes';
  19. import { deduplicatedLogsSelector, exploreItemUIStateSelector } from 'app/features/explore/state/selectors';
  20. import { getTimeZone } from '../profile/state/selectors';
  21. import { LiveLogsWithTheme } from './LiveLogs';
  22. import { offOption } from '@grafana/ui/src/components/RefreshPicker/RefreshPicker';
  23. import { Logs } from './Logs';
  24. interface LogsContainerProps {
  25. datasourceInstance: DataSourceApi | null;
  26. exploreId: ExploreId;
  27. loading: boolean;
  28. logsHighlighterExpressions?: string[];
  29. logsResult?: LogsModel;
  30. dedupedResult?: LogsModel;
  31. onClickLabel: (key: string, value: string) => void;
  32. onStartScanning: () => void;
  33. onStopScanning: () => void;
  34. timeZone: TimeZone;
  35. scanning?: boolean;
  36. scanRange?: RawTimeRange;
  37. toggleLogLevelAction: typeof toggleLogLevelAction;
  38. changeDedupStrategy: typeof changeDedupStrategy;
  39. dedupStrategy: LogsDedupStrategy;
  40. width: number;
  41. isLive: boolean;
  42. stopLive: typeof changeRefreshIntervalAction;
  43. updateTimeRange: typeof updateTimeRange;
  44. range: TimeRange;
  45. absoluteRange: AbsoluteTimeRange;
  46. }
  47. export class LogsContainer extends PureComponent<LogsContainerProps> {
  48. onChangeTime = (absoluteRange: AbsoluteTimeRange) => {
  49. const { exploreId, updateTimeRange } = this.props;
  50. updateTimeRange({ exploreId, absoluteRange });
  51. };
  52. onStopLive = () => {
  53. const { exploreId } = this.props;
  54. this.props.stopLive({ exploreId, refreshInterval: offOption.value });
  55. };
  56. handleDedupStrategyChange = (dedupStrategy: LogsDedupStrategy) => {
  57. this.props.changeDedupStrategy(this.props.exploreId, dedupStrategy);
  58. };
  59. handleToggleLogLevel = (hiddenLogLevels: LogLevel[]) => {
  60. const { exploreId } = this.props;
  61. this.props.toggleLogLevelAction({
  62. exploreId,
  63. hiddenLogLevels,
  64. });
  65. };
  66. getLogRowContext = async (row: LogRowModel, options?: any): Promise<any> => {
  67. const { datasourceInstance } = this.props;
  68. if (datasourceInstance) {
  69. return datasourceInstance.getLogRowContext(row, options);
  70. }
  71. return [];
  72. };
  73. render() {
  74. const {
  75. loading,
  76. logsHighlighterExpressions,
  77. logsResult,
  78. dedupedResult,
  79. onClickLabel,
  80. onStartScanning,
  81. onStopScanning,
  82. absoluteRange,
  83. timeZone,
  84. scanning,
  85. range,
  86. width,
  87. isLive,
  88. } = this.props;
  89. if (isLive) {
  90. return (
  91. <Collapse label="Logs" loading={false} isOpen>
  92. <LiveLogsWithTheme logsResult={logsResult} timeZone={timeZone} stopLive={this.onStopLive} />
  93. </Collapse>
  94. );
  95. }
  96. return (
  97. <Collapse label="Logs" loading={loading} isOpen>
  98. <Logs
  99. dedupStrategy={this.props.dedupStrategy || LogsDedupStrategy.none}
  100. data={logsResult}
  101. dedupedData={dedupedResult}
  102. highlighterExpressions={logsHighlighterExpressions}
  103. loading={loading}
  104. onChangeTime={this.onChangeTime}
  105. onClickLabel={onClickLabel}
  106. onStartScanning={onStartScanning}
  107. onStopScanning={onStopScanning}
  108. onDedupStrategyChange={this.handleDedupStrategyChange}
  109. onToggleLogLevel={this.handleToggleLogLevel}
  110. absoluteRange={absoluteRange}
  111. timeZone={timeZone}
  112. scanning={scanning}
  113. scanRange={range.raw}
  114. width={width}
  115. getRowContext={this.getLogRowContext}
  116. />
  117. </Collapse>
  118. );
  119. }
  120. }
  121. function mapStateToProps(state: StoreState, { exploreId }: { exploreId: string }) {
  122. const explore = state.explore;
  123. // @ts-ignore
  124. const item: ExploreItemState = explore[exploreId];
  125. const {
  126. logsHighlighterExpressions,
  127. logsResult,
  128. loading,
  129. scanning,
  130. datasourceInstance,
  131. isLive,
  132. range,
  133. absoluteRange,
  134. } = item;
  135. const { dedupStrategy } = exploreItemUIStateSelector(item);
  136. const dedupedResult = deduplicatedLogsSelector(item);
  137. const timeZone = getTimeZone(state.user);
  138. return {
  139. loading,
  140. logsHighlighterExpressions,
  141. logsResult,
  142. scanning,
  143. timeZone,
  144. dedupStrategy,
  145. dedupedResult,
  146. datasourceInstance,
  147. isLive,
  148. range,
  149. absoluteRange,
  150. };
  151. }
  152. const mapDispatchToProps = {
  153. changeDedupStrategy,
  154. toggleLogLevelAction,
  155. stopLive: changeRefreshIntervalAction,
  156. updateTimeRange,
  157. };
  158. export default hot(module)(
  159. connect(
  160. mapStateToProps,
  161. mapDispatchToProps
  162. )(LogsContainer)
  163. );