Skip to content

Instantly share code, notes, and snippets.

@jamesspittal
Forked from ConversionSciences/vwo_info.js
Created March 6, 2019 05:25
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save jamesspittal/292f91d38804479faa69c3a1574730fc to your computer and use it in GitHub Desktop.
Save jamesspittal/292f91d38804479faa69c3a1574730fc to your computer and use it in GitHub Desktop.
// ==UserScript==
// @name CS VWO Info
// @version 1.1
// @description Show info on running VWO experiments
// @author Conversion Sciences
// @include /^https?:\/\/.*/
// @grant none
// @noframes
// @downloadURL https://d2t92d45b68dnb.cloudfront.net/TM/VWO.js
// ==/UserScript==
(function() {
window['cs_getVWOgoals'] = function(exp) {
var goals = document.cookie.match(new RegExp('_vis_opt_exp_' + exp + '_goal_[0-9]*=1(;|$)', 'g'));
var goals_out = [];
if (goals !== null)
goals.forEach(function(val, ind) {
goals_out.push(val.match(/_goal_([0-9]*\d)=1;/)[1]);
});
return goals_out;
};
window.cs_toggle_vwo_vis = function() {
var el = document.getElementById('cs_vwo_div');
if (!el)
return;
if (el.className.indexOf('cs_vis') > -1)
el.className = el.className.replace(' cs_vis', '');
else
el.className = el.className + ' cs_vis';
};
window['cs_checkVWO'] = function(show_cs_vwo, hide_log) {
this.log = function(s) { if(hide_log) return; console.log(s); }
var $ = $;
if (typeof _vwo_code == 'undefined' && typeof window._vwo_acc_id == 'undefined') return ('VWO Code not defined');
else this.log('VWO Code found');
//if (!_vwo_code.libExecuted) console.log('VWO Library not excecuted');
if (typeof vwo_$ == 'undefined') {
this.log('VWO Library not loaded');
$ = jQuery;
} else $ = vwo_$;
var account_id = ($('script:contains("_vwo_code")').length > 0) ? $('script:contains("_vwo_code")').first().html().match(/account_id?([ ]*)=?([ ]*)([0-9]*\d)/)[3] : (typeof _vwo_acc_id != 'undefined' ? _vwo_acc_id : 'Not Found');
this.log('--------VWO Info------------ \nVWO account id: ' + account_id + '\n'+ 'vwo_$ jQuery Version: ' + ((typeof vwo_$ != 'undefined') ? vwo_$.fn.jquery : 'Not defined.') + '\n' + '$ jQuery Version: ' + ((typeof $ != 'undefined' && typeof $.fn != 'undefined') ? $.fn.jquery : 'Not defined') + '\n' + 'jQuery Version: ' + ((typeof jQuery != 'undefined') ? jQuery.fn.jquery : 'Not defined.'));
if (typeof _vwo_exp != 'undefined') {
var expIn = '';
var expOut = '';
var inCount = 0;
var outCount = 0;
var expInHTML = '';
var expOutHTML = '';
Object.keys(_vwo_exp).forEach(function(key, ind) {
var exp = 'Exp ' + key + ((typeof _vwo_exp[key].combination_chosen != 'undefined') ? ' : ' + _vwo_exp[key].combination_chosen : '') + ' | "' + _vwo_exp[key].name + '"';
if (typeof _vwo_exp[key].combination_chosen != 'undefined') {
expIn = expIn + exp + ((cs_getVWOgoals(key).length > 0) ? (' | Goals: ' + cs_getVWOgoals(key).join(', ')) : '') + '\n';
expInHTML = expInHTML + '<div class="cs_vwo_exp cs_in"><span class="cs_exp_name">' + _vwo_exp[key].name + '</span> <span class="cs_exp_id">(Exp: ' + key + ')</span><div class="cs_exp_var">Variation: ' + _vwo_exp[key].combination_chosen + '</div><div class="cs_exp_goals">' + ((cs_getVWOgoals(key).length > 0) ? ('Goals: ' + cs_getVWOgoals(key).join(', ')) : '') + '</div></div>';
inCount++;
} else {
expOut = expOut + exp + ((cs_getVWOgoals(key).length > 0) ? (' | Goals: ' + cs_getVWOgoals(key).join(', ')) : '') + '\n';
expOutHTML = expOutHTML + '<div class="cs_vwo_exp cs_out"><span class="cs_exp_name">' + _vwo_exp[key].name + '</span> <span class="cs_exp_id">(Exp: ' + key + ')</span><div class="cs_exp_goals">' + ((cs_getVWOgoals(key).length > 0) ? ('Goals: ' + cs_getVWOgoals(key).join(', ')) : '') + '</div></div>';
outCount++;
}
});
expOut = ((expOut.length > 0) ? '----Excluded From---------- \n' + expOut : '');
this.log('--------VWO ExpID : Var | Exp Name | Goal IDs--------- \n' + expIn + expOut);
if (show_cs_vwo) {
var o_class = (document.getElementById('cs_vwo_div') ? document.getElementById('cs_vwo_div').className : '');
var cs_vwo_div = document.getElementById('cs_vwo_div') || document.createElement('div');
cs_vwo_div.id = 'cs_vwo_div';
cs_vwo_div.innerHTML = '<style>#cs_vwo_div.cs_hidden { display: none; } .cs_vert_middle { vertical-align: middle; cursor: pointer; margin-right: 15px; } #cs_vwo_close { cursor: pointer; margin-left: 15px; color: #333; }#cs_vwo_close:hover { color: red; } #cs_vwo_div * { box-sizing: border-box; } #cs_vwo_div.cs_hidden { display: none; } #cs_vwo_div { box-sizing: border-box; position: fixed; left: 10px; bottom: 0; z-index: 999999999;} #cs_vwo_button { display: inline-block; background-color: magenta; color: white; padding: 0px 10px; } .cs_vwo_button_title { cursor: pointer; padding: 6px 0px; display: inline-block; } #cs_vwo_info { display: none; border: 1px solid magenta; background-color: white; max-height: 300px; overflow: hidden; overflow-y: auto; } #cs_vwo_div.cs_vis #cs_vwo_info { display: block; } .cs_vwo_exp { background-color: white; border-bottom: 1px solid magenta; padding: 10px;} .cs_vwo_exp.cs_out { background-color: #ccc; }</style><div id="cs_vwo_button"><img class="cs_vert_middle" src="" title="Refresh Info" onclick="cs_checkVWO(true);" /><span class="cs_vwo_button_title" onclick="cs_toggle_vwo_vis();">VWO Experiments: ' + (inCount + outCount) + ' (' + inCount + ')</span> <span id="cs_vwo_close" onclick="document.getElementById(\'cs_vwo_div\').className = \'cs_hidden\';" title="Close">X</span></div><div id="cs_vwo_info">' + expInHTML + expOutHTML + '</div>';
if (!document.getElementById('cs_vwo_div'))
document.getElementsByTagName('body')[0].appendChild(cs_vwo_div);
cs_vwo_div.className = o_class;
}
} else this.log('No experiments running on this page.');
};
if (typeof window.onload == 'undefined' || document.readyState !== 'complete') //Check if running in tampermonkey or document is not ready, and wait for DOM if so.
window.addEventListener('load', function() {
cs_checkVWO(true);
window.VWO = window.VWO || [];
window.VWO.push(['onEventReceive', 'rC', function(data) { cs_checkVWO(true, true); console.log('VWO Goal Fired. '+ data[1] + ': '+data[2]); }]);
window.VWO.push(['onVariationApplied', 'rC', function(data) { cs_checkVWO(true, true); console.log('VWO Test Running. '+ data[1] + ': '+data[2]); }]);
});
else cs_checkVWO(true);
})();
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment