selectors.ts 1.0 KB

1234567891011121314151617181920212223242526272829
  1. import { createLodashMemoizedSelector } from 'app/core/utils/reselect';
  2. import { ExploreItemState } from 'app/types';
  3. import { filterLogLevels, dedupLogRows } from 'app/core/logs_model';
  4. export const exploreItemUIStateSelector = (itemState: ExploreItemState) => {
  5. const { showingGraph, showingTable, showingStartPage, dedupStrategy } = itemState;
  6. return {
  7. showingGraph,
  8. showingTable,
  9. showingStartPage,
  10. dedupStrategy,
  11. };
  12. };
  13. const logsSelector = (state: ExploreItemState) => state.logsResult;
  14. const hiddenLogLevelsSelector = (state: ExploreItemState) => state.hiddenLogLevels;
  15. const dedupStrategySelector = (state: ExploreItemState) => state.dedupStrategy;
  16. export const deduplicatedLogsSelector = createLodashMemoizedSelector(
  17. logsSelector,
  18. hiddenLogLevelsSelector,
  19. dedupStrategySelector,
  20. (logs, hiddenLogLevels, dedupStrategy) => {
  21. if (!logs) {
  22. return null;
  23. }
  24. const filteredData = filterLogLevels(logs, new Set(hiddenLogLevels));
  25. return dedupLogRows(filteredData, dedupStrategy);
  26. }
  27. );