Skip to content

Commit

Permalink
[Observability] fix slo observability compressed styles to be not com…
Browse files Browse the repository at this point in the history
…pressed (#193081)

## Summary

Building off of PR #192993 to
revert the compressed styles for SLOs

Compressed styles PR
[here](#190636)


### Before
In the SLO page in Observability, the status and tags fields are uneven
with the unified search bar.
![Screenshot 2024-09-30 at 2 10
17 PM](https://github.com/user-attachments/assets/63391aa2-ec7d-43f5-9803-8094e73b8a6c)

### After
![Screenshot 2024-09-30 at 2 52
37 PM](https://github.com/user-attachments/assets/fb70109d-15d1-4278-81c6-318da290594f)
  • Loading branch information
rshen91 authored Oct 1, 2024
1 parent 58e6233 commit 7a9a519
Show file tree
Hide file tree
Showing 12 changed files with 78 additions and 7 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -34,6 +34,7 @@ import { ControlPanelProps, DefaultControlApi } from '../../controls/types';
import { ControlError } from './control_error';

import './control_panel.scss';
import { isCompressed } from '../utils/is_compressed';

const DragHandle = ({
isEditable,
Expand Down Expand Up @@ -122,7 +123,6 @@ export const ControlPanel = <ApiType extends DefaultControlApi = DefaultControlA
const isEditable = viewMode === ViewMode.EDIT;
const controlWidth = width ?? DEFAULT_CONTROL_WIDTH;
const controlGrow = grow ?? DEFAULT_CONTROL_GROW;

return (
<EuiFlexItem
ref={setNodeRef}
Expand Down Expand Up @@ -154,12 +154,10 @@ export const ControlPanel = <ApiType extends DefaultControlApi = DefaultControlA
data-test-subj="control-frame-title"
fullWidth
label={usingTwoLineLayout ? panelTitle || defaultPanelTitle || '...' : undefined}
display="rowCompressed"
>
<EuiFormControlLayout
fullWidth
isLoading={Boolean(dataLoading)}
compressed
className={classNames(
'controlFrame__formControlLayout',
{
Expand Down Expand Up @@ -191,6 +189,7 @@ export const ControlPanel = <ApiType extends DefaultControlApi = DefaultControlA
)}
</>
}
compressed={isCompressed(api)}
>
<>
{blockingError && (
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -40,6 +40,7 @@ export interface ControlGroupRendererProps {
timeRange?: TimeRange;
query?: Query;
dataLoading?: boolean;
compressed?: boolean;
}

export const ControlGroupRenderer = ({
Expand All @@ -50,6 +51,7 @@ export const ControlGroupRenderer = ({
query,
viewMode,
dataLoading,
compressed,
}: ControlGroupRendererProps) => {
const id = useMemo(() => uuidv4(), []);
const [regenerateId, setRegenerateId] = useState(uuidv4());
Expand Down Expand Up @@ -171,6 +173,7 @@ export const ControlGroupRenderer = ({
getRuntimeStateForChild: () => {
return runtimeState$.getValue();
},
compressed: compressed ?? true,
})}
onApiAvailable={(controlGroupApi) => {
const controlGroupRendererApi: ControlGroupRendererApi = {
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,33 @@
/*
* Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
* or more contributor license agreements. Licensed under the "Elastic License
* 2.0", the "GNU Affero General Public License v3.0 only", and the "Server Side
* Public License v 1"; you may not use this file except in compliance with, at
* your election, the "Elastic License 2.0", the "GNU Affero General Public
* License v3.0 only", or the "Server Side Public License, v 1".
*/

import { isCompressed } from './is_compressed';

describe('isCompressed', () => {
test('should return true by default', () => {
const mockApi = {};
expect(isCompressed(mockApi)).toBe(true);
});
test('should return false if compressed is false', () => {
const mockApi = { compressed: false };
expect(isCompressed(mockApi)).toBe(false);
});
test('should return false if parent api has compressed false', () => {
const mockApi = { parentApi: { compressed: false } };
expect(isCompressed(mockApi)).toBe(false);
});
test('should return false if nested api has compressed false', () => {
const mockApi = { parentApi: { parentApi: { parentApi: { compressed: false } } } };
expect(isCompressed(mockApi)).toBe(false);
});
test('should return true if parent api does not specify compressed', () => {
const mockApi = { parentApi: { parentApi: {} } };
expect(isCompressed(mockApi)).toBe(true);
});
});
23 changes: 23 additions & 0 deletions src/plugins/controls/public/control_group/utils/is_compressed.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
/*
* Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
* or more contributor license agreements. Licensed under the "Elastic License
* 2.0", the "GNU Affero General Public License v3.0 only", and the "Server Side
* Public License v 1"; you may not use this file except in compliance with, at
* your election, the "Elastic License 2.0", the "GNU Affero General Public
* License v3.0 only", or the "Server Side Public License, v 1".
*/

import { apiHasParentApi } from '@kbn/presentation-publishing';

interface HasCompressed {
compressed: boolean;
}

const apiHasCompressed = (unknownApi: unknown): unknownApi is HasCompressed => {
return Boolean(unknownApi) && typeof (unknownApi as HasCompressed).compressed === 'boolean';
};

export function isCompressed(api: unknown): boolean {
if (apiHasCompressed(api)) return api.compressed;
return apiHasParentApi(api) ? isCompressed(api.parentApi) : true;
}
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,7 @@ import {
useBatchedPublishingSubjects,
} from '@kbn/presentation-publishing';

import { isCompressed } from '../../../../control_group/utils/is_compressed';
import { OptionsListSelection } from '../../../../../common/options_list/options_list_selections';
import { MIN_POPOVER_WIDTH } from '../../../constants';
import { useOptionsListContext } from '../options_list_context_provider';
Expand Down Expand Up @@ -174,7 +175,7 @@ export const OptionsListControl = ({
);

return (
<EuiFilterGroup fullWidth compressed className={controlPanelClassName}>
<EuiFilterGroup fullWidth compressed={isCompressed(api)} className={controlPanelClassName}>
<EuiInputPopover
id={popoverId}
ownFocus
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,7 @@ interface Props {
value: RangeValue | undefined;
uuid: string;
controlPanelClassName?: string;
compressed: boolean;
}

export const RangeSliderControl: FC<Props> = ({
Expand All @@ -46,6 +47,7 @@ export const RangeSliderControl: FC<Props> = ({
value,
uuid,
controlPanelClassName,
compressed,
}: Props) => {
const rangeSliderRef = useRef<EuiDualRangeProps | null>(null);

Expand Down Expand Up @@ -194,7 +196,7 @@ export const RangeSliderControl: FC<Props> = ({
min={displayedMin}
max={displayedMax}
isLoading={isLoading}
compressed
compressed={compressed}
inputPopoverProps={{
className: controlPanelClassName,
panelMinWidth: MIN_POPOVER_WIDTH,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@ import { EuiFieldNumber, EuiFormRow } from '@elastic/eui';
import { Filter, RangeFilterParams, buildRangeFilter } from '@kbn/es-query';
import { useBatchedPublishingSubjects } from '@kbn/presentation-publishing';

import { isCompressed } from '../../../control_group/utils/is_compressed';
import { RANGE_SLIDER_CONTROL } from '../../../../common';
import { initializeDataControl } from '../initialize_data_control';
import type { DataControlFactory } from '../types';
Expand Down Expand Up @@ -248,6 +249,7 @@ export const getRangesliderControlFactory = (): DataControlFactory<
step={step ?? 1}
value={value}
uuid={uuid}
compressed={isCompressed(api)}
/>
);
},
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@ interface Props {
ticks: EuiRangeTick[];
timeRangeMin: number;
timeRangeMax: number;
compressed: boolean;
}

export function TimeSliderAnchoredRange(props: Props) {
Expand All @@ -40,7 +41,7 @@ export function TimeSliderAnchoredRange(props: Props) {
max={props.timeRangeMax}
step={props.stepSize}
ticks={props.ticks}
compressed
compressed={props.compressed}
/>
);
}
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,7 @@ interface Props {
ticks: EuiRangeTick[];
timeRangeMin: number;
timeRangeMax: number;
compressed: boolean;
}

export function TimeSliderPopoverContent(props: Props) {
Expand All @@ -35,6 +36,7 @@ export function TimeSliderPopoverContent(props: Props) {
ticks={props.ticks}
timeRangeMin={props.timeRangeMin}
timeRangeMax={props.timeRangeMax}
compressed={props.compressed}
/>
) : (
<TimeSliderSlidingWindowRange
Expand All @@ -44,6 +46,7 @@ export function TimeSliderPopoverContent(props: Props) {
ticks={props.ticks}
timeRangeMin={props.timeRangeMin}
timeRangeMax={props.timeRangeMax}
compressed={props.compressed}
/>
);
const anchorStartToggleButtonLabel = props.isAnchored
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@ interface Props {
ticks: EuiRangeTick[];
timeRangeMin: number;
timeRangeMax: number;
compressed: boolean;
}

export function TimeSliderSlidingWindowRange(props: Props) {
Expand All @@ -36,7 +37,7 @@ export function TimeSliderSlidingWindowRange(props: Props) {
step={props.stepSize}
ticks={props.ticks}
isDraggable
compressed
compressed={props.compressed}
/>
);
}
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,7 @@ import {
roundUpToNextStepSizeFactor,
} from './time_utils';
import { Timeslice, TimesliderControlApi, TimesliderControlState } from './types';
import { isCompressed } from '../../control_group/utils/is_compressed';

const displayName = i18n.translate('controls.timesliderControl.displayName', {
defaultMessage: 'Time slider',
Expand Down Expand Up @@ -306,6 +307,7 @@ export const getTimesliderControlFactory = (): ControlFactory<
ticks={timeRangeMeta.ticks}
timeRangeMin={timeRangeMeta.timeRangeMin}
timeRangeMax={timeRangeMeta.timeRangeMax}
compressed={isCompressed(api)}
/>
</EuiInputPopover>
);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -92,6 +92,7 @@ export function QuickFilters({
};
}}
timeRange={{ from: 'now-24h', to: 'now' }}
compressed={false}
/>
</Container>
);
Expand Down

0 comments on commit 7a9a519

Please sign in to comment.