Last active
August 29, 2015 14:20
-
-
Save hobbes3/de4c19c5e3c4c584ab36 to your computer and use it in GitHub Desktop.
show tokens
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
.show-tokens { | |
background: white; | |
border-top: 1px solid #ccc; | |
} | |
.show-tokens h3 { | |
padding-left: 20px; | |
} | |
.show-tokens .token-name, .show-tokens .token-value { | |
font-family: monospace; | |
} | |
.show-tokens .token-name { | |
color: #d85d3c; | |
} | |
.show-tokens .token-value { | |
color: #333; | |
} | |
.show-tokens .token-value.undefined { | |
color: #999; | |
} | |
.show-tokens .form-switch { | |
float: right; | |
padding-right: 20px; | |
padding-top: 6px; | |
} |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
require(['splunkjs/mvc/simplexml/ready!', 'css!../app/<app_name>/showtokens.css'], function() { | |
var _ = require('underscore'); | |
var $ = require('jquery'); | |
var Backbone = require('backbone'); | |
var mvc = require('splunkjs/mvc'); | |
var defaultTokenModel = mvc.Components.get('default'); | |
var submittedTokenModel = mvc.Components.get('submitted'); | |
var urlTokenModel = mvc.Components.get('url'); | |
var models = [defaultTokenModel, submittedTokenModel, urlTokenModel]; | |
var TokenDebugView = Backbone.View.extend({ | |
className: 'show-tokens', | |
initialize: function() { | |
this.model = new Backbone.Model({ includeFormTokens: false }); | |
if ('localStorage' in window && window.localStorage) { | |
try { | |
var STORAGE_KEY = 'splunk-show-tokens'; | |
var localSettings = window.localStorage.getItem(STORAGE_KEY); | |
if (localSettings) { | |
this.model.set(JSON.parse(localSettings)); | |
} | |
this.model.on('change', function(model) { | |
try { | |
window.localStorage.setItem(STORAGE_KEY, JSON.stringify(model.toJSON())); | |
} catch (e) { | |
} | |
}); | |
} catch (e) { | |
} | |
} | |
this.listenTo(this.model, 'change', this.render); | |
this.listenTo(defaultTokenModel, 'change', this.render); | |
this.listenTo(submittedTokenModel, 'change', this.render); | |
this.listenTo(urlTokenModel, 'change', this.render); | |
}, | |
events: { | |
'click .checkbox a': function(e) { | |
e.preventDefault(); | |
this.model.set('includeFormTokens', !this.model.get('includeFormTokens')); | |
} | |
}, | |
render: function() { | |
this.$el.addClass('show-tokens'); | |
if (this.$el.is(':empty')) { | |
this.$el.html(this.template); | |
} | |
var includeFormTokens = this.model.get('includeFormTokens'); | |
this.$('.checkbox>a>i')[includeFormTokens ? 'show' : 'hide'](); | |
var tbody = this.$('tbody'); | |
tbody.empty(); | |
var keys = _.union.apply(_, _(models).invoke('keys')); | |
if (!includeFormTokens) { | |
keys = _(keys).filter(function(k) { return k.indexOf('form.') !== 0; }); | |
} | |
keys.sort(); | |
_(keys).each(function(token) { | |
var tr = $('<tr></tr>'); | |
$('<td class="token-name"></td>').text('$' + token + '$').appendTo(tr); | |
_(models).each(function(ns) { | |
var td = $('<td class="token-value"></td>').appendTo(tr); | |
var val = ns.get(token); | |
if (val === undefined) { | |
td.addClass('undefined').text('undefined'); | |
} else { | |
if (_.isString(val)) { | |
td.text(val); | |
} else { | |
$('<code title="Non-string value"></code>').text(JSON.stringify(val)).appendTo(td); | |
} | |
} | |
}); | |
tr.appendTo(tbody); | |
}); | |
return this; | |
}, | |
template: '<div class="form-switch">' + | |
'<label class="checkbox">' + | |
'<a href="#" class="btn"><i class="icon-check" style="display:none"></i></a>' + | |
' Show <code>form.</code> tokens' + | |
'</label>' + | |
'</div>' + | |
'<h3>Token Debug Info</h3>' + | |
'<table class="table table-striped table-chrome table-hover">' + | |
'<thead>' + | |
'<tr>' + | |
' <th>Token</th>' + | |
' <th>Default</th>' + | |
' <th>Submitted</th>' + | |
' <th>URL</th>' + | |
'</tr>' + | |
'</thead>' + | |
'<tbody></tbody>' + | |
'</table>' | |
}); | |
var ct = $('#show-tokens'); | |
if (!ct.length) { | |
ct = $('<div id="show-tokens"></div>').insertBefore($('.dashboard-body')); | |
} | |
window.tokenDebug = new TokenDebugView({ el: ct }).render(); | |
}); |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment