function addEvent( obj, type, fn ) { if (obj.addEventListener) { obj.addEventListener( type, fn, false ); EventCache.add(obj, type, fn); } else if (obj.attachEvent) { obj["e"+type+fn] = fn; obj[type+fn] = function() { obj["e"+type+fn]( window.event ); } obj.attachEvent( "on"+type, obj[type+fn] ); EventCache.add(obj, type, fn); } else { obj["on"+type] = obj["e"+type+fn]; } } var EventCache = function() { var listEvents = []; return { listEvents : listEvents, add : function(node, sEventName, fHandler) { listEvents.push(arguments); }, flush : function() { var i, item; for (i = listEvents.length - 1; i >= 0; i = i - 1) { item = listEvents[i]; if(item[0].removeEventListener) { item[0].removeEventListener(item[1], item[2], item[3]); }; if(item[1].substring(0, 2) != "on") { item[1] = "on" + item[1]; }; if(item[0].detachEvent) { item[0].detachEvent(item[1], item[2]); }; item[0][item[1]] = null; }; } }; }(); addEvent(window,'unload',EventCache.flush); // function use to create the HTML var Flux = new Array(); var isIE = (document.all) ? true : false; Array.prototype.ArrayPos = function(quoi) { var Position = -1; for (i = 0; this[i]; i++) { if (quoi == this[i]) { Position = i; } } return Position; } $Close=function(Closing) { var FluxPos = Flux.ArrayPos(Closing) var FluxLength = Flux.length; var SpliceLength = FluxLength - FluxPos + 1; var AppendLot = Flux.splice(FluxPos + 1, SpliceLength); for(l = 0; AppendLot[0]; l++) { Closing.appendChild(AppendLot.shift()); } if(Flux.length == 1) { document.getElementById('cartouche').appendChild(Flux.pop()); } } var $Component = function (htmlObj) { var Elt = ''; var created = 0; Elt = htmlObj['obj']; if(htmlObj['obj'] === 'form') { if(isIE) { var Obj = document.createElement('form'); if(isIE9) { Obj.setAttribute('name',htmlObj['name']); Obj.setAttribute('target','_self'); }else { Obj.name = htmlObj['name']; Obj.target = '_self'; } }else{ var Obj = document.createElement(htmlObj['obj']); } created = 1; } else { if (('name' in htmlObj) && (htmlObj['obj'] == 'input') && (isIE)) { var Obj = document.createElement('input'); if(isIE9) { Obj.setAttribute('name',htmlObj['name']); if ('value' in htmlObj) { Obj.setAttribute('value',htmlObj['value']); } }else { Obj.name = htmlObj['name']; if ('value' in htmlObj) { Obj.value = htmlObj['value']; } } created = 1; } } if( created === 0 ) { var Obj = document.createElement(Elt); } var Obj = document.createElement(Elt); for (elt in htmlObj) { if (elt != 'obj') { if(elt == 'css') { for(Styl in htmlObj['css']) { if(Styl == 'cssFloat' && isIE) { Obj.style['float'] = htmlObj['css'][Styl]; } else { Obj.style[Styl] = htmlObj['css'][Styl]; } } }else { if(isIE) { if(!isIE || (elt != 'name' && elt != 'for' )) { Obj[elt] = htmlObj[elt]; } } else { Obj[elt] = htmlObj[elt]; } } } } Flux.push(Obj); return Obj; } function closeSearch() { document.getElementById('searchForm').reset(); document.getElementById('closeSearch').style.visibility = 'hidden'; } function search() { var value = document.getElementById('searchInputId').value; var selectedBlockId = completionMosse.getAllSuggestionParams(completionMosse.getSuggestionPrefix()+ completionMosse.getHighlightedSuggestionIndex()); var url = ''; if (typeof selectedBlockId !== 'undefined' && selectedBlockId !==null) { var bhv = completionMosse.blocks["default"][selectedBlockId['blockId']]['bhv']; url = this.searchurl + '/?' + propertiesMosse.additionalParams + '&bhv=' + bhv + '&kw=' + value + '&suggest=on'; } else { url = this.searchurl + '/?' + propertiesMosse.additionalParams + '&bhv=' + this.bhvSelect + '&kw=' + value; } // Redirect to search url document.location.href = url; } // Initialize var init = function createCartouche() { this.bhvSelect = 'results'; this.searchurl = 'http://search.orange.jo/'; this.searchcmplurl = 'http://completion.ke.voila.fr'; this.pays = 'ojo'; this.lg = 'ar'; this.type = 'res'; this.blocksTitle = new Array(); this.blocksTitle['ar'] = new Array(); this.blocksTitle['ar']['Store'] = 'تسوق >'; this.blocksTitle['ar']['Assistance'] = 'جمهور >'; this.blocksTitle['ar']['Results'] = 'النتائج >'; this.blocksTitle['ar']['Placeholder'] = ''; if(isIE) { var mycenterdiv = $Component({ 'obj' :'div', 'css' :{ 'margin' : '0px 0px 0px' } }); var myform = $Component({ 'obj' : 'form', 'id' : 'searchForm', 'name' : 'searchForm', 'method' : 'get', 'action' : this.searchurl, 'css' : { 'textAlign' : 'left' }, 'autocomplete' : 'off' }); } else { var myform = $Component({ 'obj' : 'form', 'id' : 'searchForm', 'name' : 'searchForm', 'method' : 'get', 'action' : this.searchurl, 'css' : { 'textAlign' : 'left', }, 'autocomplete' : 'off' }); } if(!isIE) { var bgImage; var nav = (navigator.userAgent); if (nav.indexOf('Chrome') !== -1 || nav.indexOf('Safari') !== -1) { bgImage = '-webkit-gradient(linear, left top, left bottom, from(#FFFFFF), to(#BBBBBB))'; } else if (nav.indexOf('Opera') !== -1 ) { bgImage = '-o-linear-gradient(#BBBBBB 0%, #FFFFFF 100%)'; } else { bgImage = '-moz-linear-gradient(center bottom , #BBBBBB 0px, #FFFFFF 100%)'; } var myinput = $Component({ 'obj' : 'input', 'placeholder' : '', 'id' : 'searchInputId', 'type' : 'text', 'name' : 'kw', 'css': { 'width': '235px', 'height': '13px', 'border': '0px', 'padding': '0px', 'margin-right': '0px', 'float': 'right', 'color': '#999999', 'font-size': '13px', 'font-family': 'arial' } }); // $Close(myinput); var mybuttonClosesearch = $Component({ 'obj' : 'a', 'id' : 'closeSearch', 'href' : 'javascript:closeSearch()', 'css' : { 'backgroundImage' : 'url("")', 'backgroundRepeat' : 'no-repeat', 'display' : 'none', 'position' : 'absolute', 'right' : '235px', 'top' : '17px', 'height' : '35px', 'width' : '18px' } }); // $Close(mybuttonClosesearch); var mysubmit = $Component({ 'obj' : 'span', 'css' : { 'float':'right' } // }); var mysubmitText = $Component({ 'obj' : 'input', 'type' : 'submit', 'id' : 'searchSubmitId', 'value' : '', 'css':{ 'display': 'block', 'float': 'left', 'width': '37px', 'height': '33px', 'text-decoration': 'none', 'margin-left':'0px', 'background': 'url(/shop/mediaServlet/site/images/menu_images/searchIcon.png) no-repeat left 50%' } }); // $Close(mysubmitText); // $Close(mysubmit); }else { var myinput = $Component({ 'obj' : 'input', 'placeholder' : '', 'id' : 'searchInputId', 'type' : 'text', 'name' : 'kw', 'css': { 'width': '235px', 'height': '13px', 'border': '0px', 'padding': '0px', 'margin-right': '0px', 'float': 'right', 'color': '#999999', 'font-size': '13px', 'font-family': 'arial' } }); // $Close(myinput); var mybuttonClosesearch = $Component({ 'obj' :'a', 'id' :'closeSearch', 'href' :'javascript:closeSearch()', 'css' : { 'backgroundImage' : 'url("/_layouts/OrangeNewCMS/EN/Styles/FTsearch/close_search.png")', 'backgroundRepeat' : 'no-repeat', 'display' : 'none', 'position' : 'absolute', 'right' : '240px', 'top' : '8px', 'height' : '33px', 'width' : '18px' } }); // $Close(mybuttonClosesearch); if(navigator.appVersion.indexOf('MSIE 10.0') > 0) { var mysubmit = $Component({ 'obj' : 'span', 'css' : { 'float':'right' } }); } else if(navigator.appVersion.indexOf('MSIE 9.0') > 0) { var mysubmit = $Component({ 'obj' : 'span', 'css' : { 'float':'right' } }); } else { var mysubmit = $Component({ 'obj' : 'span', 'css' : { 'float':'right' } }); } var mysubmitText = $Component({ 'obj' : 'input', 'type' : 'submit', 'id' : 'searchSubmitId', 'value' : '', 'css':{ 'display': 'block', 'float': 'left', 'width': '37px', 'height': '33px', 'text-decoration': 'none', 'margin-left':'0px', 'background': 'url(/shop/mediaServlet/site/images/menu_images/searchIcon.png) no-repeat left 50%' } }); // $Close(mysubmitText); // $Close(mysubmit); } // $Close(myform); }(); (function () { // Add event on the input and cancel button var cancel = document.getElementById('closeSearch'); var input = document.getElementById('searchInputId'); var submit = document.getElementById('searchSubmitId'); var checkInputClearButton = function() { if (input.value) cancel.style.display = 'block'; else cancel.style.display = 'none'; } addEvent(input,"blur", function () { cancel.style.display = 'none'; }); addEvent(input, "keyup", checkInputClearButton); addEvent(input, "change", checkInputClearButton); addEvent(input, "focus", checkInputClearButton); addEvent(cancel, "mousedown", function (e) { e = e || window.event; e.preventDefault ? e.preventDefault() : e.returnValue = false; input.value = ''; cancel.style.display = 'none'; // Simulate a normal key entry to update the completer after cancelling search input completionMosse.defaultFieldOnKeyUpCallBack({keyCode:-1}); setTimeout(function() { input.focus(); }, 10); }); // Press enter addEvent(document, "keypress", function(e) { var keycode = (window.event) ? window.event.keyCode : e.keyCode; if(keycode == 13 && input.value == '') { if (e.preventDefault) { e.preventDefault(); } e.returnValue = false; if (e.stopPropagation) { e.stopPropagation(); } e.cancelBubble = true; } }); // click search button addEvent(submit, "click", function (e) { if (input.value == '') { if (e.preventDefault) { e.preventDefault(); } e.returnValue = false; if (e.stopPropagation) e.stopPropagation(); e.cancelBubble = true; } }); })(); var petaleDefaultImages = {"boutique" : "/shop/mediaServlet/site/images/menu_images/searchPetaleGenericBoutique.png"}; var propertiesMosse = { 'url' : this.searchcmplurl + '/proxy/cmplGsa', 'blocks' : [ { 'label' : this.blocksTitle[this.lg]['Store'], 'bhv' : 'store', 'max' : 3 }, { 'label' : this.blocksTitle[this.lg]['Assistance'], 'bhv' : 'assistance', 'max' : 3 }, { 'label' : this.blocksTitle[this.lg]['Results'], 'bhv' : 'results', 'max' : 3 } ], 'divCompletionId' : 'mydivcmplsuggest', 'field' : document.getElementById('searchInputId'), 'queryParamName' : 'kw', 'additionalParams' : 'pays=' + encodeURIComponent(this.pays) + '&langue=' + encodeURIComponent(this.lg) + '&type=' + encodeURIComponent(this.type), 'cssPrefix' : 'cmpl', 'maxNbSuggestions' : 9, 'maxNbChar' : 45, 'clearAccents' : false, callbacks : { "submit" : { context: null, method: "search" } }, 'closeCompletionOnBlur' : true, 'isFormSubmit' : false, 'closeLink' : false, 'nameOfInstanceForJsonP' : 'completionMosse', 'petale' : true, 'plugins' : ['Petale'], 'petaleDefaultImages' : petaleDefaultImages }; var completionMosse = new orangesearch.completion.Component(propertiesMosse); completionMosse.start();