Dashboards & Visualizations

Timerangeview dialogOption and presets

rbariatti
Loves-to-Learn Lots

Hello Folks,

I've tried to implement a custom timerange picker with JS but encounter some unconsitent behaviour...
Indeed I have tried both to render the input with js and get the instance in js and modify the settings.
In the first case, i achieved to modify the presets values, but dialogOptions settings is not taken into account.
In the second case, i can't either change dialogOptions and presets settings.
See bellow sample of code:

dashboard.xml

 

...
  <fieldset submitButton="true" autoRun="false">
    <html>
      <div id="mytimerangeview_custom"/>
    </html>
    <input id="in_timerangepicker" type="time" token="field1">
      <label></label>
      <default>
        <earliest>-24h@h</earliest>
        <latest>now</latest>
      </default>
    </input>
    <input type="dropdown" token="tkn_scope">
      <label>Scope</label>
      <fieldForLabel>key_text</fieldForLabel>
      <fieldForValue>key_value</fieldForValue>
      <search>
        <query>| savedsearch "Super saved search"</query>
        <earliest>-15m</earliest>
        <latest>now</latest>
      </search>
    </input>
  </fieldset>
...

 

 

 and script.js

 

 

require([
	'underscore',
	'jquery',
	'splunkjs/mvc',
	'splunkjs/mvc/timerangeview',
	'splunkjs/mvc/simplexml/ready!'
],
function (
	_,
	$,
	mvc,
	TimeRangeView
	
) {
	console.log("JS LOADED");
	
	// Get timerangeview object
	var timerangepicker_input = mvc.Components.get('in_timerangepicker');
	console.log(timerangepicker_input);
	
	// Show the Presets panel, hide the Real-time and Advanced panels
	var mypresetsettings = {
		showPresets: true,
		showCustomRealTime: false,
		showCustomAdvanced: false,
	};

	// Define custom preset values
	var mypresetvalues = [
		{label: 'Last 13 minutes', earliest_time: '-13m', latest_time: 'now'},
		{label: 'Last 42 minutes', earliest_time: '-42m', latest_time: 'now'}
	];

	// Instantiate a view using the custom time range picker
	//timerangepicker_input.settings.set('dialogOptions', mypresetsettings);
	timerangepicker_input.settings.set('presets', mypresetvalues);

	
	// Create a custom time range picker
    

    // Instantiate a view using the custom time range picker
    var mytimerange_custom = new TimeRangeView({
        id: "mytimerangeview_custom",
        managerid: "example-search",
        presets: mypresetvalues,
        dialogOptions: mypresetsettings,
        el: $("#mytimerangeview_custom")
    }).render();
	
});

 

 

mytimerangeview_custom looks like:

rbariatti_1-1596206603314.png

 

and in_timerangepicker looks like:

rbariatti_2-1596206661669.png

 

This goes without saying that I have tried all the possible combination for the dialogOptions dict.
Playing with the stylesheet.css allows me to hide the input section but i would rather go with the correct approach and more specificaly the one that just get the instance and modify the settings (allowing me to keep native splunk displaying).

Thank you all for your help 🙂

R.

Labels (5)
0 Karma
Get Updates on the Splunk Community!

Preparing your Splunk Environment for OpenSSL3

The Splunk platform will transition to OpenSSL version 3 in a future release. Actions are required to prepare ...

Deprecation of Splunk Observability Kubernetes “Classic Navigator” UI starting ...

Access to Splunk Observability Kubernetes “Classic Navigator” UI will no longer be available starting January ...

Now Available: Cisco Talos Threat Intelligence Integrations for Splunk Security Cloud ...

At .conf24, we shared that we were in the process of integrating Cisco Talos threat intelligence into Splunk ...