diff --git a/x-pack/plugins/security_solution/public/resolver/view/panels/copyable_panel_field.tsx b/x-pack/plugins/security_solution/public/resolver/view/panels/copyable_panel_field.tsx index 356dd1c73678e..c3474a7724dee 100644 --- a/x-pack/plugins/security_solution/public/resolver/view/panels/copyable_panel_field.tsx +++ b/x-pack/plugins/security_solution/public/resolver/view/panels/copyable_panel_field.tsx @@ -9,10 +9,10 @@ import { EuiToolTip, EuiPopover } from '@elastic/eui'; import { i18n } from '@kbn/i18n'; import styled from 'styled-components'; -import React, { memo, useState, useContext } from 'react'; +import React, { memo, useState } from 'react'; import { WithCopyToClipboard } from '../../../common/lib/clipboard/with_copy_to_clipboard'; import { useColors } from '../use_colors'; -import { ResolverPanelContext } from './panel_context'; +import { StyledPanel } from '../styles'; interface StyledCopyableField { readonly backgroundColor: string; @@ -20,28 +20,35 @@ interface StyledCopyableField { } const StyledCopyableField = styled.div` - background-color: ${(props) => props.backgroundColor}; border-radius: 3px; padding: 4px; transition: background 0.2s ease; - &:hover { - background-color: ${(props) => props.activeBackgroundColor}; - color: #fff; + ${StyledPanel}:hover & { + background-color: ${(props) => props.backgroundColor}; + + &:hover { + background-color: ${(props) => props.activeBackgroundColor}; + color: #fff; + } } `; +/** + * Field that behaves similarly to the current implementation of copyable fields in timeline as of 7.10 + * When the panel is hovered, these fields will show a gray background + * When you then hover over these fields they will show a blue background and a tooltip with a copy button will appear + */ export const CopyablePanelField = memo( ({ textToCopy, content }: { textToCopy: string; content: JSX.Element | string }) => { - const { linkColor, copyableBackground } = useColors(); + const { linkColor, copyableFieldBackground } = useColors(); const [isOpen, setIsOpen] = useState(false); - const panelContext = useContext(ResolverPanelContext); const onMouseEnter = () => setIsOpen(true); const ButtonContent = memo(() => ( updateIsHoveringInPanel(true); - const stopPanelHover = () => updateIsHoveringInPanel(false); - - /* The default 'Event List' / 'List of all processes' view */ - let panelViewToRender = ; - if (params.panelView === 'nodeDetail') { - panelViewToRender = ; + return ; } else if (params.panelView === 'nodeEvents') { - panelViewToRender = ; + return ; } else if (params.panelView === 'nodeEventsInCategory') { - panelViewToRender = ( + return ( ); } else if (params.panelView === 'eventDetail') { - panelViewToRender = ( + return ( ); + } else { + /* The default 'Event List' / 'List of all processes' view */ + return ; } - - return ( - -
- {panelViewToRender} -
-
- ); }); diff --git a/x-pack/plugins/security_solution/public/resolver/view/panels/panel_context.tsx b/x-pack/plugins/security_solution/public/resolver/view/panels/panel_context.tsx deleted file mode 100644 index 60109c732c46d..0000000000000 --- a/x-pack/plugins/security_solution/public/resolver/view/panels/panel_context.tsx +++ /dev/null @@ -1,9 +0,0 @@ -/* - * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one - * or more contributor license agreements. Licensed under the Elastic License; - * you may not use this file except in compliance with the Elastic License. - */ - -import React from 'react'; - -export const ResolverPanelContext = React.createContext({ isHoveringInPanel: false }); diff --git a/x-pack/plugins/security_solution/public/resolver/view/use_colors.ts b/x-pack/plugins/security_solution/public/resolver/view/use_colors.ts index 6f0cbcb3fd876..7daf181a7b2bb 100644 --- a/x-pack/plugins/security_solution/public/resolver/view/use_colors.ts +++ b/x-pack/plugins/security_solution/public/resolver/view/use_colors.ts @@ -10,7 +10,7 @@ import { useMemo } from 'react'; import { useUiSetting } from '../../../../../../src/plugins/kibana_react/public'; type ResolverColorNames = - | 'copyableBackground' + | 'copyableFieldBackground' | 'descriptionText' | 'full' | 'graphControls' @@ -33,7 +33,7 @@ export function useColors(): ColorMap { const theme = isDarkMode ? euiThemeAmsterdamDark : euiThemeAmsterdamLight; return useMemo(() => { return { - copyableBackground: theme.euiColorLightShade, + copyableFieldBackground: theme.euiColorLightShade, descriptionText: theme.euiTextColor, full: theme.euiColorFullShade, graphControls: theme.euiColorDarkestShade,