
(function() { // BeginSpryComponent

if (typeof Spry == "undefined" || !Spry.Widget || !Spry.Widget.TabbedPanels2)
{
	alert("SpryTabbedPanelsKeyNavigationPlugin.js requires SpryTabbedPanels2.js!");
	return;
}

var KNP = Spry.Widget.TabbedPanels2.KeyNavigationPlugin = {
	initialize: function(tb)
	{
		tb.addObserver(this);
	},

	KEY_UP:    38,
	KEY_DOWN:  40,
	KEY_LEFT:  37,
	KEY_RIGHT: 39,
	KEY_ENTER: 13,
	KEY_SPACE: 32,

	handleOnButtonKeyDown: function(e, tb, btn)
	{
		var currentIndex = tb.panelSelector.elementToIndex(btn);

		if (currentIndex != -1 )
		{
			var key = e.keyCode;
			var nextIndex = -1;
			switch(key)
			{
				case KNP.KEY_LEFT:
				case KNP.KEY_UP:
					if (currentIndex > 0)
						nextIndex = currentIndex - 1;
					else
						nextIndex = tb.panelSelector.getButtonCount() - 1;
					break;
				case KNP.KEY_RIGHT:
				case KNP.KEY_DOWN:
					if (currentIndex < tb.panelSelector.getButtonCount() - 1)
						nextIndex = currentIndex + 1;
					else
						nextIndex = 0;
					break;
				case KNP.KEY_SPACE:
				case KNP.KEY_ENTER:
					nextIndex = currentIndex;
					break;
			}

			if (nextIndex != -1)
			{
				tb.panelSelector.handleActivate(nextIndex);
				tb.panelSelector.focusButton(nextIndex);
				return Spry.Utils.cancelEvent(e);
			}
		}
	},
	onPostAttachTabBehaviors: function(tb, evt)
	{
		if (tb.enableKeyboardNavigation && tb.panelSelector) {
			for (var i=0; i<tb.panelSelector.buttons.length; i++) {
				tb.panelSelector.buttons[i].psButton.addObserver({
				 	onButtonKeyDown: function(btn, e) {
				 		KNP.handleOnButtonKeyDown(e.event, tb, e.element);
				 	}
				 });
			}
		}
	}
};

// We want to add our plugin to the default configuration for TabbedPanels2 if it is included!

Spry.Widget.TabbedPanels2.config.plugIns.push(Spry.Widget.TabbedPanels2.KeyNavigationPlugin);

})(); // EndSpryComponent


