Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[Dashboard Usability] Remove borders from presentation panel and CSS clean up for hover actions #198454

Merged
merged 25 commits into from
Nov 13, 2024
Merged
Show file tree
Hide file tree
Changes from 6 commits
Commits
Show all changes
25 commits
Select commit Hold shift + click to select a range
3ba63da
Fix border styles in dashboard
cqliu1 Oct 30, 2024
a22965f
Move border styles into presentation panel
cqliu1 Nov 1, 2024
4f0b522
Delete unused CSS
cqliu1 Nov 1, 2024
c72ef4c
More cleanup
cqliu1 Nov 1, 2024
f5f6fbe
[CI] Auto-commit changed files from 'node scripts/eslint --no-cache -…
kibanamachine Nov 1, 2024
ac03c42
Remove conflicting styles in solutions
cqliu1 Nov 1, 2024
f4ae6de
Fix emotion
cqliu1 Nov 4, 2024
ed0b4fc
Merge branch 'main' of https://github.com/elastic/kibana into dashboa…
cqliu1 Nov 4, 2024
9420aea
Fix hover actions check
cqliu1 Nov 5, 2024
db2e564
Only show panel border on hover if hover actions are available
cqliu1 Nov 5, 2024
d89fdde
Merge branch 'main' of https://github.com/elastic/kibana into dashboa…
cqliu1 Nov 5, 2024
0146c38
Add comments
cqliu1 Nov 5, 2024
ff5237d
Fix z-index on hover actions hover
cqliu1 Nov 7, 2024
3c57f94
Fix hover actions getting cut off
cqliu1 Nov 7, 2024
5360032
Fix outlines on hover with margins on and off
cqliu1 Nov 7, 2024
32d978b
Move hover actions styles to emotion
cqliu1 Nov 7, 2024
945ccd5
Remove unused imports
cqliu1 Nov 7, 2024
57399c7
Merge branch 'main' of https://github.com/elastic/kibana into dashboa…
cqliu1 Nov 7, 2024
1b38329
Update presentation_panel_hover_actions.tsx
cqliu1 Nov 7, 2024
e75da38
[CI] Auto-commit changed files from 'node scripts/eslint --no-cache -…
kibanamachine Nov 8, 2024
ed9869c
Fix whitespace
cqliu1 Nov 11, 2024
acff0b1
Merge branch 'main' of https://github.com/elastic/kibana into dashboa…
cqliu1 Nov 11, 2024
4b5535a
Change hover border selectors
cqliu1 Nov 11, 2024
397b828
Merge branch 'main' of https://github.com/elastic/kibana into dashboa…
cqliu1 Nov 11, 2024
bff6474
Merge branch 'main' into dashboard/hover-actions-style-cleanup
cqliu1 Nov 12, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
@@ -1,41 +1,7 @@
/**
* EDITING MODE
* Use .dshLayout--editing to target editing state because
* .embPanel--editing doesn't get updating without a hard refresh
*/

.dshLayout--editing {
// change the style of the hover actions border to a dashed line in edit mode
.embPanel__hoverActionsAnchor {
.embPanel__hoverActionsWrapper {
.embPanel__hoverActions {
border-color: $euiColorMediumShade;
border-style: dashed;
}
}
}
}

// LAYOUT MODES
// Adjust borders/etc... for non-spaced out and expanded panels
.dshLayout-withoutMargins {
.embPanel,
.embPanel__hoverActionsAnchor {
box-shadow: none;
outline: none;
border-radius: 0;
}

&.dshLayout--editing {
.embPanel__hoverActionsAnchor:hover {
outline: 1px dashed $euiColorMediumShade;
}
}

.embPanel__hoverActionsAnchor:hover {
outline: $euiBorderThin;
z-index: $euiZLevel2;
}
margin-top: $euiSizeS;
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is adds space between controls and the dashboard grid when margins are off.


.embPanel__content,
.dshDashboardGrid__item--highlighted,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -128,7 +128,7 @@ Default.args = {
hideHeader: false,
loading: false,
showShadow: false,
showBorder: true,
showBorder: false,
Heenawter marked this conversation as resolved.
Show resolved Hide resolved
title: 'Hello World',
viewMode: true,
};
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -72,6 +72,7 @@ export const getLensAttributes = (group: EventAnnotationGroupConfig, timeField:
language: 'kuery',
},
filters: [],
showBorder: false,
datasourceStates: {
formBased: {
layers: {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -6,8 +6,6 @@
height: 100%;
min-height: $euiSizeL + 2px; // + 2px to account for border
position: relative;
border: none;
outline: $euiBorderThin;

&-isLoading {
// completely center the loading indicator
Expand Down Expand Up @@ -141,7 +139,6 @@

.embPanel--editing {
transition: all $euiAnimSpeedFast $euiAnimSlightResistance;
outline: 1px dashed $euiColorMediumShade;

.embPanel--dragHandle {
transition: background-color $euiAnimSpeedFast $euiAnimSlightResistance;
Expand Down Expand Up @@ -192,7 +189,6 @@
padding: calc($euiSizeXS - 1px);
display: flex;
flex-wrap: nowrap;
border: $euiBorderThin;

background-color: $euiColorEmptyShade;
height: $euiSizeXL;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -41,7 +41,7 @@ import {
} from '@kbn/presentation-publishing';
import { Subscription } from 'rxjs';
import { euiThemeVars } from '@kbn/ui-theme';
import { css } from '@emotion/react';
import { css, CSSObject } from '@emotion/react';
import { ActionWithContext } from '@kbn/ui-actions-plugin/public/context_menu/build_eui_context_menu_panels';
import { uiActions } from '../../kibana_services';
import {
Expand All @@ -67,12 +67,19 @@ const QUICK_ACTION_IDS = {

const ALLOWED_NOTIFICATIONS = ['ACTION_FILTERS_NOTIFICATION'] as const;

const ALL_ROUNDED_CORNERS = `border-radius: ${euiThemeVars.euiBorderRadius};
`;
const TOP_ROUNDED_CORNERS = `border-top-left-radius: ${euiThemeVars.euiBorderRadius};
border-top-right-radius: ${euiThemeVars.euiBorderRadius};
border-bottom: 0 !important;
`;
const ALL_ROUNDED_CORNERS: CSSObject = {
borderRadius: euiThemeVars.euiBorderRadius,
borderWidth: '1px',
};
const TOP_ROUNDED_CORNERS: CSSObject = {
borderTopLeftRadius: euiThemeVars.euiBorderRadius,
borderTopRightRadius: euiThemeVars.euiBorderRadius,
borderWidth: '1px',
borderBottom: `0px`,
};

const DASHED_OUTLINE = `1px dashed ${euiThemeVars.euiColorMediumShade}`;
const SOLID_OUTLINE = `1px solid ${euiThemeVars.euiBorderColor}`;

const createClickHandler =
(action: AnyApiAction, context: ActionExecutionContext<EmbeddableApiContext>) =>
Expand Down Expand Up @@ -101,6 +108,7 @@ export const PresentationPanelHoverActions = ({
className,
viewMode,
showNotifications = true,
showBorder,
}: {
index?: number;
api: DefaultPresentationPanelApi | null;
Expand All @@ -110,6 +118,7 @@ export const PresentationPanelHoverActions = ({
className?: string;
viewMode?: ViewMode;
showNotifications?: boolean;
showBorder?: boolean;
}) => {
const [quickActions, setQuickActions] = useState<AnyApiAction[]>([]);
const [contextMenuPanels, setContextMenuPanels] = useState<EuiContextMenuPanelDescriptor[]>([]);
Expand All @@ -121,7 +130,7 @@ export const PresentationPanelHoverActions = ({
const leftHoverActionsRef = useRef<HTMLDivElement | null>(null);
const rightHoverActionsRef = useRef<HTMLDivElement | null>(null);
const [combineHoverActions, setCombineHoverActions] = useState<boolean>(false);
const [borderStyles, setBorderStyles] = useState<string>(TOP_ROUNDED_CORNERS);
const [borderStyles, setBorderStyles] = useState<CSSObject>(TOP_ROUNDED_CORNERS);

const updateCombineHoverActions = () => {
if (!hoverActionsRef.current || !anchorRef.current) return;
Expand Down Expand Up @@ -195,7 +204,6 @@ export const PresentationPanelHoverActions = ({
);

const hideTitle = hidePanelTitle || parentHideTitle;

const showDescription = description && (!title || hideTitle);

const quickActionIds = useMemo(
Expand Down Expand Up @@ -462,6 +470,15 @@ export const PresentationPanelHoverActions = ({
/\s/g,
''
)}`}
css={css`
${showBorder ? `outline: ${viewMode === 'edit' ? DASHED_OUTLINE : SOLID_OUTLINE};` : ''};
border-radius: ${euiThemeVars.euiBorderRadius};

&:hover {
outline: ${viewMode === 'edit' ? DASHED_OUTLINE : SOLID_OUTLINE};
z-index: 2;
}
`}
>
{children}
{api ? (
Expand All @@ -481,81 +498,93 @@ export const PresentationPanelHoverActions = ({
'embPanel__hoverActionsLeft',
className
)}
css={css`
${borderStyles}
`}
css={{
...borderStyles,
borderStyle: viewMode === 'edit' ? 'dashed' : 'solid',
borderColor:
viewMode === 'edit'
? euiThemeVars.euiColorMediumShade
: euiThemeVars.euiBorderColor,
}}
>
{dragHandle}
</div>
) : (
<div /> // necessary for the right hover actions to align correctly when left hover actions are not present
)}
<div
ref={rightHoverActionsRef}
data-test-subj="embPanel__hoverActions__right"
className={classNames(
'embPanel__hoverActions',
'embPanel__hoverActionsRight',
className
)}
css={css`
${borderStyles}
`}
>
{viewMode === 'edit' && combineHoverActions && dragHandle}
{showNotifications && notificationElements}
{showDescription && (
<EuiIconTip
title={!hideTitle ? title || undefined : undefined}
content={description}
delay="regular"
position="top"
anchorClassName="embPanel__descriptionTooltipAnchor"
data-test-subj="embeddablePanelDescriptionTooltip"
type="iInCircle"
/>
)}
{quickActionElements.map(
({ iconType, 'data-test-subj': dataTestSubj, onClick, name }, i) => (
<EuiToolTip key={`main_action_${dataTestSubj}_${api?.uuid}`} content={name}>
<EuiButtonIcon
iconType={iconType}
color="text"
onClick={onClick as MouseEventHandler}
data-test-subj={dataTestSubj}
aria-label={name as string}
/>
</EuiToolTip>
)
)}
{contextMenuPanels.length ? (
<EuiPopover
repositionOnScroll
panelPaddingSize="none"
anchorPosition="downRight"
button={ContextMenuButton}
isOpen={isContextMenuOpen}
className={contextMenuClasses}
closePopover={onClose}
data-test-subj={
isContextMenuOpen
? 'embeddablePanelContextMenuOpen'
: 'embeddablePanelContextMenuClosed'
}
focusTrapProps={{
closeOnMouseup: true,
clickOutsideDisables: false,
onClickOutside: onClose,
}}
>
<EuiContextMenu
data-test-subj="presentationPanelContextMenuItems"
initialPanelId={'mainMenu'}
panels={contextMenuPanels}
{quickActionElements.length && contextMenuPanels.lastIndexOf.length ? (
<div
ref={rightHoverActionsRef}
data-test-subj="embPanel__hoverActions__right"
className={classNames(
'embPanel__hoverActions',
'embPanel__hoverActionsRight',
className
)}
css={{
...borderStyles,
borderStyle: viewMode === 'edit' ? 'dashed' : 'solid',
borderColor:
viewMode === 'edit'
? euiThemeVars.euiColorMediumShade
: euiThemeVars.euiBorderColor,
}}
>
{viewMode === 'edit' && combineHoverActions && dragHandle}
{showNotifications && notificationElements}
{showDescription && (
<EuiIconTip
title={!hideTitle ? title || undefined : undefined}
content={description}
delay="regular"
position="top"
anchorClassName="embPanel__descriptionTooltipAnchor"
data-test-subj="embeddablePanelDescriptionTooltip"
type="iInCircle"
/>
</EuiPopover>
) : null}
</div>
)}
{quickActionElements.map(
({ iconType, 'data-test-subj': dataTestSubj, onClick, name }, i) => (
<EuiToolTip key={`main_action_${dataTestSubj}_${api?.uuid}`} content={name}>
<EuiButtonIcon
iconType={iconType}
color="text"
onClick={onClick as MouseEventHandler}
data-test-subj={dataTestSubj}
aria-label={name as string}
/>
</EuiToolTip>
)
)}
{contextMenuPanels.length ? (
<EuiPopover
repositionOnScroll
panelPaddingSize="none"
anchorPosition="downRight"
button={ContextMenuButton}
isOpen={isContextMenuOpen}
className={contextMenuClasses}
closePopover={onClose}
data-test-subj={
isContextMenuOpen
? 'embeddablePanelContextMenuOpen'
: 'embeddablePanelContextMenuClosed'
}
focusTrapProps={{
closeOnMouseup: true,
clickOutsideDisables: false,
onClickOutside: onClose,
}}
>
<EuiContextMenu
data-test-subj="presentationPanelContextMenuItems"
initialPanelId={'mainMenu'}
panels={contextMenuPanels}
/>
</EuiPopover>
) : null}
</div>
) : null}
</div>
) : null}
</div>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,8 @@ import { PanelLoader } from '@kbn/panel-loader';
import { isPromise } from '@kbn/std';
import React from 'react';
import useAsync from 'react-use/lib/useAsync';
import { css } from '@emotion/react';
import { euiThemeVars } from '@kbn/ui-theme';
import { untilPluginStartServicesReady } from '../kibana_services';
import { PresentationPanelError } from './presentation_panel_error';
import { DefaultPresentationPanelApi, PresentationPanelProps } from './types';
Expand Down Expand Up @@ -55,7 +57,11 @@ export const PresentationPanel = <
<PanelLoader
showShadow={props.showShadow}
showBorder={props.showBorder}
dataTestSubj="embeddablePanelLoadingIndicator"
css={css`
border-radius: ${euiThemeVars.euiBorderRadius};
`}
dataTestSubj="embed
dablePanelLoadingIndicator"
/>
);

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -92,7 +92,7 @@ export const PresentationPanelInternal = <

return (
<PresentationPanelHoverActions
{...{ index, api, getActions, actionPredicate, viewMode, showNotifications }}
{...{ index, api, getActions, actionPredicate, viewMode, showNotifications, showBorder }}
>
<EuiPanel
role="figure"
Expand All @@ -101,7 +101,6 @@ export const PresentationPanelInternal = <
'embPanel--editing': viewMode === 'edit',
})}
hasShadow={showShadow}
hasBorder={showBorder}
aria-labelledby={headerId}
data-test-subj="embeddablePanel"
{...contentAttrs}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -288,8 +288,5 @@ const Wrapper = styled.div<{
right: 50%;
transform: translate(50%, -50%);
}
.embPanel {
outline: none;
}
}
`;
Original file line number Diff line number Diff line change
Expand Up @@ -43,19 +43,6 @@ const LensComponentWrapper = styled.div<{
height: ${({ $height }) => ($height ? `${$height}px` : 'auto')};
width: ${({ width }) => width ?? 'auto'};

.embPanel {
outline: none;
}

.embPanel__hoverActions.embPanel__hoverActionsRight {
border-radius: 6px !important;
border-bottom: 1px solid #d3dae6 !important;
}

.embPanel__hoverActionsAnchor .embPanel__hoverActionsWrapper {
top: -20px;
}

.expExpressionRenderer__expression {
padding: 2px 0 0 0 !important;
}
Expand Down
Loading