

if (typeof(Wicket) == "undefined")
Wicket = { };
Wicket.AutoCompleteSettings =
{
enterHidesWithNoSelection : false
};
Wicket.AutoComplete=function(elementId, callbackUrl, cfg){
var KEY_TAB=9;
var KEY_ENTER=13;
var KEY_ESC=27;
var KEY_LEFT=37;
var KEY_UP=38;
var KEY_RIGHT=39;
var KEY_DOWN=40;
var KEY_SHIFT=16;
var KEY_CTRL=17;
var KEY_ALT=18;
var selected=-1;

var elementCount=0; 
var visible=0;

var mouseactive=0;		var	hidingAutocomplete=0;


var objonkeydown;
var objonblur;
var objonkeyup;
var objonkeypress;
var objonchange;
var objonchangeoriginal;
		var initialDelta = -1;
		var localThrottler = new Wicket.Throttler(true);
var throttleDelay = 300;
function initialize(){




var choiceDiv=document.getElementById(getMenuId());
if (choiceDiv != null) {
choiceDiv.parentNode.parentNode.removeChild(choiceDiv.parentNode);
}
var obj=wicketGet(elementId);
objonkeydown=obj.onkeydown;
objonblur=obj.onblur;
objonkeyup=obj.onkeyup;
objonkeypress=obj.onkeypress;

objonchangeoriginal=obj.onchange;
obj.onchange=function(event){
if(mouseactive==1)return false;
if(typeof objonchangeoriginal=="function")objonchangeoriginal();
}
objonchange=obj.onchange;
obj.onblur=function(event){
if(mouseactive==1){
Wicket.$(elementId).focus();
return killEvent(event);
}
hideAutoComplete();
if(typeof objonblur=="function")objonblur();
}
obj.onkeydown=function(event){
switch(wicketKeyCode(Wicket.fixEvent(event))){
case KEY_UP:
if(selected>-1)selected--;
if(selected==-1){
hideAutoComplete();
} else {
render();
}
if(Wicket.Browser.isSafari())return killEvent(event);
break;
case KEY_DOWN:
if(selected<elementCount-1){
selected++;
}
if(visible==0){
updateChoices();
} else {
render();
showAutoComplete();
}
if(Wicket.Browser.isSafari())return killEvent(event);
break;
case KEY_ESC:
hideAutoComplete();
return killEvent(event);
break;
case KEY_ENTER:
if(selected>-1){
obj.value=getSelectedValue();
hideAutoComplete();
hidingAutocomplete=1;
if(typeof objonchange=="function")objonchange();
} else if (Wicket.AutoCompleteSettings.enterHidesWithNoSelection==true) {
hideAutoComplete();
hidingAutocomplete=1;
}
mouseactive=0;
if(typeof objonkeydown=="function")objonkeydown();
if(selected>-1){

}
return true;
break;
default:
}
}
obj.onkeyup=function(event){
switch(wicketKeyCode(Wicket.fixEvent(event))){
case KEY_ENTER:
return killEvent(event);
case KEY_UP:
case KEY_DOWN:
case KEY_ESC:
case KEY_TAB:
case KEY_RIGHT:
case KEY_LEFT:
case KEY_SHIFT:
case KEY_ALT:
case KEY_CTRL:
break;
default:
updateChoices();
}
if(typeof objonkeyup=="function")objonkeyup();
return null;
}
obj.onkeypress=function(event){
if(wicketKeyCode(Wicket.fixEvent(event))==KEY_ENTER){
if(selected>-1 || hidingAutocomplete==1){
hidingAutocomplete=0;
return killEvent(event);
}
}
if(typeof objonkeypress=="function")objonkeypress();
}
}
function getMenuId() {
return elementId+"-autocomplete";
}
function getAutocompleteMenu() {
var choiceDiv=document.getElementById(getMenuId());
if (choiceDiv==null) {
var container = document.createElement("div");
container.className="wicket-aa-container";
document.body.appendChild(container);
container.style.display="none";
container.style.overflow="auto";
container.style.position="absolute";
container.id=getMenuId()+"-container";
container.show = function() { wicketShow(this.id) };
container.hide = function() { wicketHide(this.id) };
choiceDiv=document.createElement("div");
container.appendChild(choiceDiv);
choiceDiv.id=getMenuId();
choiceDiv.className="wicket-aa";

container.onmouseout=function() {mouseactive=0;};
container.onmousemove=function() {mouseactive=1;};
}
return choiceDiv;
}
function getAutocompleteContainer() {
var node=getAutocompleteMenu().parentNode;
return node;
}
function killEvent(event){
if(!event)event=window.event;
if(!event)return false;
if(event.cancelBubble!=null){
event.cancelBubble=true;
}
if(event.returnValue){
event.returnValue=false;
}
if(event.stopPropagation){
event.stopPropagation();
}
if(event.preventDefault){
event.preventDefault();
}
return false;
}
function updateChoices(){
if(cfg.preselect==true){
selected = 0;
}
else{
selected=-1;
}
localThrottler.throttle(getMenuId(), throttleDelay, actualUpdateChoices);
}
function actualUpdateChoices()
{
var value = wicketGet(elementId).value;
var request = new Wicket.Ajax.Request(callbackUrl+"&q="+processValue(value), doUpdateChoices, false, true, false, "wicket-autocomplete|d");
request.get();
}
function processValue(param) {
return (encodeURIComponent)?encodeURIComponent(param):escape(param);
}
function showAutoComplete(){
var position=getPosition(wicketGet(elementId));
var container = getAutocompleteContainer();
var input=wicketGet(elementId);
var index=getOffsetParentZIndex(elementId);
container.show();
container.style.zIndex=(Number(index)!=Number.NaN?Number(index)+1:index);
container.style.left=position[0]+'px'
container.style.top=(input.offsetHeight+position[1])+'px';
container.style.width=input.offsetWidth+'px';
visible=1;
hideShowCovered();
}
function hideAutoComplete(){
visible=0;
selected=-1;
if ( getAutocompleteContainer() )
{
getAutocompleteContainer().hide();
hideShowCovered();
}
}
function getPosition(obj) {
var leftPosition=0;
var topPosition=0;
do {
topPosition += obj.offsetTop || 0;
leftPosition += obj.offsetLeft || 0;
obj = obj.offsetParent;
} while (obj);
return [leftPosition,topPosition];
}
function doUpdateChoices(resp){

var input=wicketGet(elementId);
if (!cfg.showListOnEmptyInput && (input.value==null || input.value=="")) {
hideAutoComplete();
return;
}
var element = getAutocompleteMenu();
element.innerHTML=resp;
if(element.firstChild && element.firstChild.childNodes) {
elementCount=element.firstChild.childNodes.length;
var clickFunc = function(event){
mouseactive=0;
wicketGet(elementId).value=getSelectedValue();
if(typeof objonchange=="function")objonchange();
hideAutoComplete();
};
var mouseOverFunc = function(event){
selected = getElementIndex(this);
render();
showAutoComplete();
};
var node=element.firstChild.childNodes[0];
for(var i=0;i<elementCount;i++){
node.onclick = clickFunc;
node.onmouseover = mouseOverFunc;
node = node.nextSibling;
}
} else {
elementCount=0;
}
if(elementCount>0){
showAutoComplete();
} else {
hideAutoComplete();
}
render();
scheduleEmptyCheck();
Wicket.Log.info("Response processed successfully.");
Wicket.Ajax.invokePostCallHandlers();
}
function scheduleEmptyCheck() {
window.setTimeout(function() {
var input=wicketGet(elementId);
if (!cfg.showListOnEmptyInput && (input.value==null || input.value=="")) {
hideAutoComplete();
}
}, 100);
}
function getSelectedValue(){
var element=getAutocompleteMenu();
var attr=element.firstChild.childNodes[selected].attributes['textvalue'];
var value;
if (attr==undefined) {
value=element.firstChild.childNodes[selected].innerHTML;
} else {
value=attr.value;
}
return stripHTML(value);
}
function getElementIndex(element) {
for(var i=0;i<element.parentNode.childNodes.length;i++){
var node=element.parentNode.childNodes[i];
if(node==element)return i;
}
return -1;
}
function stripHTML(str) {
return str.replace(/<[^>]+>/g,"");
}
function adjustScrollOffset(menu, item) {
if (item.offsetTop + item.offsetHeight > menu.scrollTop + menu.offsetHeight) {
menu.scrollTop = item.offsetTop + item.offsetHeight - menu.offsetHeight;
} else

if (item.offsetTop < menu.scrollTop) {
menu.scrollTop = item.offsetTop;
}
}
function render(){
var menu=getAutocompleteMenu();
var height=0;
var node=menu.firstChild.childNodes[0];
var re = /\bselected\b/gi;
for(var i=0;i<elementCount;i++)
{
var origClassNames = node.className;
var classNames = origClassNames.replace(re, "");
if(selected==i){
classNames += " selected";
adjustScrollOffset(menu.parentNode, node);
}
if (classNames != origClassNames)
node.className = classNames;
if ((cfg.maxHeight > -1) && (height < cfg.maxHeight))
height+=node.offsetHeight;
node = node.nextSibling;
}
if (cfg.maxHeight > -1) {


if (initialDelta == -1)
initialDelta = menu.parentNode.offsetHeight - height;
height = height<cfg.maxHeight ? height+initialDelta : cfg.maxHeight;
menu.parentNode.style.height=height+"px";
}
}

function getStyle(obj,cssRule) {
var cssRuleAlt = cssRule.replace(/\-(\w)/g,function(strMatch,p1){return p1.toUpperCase();});
var value=obj.style[cssRuleAlt];
if (!value) {
if (document.defaultView && document.defaultView.getComputedStyle) {
value = document.defaultView.getComputedStyle(obj,"").getPropertyValue(cssRule);
}
else if (obj.currentStyle)
{
value=obj.currentStyle[cssRuleAlt];
}
}
return value;
}
function isVisible(obj) {
return getStyle(obj,"visibility");
}
function getOffsetParentZIndex(obj) {
obj=typeof obj=="string"?Wicket.$(obj):obj;
obj=obj.offsetParent;
var index="auto";
do {
var pos=getStyle(obj,"position");
if(pos=="relative"||pos=="absolute"||pos=="fixed") {
index=getStyle(obj,"z-index");
}
obj=obj.offsetParent;
} while (obj && index == "auto");
return index;
}
function hideShowCovered(){
if (!/msie/i.test(navigator.userAgent) && !/opera/i.test(navigator.userAgent)) {
return;
}


setTimeout(hideShowCoveredTimeout,1);
}
function hideShowCoveredTimeout(){
var el=getAutocompleteContainer();
var p=getPosition(el);
var acLeftX=p[0];
var acRightX=el.offsetWidth+acLeftX;
var acTopY=p[1];
var acBottomY=el.offsetHeight+acTopY;
var hideTags=new Array("select","iframe","applet");
for (var j=0;j<hideTags.length;j++) {
var tagsFound=document.getElementsByTagName(hideTags[j]);
for (var i=0; i<tagsFound.length; i++){
var tag=tagsFound[i];
p=getPosition(tag);
var leftX=p[0];
var rightX=leftX+tag.offsetWidth;
var topY=p[1];
var bottomY=topY+tag.offsetHeight;
if (this.hidden || (leftX>acRightX) || (rightX<acLeftX) || (topY>acBottomY) || (bottomY<acTopY)) {
if(!tag.wicket_element_visibility) {
tag.wicket_element_visibility=isVisible(tag);
}
tag.style.visibility=tag.wicket_element_visibility;
} else {
if (!tag.wicket_element_visibility) {
tag.wicket_element_visibility=isVisible(tag);
}
tag.style.visibility = "hidden";
}
}
}
}
initialize();
}

