From d04ea02a3a9892dcd08837117783cc60a4332cca Mon Sep 17 00:00:00 2001 From: ricoberger Date: Thu, 11 Nov 2021 19:43:35 +0100 Subject: [PATCH] [core] Add tooltip to refresh button The refresh button of the Options component now contains a tooltip, which shows the selected time range. --- CHANGELOG.md | 1 + plugins/core/src/components/misc/Options.tsx | 23 +++++++++++++++++--- 2 files changed, 21 insertions(+), 3 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index da59fffb2..b182a1275 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -18,6 +18,7 @@ NOTE: As semantic versioning states all 0.y.z releases can contain breaking chan - [#192](https://github.com/kobsio/kobs/pull/192): [clickhouse] Add options to download aggregation results as `.csv` file. - [#193](https://github.com/kobsio/kobs/pull/193): [elasticsearch] Adjust selected time range via logs chart and allow filtering via fields. - [#201](https://github.com/kobsio/kobs/pull/201): [sonarqube] Add SonarQube plugin to view projects and their measures within kobs. +- [#202](https://github.com/kobsio/kobs/pull/202): [core] Add tooltip to refresh button to show selected time interval. ### Fixed diff --git a/plugins/core/src/components/misc/Options.tsx b/plugins/core/src/components/misc/Options.tsx index df9be4134..9080b74a8 100644 --- a/plugins/core/src/components/misc/Options.tsx +++ b/plugins/core/src/components/misc/Options.tsx @@ -12,6 +12,8 @@ import { SimpleList, SimpleListItem, TextInput, + Tooltip, + TooltipPosition, } from '@patternfly/react-core'; import React, { useEffect, useState } from 'react'; import { RedoIcon } from '@patternfly/react-icons'; @@ -186,6 +188,19 @@ export const Options: React.FunctionComponent = ({ ); }; + const refreshTimesTooltip = (): React.ReactNode => { + const timeDiff = timeEnd - timeStart; + const time = Object.keys(times) + .map((key) => times[key]) + .filter((time) => time.seconds === timeDiff); + + if (time.length === 1) { + return
{time[0].label}
; + } + + return
Custom
; + }; + // useEffect is used to update the UI, every time a property changes. useEffect(() => { setInternalAdditionalFields(additionalFields); @@ -199,9 +214,11 @@ export const Options: React.FunctionComponent = ({ {formatTime(timeStart)} to {formatTime(timeEnd)} - + + +