Skip to content

Commit

Permalink
[Resolver] Remove currentPanelView selector (elastic#71154)
Browse files Browse the repository at this point in the history
The `currentPanelView` selector returns a value that's out of sync
with the component that uses it.
  • Loading branch information
Robert Austin committed Jul 8, 2020
1 parent 9a75c48 commit 7922ba7
Show file tree
Hide file tree
Showing 7 changed files with 11 additions and 57 deletions.
12 changes: 0 additions & 12 deletions x-pack/plugins/security_solution/public/resolver/store/actions.ts
Original file line number Diff line number Diff line change
Expand Up @@ -24,17 +24,6 @@ interface UserBroughtProcessIntoView {
};
}

/**
* Dispatched to notify state that a different panel needs to be displayed
*/
interface AppDisplayedDifferentPanel {
readonly type: 'appDisplayedDifferentPanel';
/**
* The name of the panel to display
*/
readonly payload: string;
}

/**
* When an examination of query params in the UI indicates that state needs to
* be updated to reflect the new selection
Expand Down Expand Up @@ -130,5 +119,4 @@ export type ResolverAction =
| UserRequestedRelatedEventData
| UserSelectedRelatedEventCategory
| AppDetectedNewIdFromQueryParams
| AppDisplayedDifferentPanel
| AppDetectedMissingEventData;
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,6 @@ const uiReducer: Reducer<ResolverUIState, ResolverAction> = (
activeDescendantId: null,
selectedDescendantId: null,
processEntityIdOfSelectedDescendant: null,
panelToDisplay: null,
},
action
) => {
Expand All @@ -39,11 +38,6 @@ const uiReducer: Reducer<ResolverUIState, ResolverAction> = (
selectedDescendantId: action.payload.nodeId,
processEntityIdOfSelectedDescendant: action.payload.selectedProcessId,
};
} else if (action.type === 'appDisplayedDifferentPanel') {
return {
...uiState,
panelToDisplay: action.payload,
};
} else if (
action.type === 'userBroughtProcessIntoView' ||
action.type === 'appDetectedNewIdFromQueryParams'
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -127,11 +127,6 @@ export const uiSelectedDescendantProcessId = composeSelectors(
uiSelectors.selectedDescendantProcessId
);

/**
* The current panel to display
*/
export const currentPanelView = composeSelectors(uiStateSelector, uiSelectors.currentPanelView);

/**
* Returns the camera state from within ResolverState
*/
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -39,8 +39,3 @@ export const selectedDescendantProcessId = createSelector(
return processEntityIdOfSelectedDescendant;
}
);

// Select the current panel to be displayed
export const currentPanelView = (uiState: ResolverUIState) => {
return uiState.panelToDisplay;
};
4 changes: 0 additions & 4 deletions x-pack/plugins/security_solution/public/resolver/types.ts
Original file line number Diff line number Diff line change
Expand Up @@ -45,10 +45,6 @@ export interface ResolverUIState {
* The entity_id of the process for the resolver's currently selected descendant.
*/
readonly processEntityIdOfSelectedDescendant: string | null;
/**
* Which panel the ui should display
*/
readonly panelToDisplay: string | null;
}

/**
Expand Down
29 changes: 6 additions & 23 deletions x-pack/plugins/security_solution/public/resolver/view/panel.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -4,15 +4,7 @@
* you may not use this file except in compliance with the Elastic License.
*/

import React, {
memo,
useCallback,
useMemo,
useContext,
useLayoutEffect,
useState,
useEffect,
} from 'react';
import React, { memo, useCallback, useMemo, useContext, useLayoutEffect, useState } from 'react';
import { useSelector } from 'react-redux';
import { useHistory } from 'react-router-dom';
// eslint-disable-next-line import/no-nodejs-modules
Expand Down Expand Up @@ -205,21 +197,12 @@ const PanelContent = memo(function PanelContent() {
return 'processListWithCounts';
}, [uiSelectedEvent, crumbEvent, crumbId, graphableProcessEntityIds]);

useEffect(() => {
// dispatch `appDisplayedDifferentPanel` to sync state with which panel gets displayed
dispatch({
type: 'appDisplayedDifferentPanel',
payload: panelToShow,
});
}, [panelToShow, dispatch]);

const currentPanelView = useSelector(selectors.currentPanelView);
const terminatedProcesses = useSelector(selectors.terminatedProcesses);
const processEntityId = uiSelectedEvent ? event.entityId(uiSelectedEvent) : undefined;
const isProcessTerminated = processEntityId ? terminatedProcesses.has(processEntityId) : false;

const panelInstance = useMemo(() => {
if (currentPanelView === 'processDetails') {
if (panelToShow === 'processDetails') {
return (
<ProcessDetails
processEvent={uiSelectedEvent!}
Expand All @@ -230,7 +213,7 @@ const PanelContent = memo(function PanelContent() {
);
}

if (currentPanelView === 'eventCountsForProcess') {
if (panelToShow === 'eventCountsForProcess') {
return (
<EventCountsForProcess
processEvent={uiSelectedEvent!}
Expand All @@ -240,7 +223,7 @@ const PanelContent = memo(function PanelContent() {
);
}

if (currentPanelView === 'processEventListNarrowedByType') {
if (panelToShow === 'processEventListNarrowedByType') {
return (
<ProcessEventListNarrowedByType
processEvent={uiSelectedEvent!}
Expand All @@ -251,7 +234,7 @@ const PanelContent = memo(function PanelContent() {
);
}

if (currentPanelView === 'relatedEventDetail') {
if (panelToShow === 'relatedEventDetail') {
const parentCount: number = Object.values(
relatedStatsForIdFromParams?.events.byCategory || {}
).reduce((sum, val) => sum + val, 0);
Expand All @@ -278,7 +261,7 @@ const PanelContent = memo(function PanelContent() {
crumbId,
pushToQueryParams,
relatedStatsForIdFromParams,
currentPanelView,
panelToShow,
isProcessTerminated,
]);

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -82,10 +82,13 @@ const invalidDateText = i18n.translate(
}
);
/**
* @param {ConstructorParameters<typeof Date>[0]} timestamp To be passed through Date->Intl.DateTimeFormat
* @returns {string} A nicely formatted string for a date
*/
export function formatDate(timestamp: ConstructorParameters<typeof Date>[0]) {
export function formatDate(
/** To be passed through Date->Intl.DateTimeFormat */ timestamp: ConstructorParameters<
typeof Date
>[0]
): string {
const date = new Date(timestamp);
if (isFinite(date.getTime())) {
return formatter.format(date);
Expand Down

0 comments on commit 7922ba7

Please sign in to comment.