-
Notifications
You must be signed in to change notification settings - Fork 8.3k
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
Add advanced setting to control quick ranges #15975
Changes from 1 commit
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -277,6 +277,37 @@ export function getUiSettingDefaults() { | |
}`, | ||
description: 'The timefilter\'s default refresh interval' | ||
}, | ||
'timepicker:quickRanges': { | ||
type: 'json', | ||
value: JSON.stringify([ | ||
{ from: 'now/d', to: 'now/d', display: 'Today', section: 0 }, | ||
{ from: 'now/w', to: 'now/w', display: 'This week', section: 0 }, | ||
{ from: 'now/M', to: 'now/M', display: 'This month', section: 0 }, | ||
{ from: 'now/y', to: 'now/y', display: 'This year', section: 0 }, | ||
{ from: 'now/d', to: 'now', display: 'Today so far', section: 0 }, | ||
{ from: 'now/w', to: 'now', display: 'Week to date', section: 0 }, | ||
{ from: 'now/M', to: 'now', display: 'Month to date', section: 0 }, | ||
{ from: 'now/y', to: 'now', display: 'Year to date', section: 0 }, | ||
|
||
{ from: 'now-15m', to: 'now', display: 'Last 15 minutes', section: 1 }, | ||
{ from: 'now-30m', to: 'now', display: 'Last 30 minutes', section: 1 }, | ||
{ from: 'now-1h', to: 'now', display: 'Last 1 hour', section: 1 }, | ||
{ from: 'now-4h', to: 'now', display: 'Last 4 hours', section: 1 }, | ||
{ from: 'now-12h', to: 'now', display: 'Last 12 hours', section: 1 }, | ||
{ from: 'now-24h', to: 'now', display: 'Last 24 hours', section: 1 }, | ||
{ from: 'now-7d', to: 'now', display: 'Last 7 days', section: 1 }, | ||
|
||
{ from: 'now-30d', to: 'now', display: 'Last 30 days', section: 2 }, | ||
{ from: 'now-60d', to: 'now', display: 'Last 60 days', section: 2 }, | ||
{ from: 'now-90d', to: 'now', display: 'Last 90 days', section: 2 }, | ||
{ from: 'now-6M', to: 'now', display: 'Last 6 months', section: 2 }, | ||
{ from: 'now-1y', to: 'now', display: 'Last 1 year', section: 2 }, | ||
{ from: 'now-2y', to: 'now', display: 'Last 2 years', section: 2 }, | ||
{ from: 'now-5y', to: 'now', display: 'Last 5 years', section: 2 }, | ||
|
||
], null, 2), | ||
description: 'The list of ranges to show in the Quick section of the time picker.' | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Is there any documentation that you could link too? It would be helpful to know what proper values can be used. |
||
}, | ||
'dashboard:defaultDarkTheme': { | ||
value: false, | ||
description: 'New dashboards use dark theme by default' | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,20 +1,20 @@ | ||
import _ from 'lodash'; | ||
import dateMath from '@elastic/datemath'; | ||
import moment from 'moment'; | ||
import 'ui/timepicker/quick_ranges'; | ||
import 'ui/timepicker/time_units'; | ||
import { uiModules } from 'ui/modules'; | ||
const module = uiModules.get('kibana'); | ||
|
||
|
||
module.directive('prettyDuration', function (config, quickRanges, timeUnits) { | ||
module.directive('prettyDuration', function (config, timeUnits) { | ||
return { | ||
restrict: 'E', | ||
scope: { | ||
from: '=', | ||
to: '=' | ||
}, | ||
link: function ($scope, $elem) { | ||
const quickRanges = config.get('timepicker:quickRanges'); | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Do we need a check here to make sure users don't add a crazy number of sections? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Meh, we could, but I don't envision that being a super common problem and it's easily fixed. |
||
const dateFormat = config.get('dateFormat'); | ||
|
||
const lookupByRange = {}; | ||
|
This file was deleted.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Is there a way to add a
verify
method to ensure the time ranges are valid? It would be better to get an error message and not update the quickRanges on the advanced setting page, then to let users save invalid time ranges and get a cryptic error when selecting the invalid range via the timepicker.There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I don't think there's any sort of verification currently (beyond verifying that the value actually is JSON). I could probably add a custom directive and handling for this but it might add more complexity than it's worth... Plus, there are other JSON values in the advanced settings that we don't have any sort of verification either. What if I just added some notes to the docs about how to configure the value and linked to it in the description?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
sounds good
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@nreese 1eb0eee