Skip to content

Instantly share code, notes, and snippets.

@andyed
Created December 16, 2009 02:30
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 andyed/257534 to your computer and use it in GitHub Desktop.
Save andyed/257534 to your computer and use it in GitHub Desktop.
/*
@author: Andy Edmonds
@url: http://www.uxagile.com
@update: http://uxagile.com/kiosk-tab-rotator-jetpack-for-firefox/
@title: Jetpack Kiosk Tab Rotator
@description: For you information radiator screens
@license: MPL
*/
// TODO
// Auto cancel when user interacts with page
// Provide ability to set delay
// Update state upon pause/resume in jetpack bar
// Latest developments at http://gist.github.com/169784
// Stable version http://gist.github.com/gists/257534
var tabDelaySeconds = 40;
var interval= false;
var curTab= 0;
var widgetHandle = false;
jetpack.statusBar.append({
html: "<span id='cycleStats'><img id='tabRotateLogo' src='' width='16' height='16' vspace='2'></span>",
width: 16,
onReady: function(widget){
widgetHandle = widget;
$(widget).click(function(){
cycleInit();
});
},
});
function cycleInit() {
if(!interval) {
jetpack.notifications.show( "Rotating tab to:" + this.curTab );
interval = setInterval( cycle, 1000*tabDelaySeconds );
//$("#cycleStatus", widgetHandle).html("CYCLING")
var doc = jetpack.tabs.focused.contentDocument;
//doc.addEventListener("mousemove", cancelCycle)
} else {
jetpack.notifications.show( "Ending Tab Rotation");
interval = clearInterval(interval);
//console.log($(widgetHandle));
}
}
function cycle(){
var doc = jetpack.tabs.focused.contentDocument;
//doc.removeEventListener("mousemove", cancelCycle)
if(this.curTab<jetpack.tabs.length ) {
this.curTab++;
} else {
this.curTab = 0;
}
jetpack.notifications.show( "Rotating tab to:" + this.curTab );
jetpack.tabs[curTab].focus();
};
function cancelCycle () {
interval = clearInterval(interval);
var doc = jetpack.tabs.focused.contentDocument;
//doc.removeEventListener("mousemove", cancelCycle)
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment