LogsContainer.tsx 5.4 KB

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