/*
  Moogets - TextboxList 0.2
  - MooTools version required: 1.2
  - MooTools components required: Element.Event, Element.Style and dependencies.
  
  Credits:
  - Idea: Facebook + Apple Mail
  - Caret position method: Diego Perini <http://javascript.nwbox.com/cursor_position/cursor.js>
  
  Changelog:
  - 0.1: initial release
  - 0.2: code cleanup, small blur/focus fixes
*/

/* Copyright: Guillermo Rauch <http://devthought.com/> - Distributed under MIT - Keep this message! */

Element.implement({
  
  getCaretPosition: function() {
    if (this.createTextRange) {
      var r = document.selection.createRange().duplicate();
        r.moveEnd('character', this.value.length);
        if (r.text === '') { return this.value.length; }
        return this.value.lastIndexOf(r.text);
    } else { return this.selectionStart; }
  }
  
});

var ResizableTextbox = new Class({
  
  Implements: Options,
  
  options: {
    min: 166,
    max: 166,
    step: 7
  },
  
  initialize: function(element, options) {
    var that = this;
    this.setOptions(options);
    this.el = $(element);
    this.width = this.el.offsetWidth;
    this.el.addEvents({
      'keydown': function() {
        this.store('rt-value', this.get('value').length);
      },
      'keyup': function() {
        var newsize = that.options.step * this.get('value').length;
        if(newsize <= that.options.min) { newsize = that.width; }
        if(! (this.get('value').length == this.retrieve('rt-value') || newsize <= that.options.min || newsize >= that.options.max)) {
           this.setStyle('width', newsize);
        } 
      }
    });
  }
  
});

var TextboxList = new Class({
  
  Implements: [Events, Options],

  options: {/*
    onFocus: $empty,
    onBlur: $empty,
    onInputFocus: $empty,
    onInputBlur: $empty,
    onBoxFocus: $empty,
    onBoxBlur: $empty,
    onBoxDispose: $empty,
    onKeyPressGetCity: $empty,*/
    resizable: {},
    className: 'bit',
    separator: '###',
    extrainputs: true,
    startinput: true,
    hideempty: true,
    searchAjax: true
  },
  
  initialize: function(element, options) {
    this.setOptions(options);
    this.element = $(element).setStyle('display', 'none');    
    this.bits = new Hash();
    this.events = new Hash();
    this.count = 0;
    this.current = false;
    this.maininput = this.createInput({'class': 'maininput'});
    this.holder = new Element('ul', {
      'class': 'holder', 
      'events': {
        'click': function(e) { 
          e = new Event(e).stop();
          if(this.maininput != this.current) { this.focus(this.maininput); }
        }.bind(this)
      }
    }).inject(this.element, 'before').adopt(this.maininput);


          

   this.makeResizable(this.maininput);
    this.setEvents();
  },
  
  setEvents: function() {
    document.addEvent(Browser.Engine.trident ? 'keydown' : 'keypress', function(e) {    
      if(! this.current) { return; }
      if(this.current.retrieve('type') == 'box' && e.code == Event.Keys.backspace) { new Event(e).stop(); }
    }.bind(this));      
         
    document.addEvents({
      'keyup': function(e) { 
        e = new Event(e).stop();
        if(! this.current) { return; }
        switch(e.code){
          case Event.Keys.left: return this.move('left');
          case Event.Keys.right: return this.move('right');
          case Event.Keys.backspace: return this.moveDispose();
        }
      }.bind(this),
      'click': function() { this.fireEvent('onBlur').blur(); }.bind(this)
    });
  },
  
  update: function() {
    this.element.set('value', this.bits.getValues().join(this.options.separator));
    return this;
  },
  
  add: function(text, html) {
    var id = this.options.className + '-' + this.count++;
	var textIn = text.split(",");

   
    var startCityId = document.getElementById('sel_directions_from').value;
    var endCityId = document.getElementById('sel_directions_to').value;

       if(startCityId == textIn[2] || endCityId == textIn[2]) {
          alert("Cannot select start city or end city as an additional city.");


          /*var textforlist = "";
          for (var y in this.datadescrition) {
                 if (y == textIn[1]) {
                    textforlist =  this.datadescrition[textIn[1]];
                 }
          }
          textforlist = textforlist + "-" + textIn[1];
          this.fireEvent('onBoxDispose', el.set('text', textforlist));
          el.destroy();*/

          return;
      }

     
      if(itemCountInViaCityList >= 3) {
		alert("You can only select up to three cities.");
		var elems = document.getElementById('via_cities_input');
        for(var x=0; x < elems.length; x++) {
           elems[x].style.display="none";
        }
		return;
	}
	itemCountInViaCityList++;


   var textToPrint = "";
    var el = this.createBox($pick(html, textIn[0]), {'id': id}).inject(this.current || this.maininput, 'before');

    var liele = document.getElementById('facebook-list');
    var  ulele = getElementsByClassName(liele, "ul", "feed");
    var elems1 =   getElementsByClassName(ulele[0], "li", "auto-focus");
    if(elems1.length > 0) {
       // alert(elems[0].id);
         el.set('via-city-id', elems1[0].id);

          var texttolist = "";

          if(textIn[1].length > 1) {
              texttolist = textIn[0] + "," + textIn[1];
          } else {
               texttolist = textIn[0] + ",";
          }
 

         el.set('title', texttolist);



    }



    el.addEvent('click', function(e) {
      e = new Event(e).stop();
      this.focus(el);
    }.bind(this));

    this.bits.set(id, text);

	//for(var a=0; a < tokensArray[0].length; a++) {
		//if(text == tokensArray[0][a][0]) {
			//var city_id = tokensArray[0][a][2];
			viaCitiesArray[elems1[0].id] = textIn[0];
			generateMarkerForViaCity(elems1[0].id, textIn[0]);
		//}
	//}


	   
    if(this.options.extrainputs && (this.options.startinput || el.getPrevious())) { this.addSmallInput(el, 'before'); }
    return el;
  },
  
  addSmallInput: function(el, where) {
    var input = this.createInput({'class': 'smallinput'}).inject(el, where);
    input.store('small', true);
    this.makeResizable(input);
    if(this.options.hideempty) { input.setStyle('display', 'none'); }
    return input;
  },
  
  dispose: function(el) {
    
	var textOfCity = el.get('text');

    var city_id = (el.get('via-city-id'));

          for(var key in viaCitiesMarkersArray) {
             if(key==city_id) {
					delete viaCitiesArray[city_id];
				}
          }

		for(var val in viaCitiesMarkersArray) {
				if(val==city_id) {
					map.removeOverlay(viaCitiesMarkersArray[city_id]);
					delete viaCitiesMarkersArray[city_id]; // remove this from markers array
				}
		}

      if(itemCountInViaCityList !== 0) {
         itemCountInViaCityList--;
      }


        var elems = document.getElementById('via_cities_input');
        if(elems.length > 0) {
          elems[0].style.display="";
        }


	this.bits.erase(el.id);

    if(el.getPrevious().retrieve('small')) { el.getPrevious().destroy(); }
    if(this.current == el) { this.focus(el.getNext()); }

    var titletext = el.get('title').split(",");
    var newtext = el.retrieve('text').trim() + "," + titletext[1].trim() + "," + el.get('via-city-id').trim();

    if(el.retrieve('type') == 'box') { this.fireEvent('onBoxDispose', el.set('text', newtext)); }
    el.destroy();
    return this;
  },
  
  focus: function(el, nofocus) {
    if(! this.current) { this.fireEvent('onFocus', el); }
    else if(this.current == el) { return this; }
    this.blur();
    el.addClass(this.options.className + '-' + el.retrieve('type') + '-focus');
    if(el.retrieve('small')) { el.setStyle('display', 'block'); }
    if(el.retrieve('type') == 'input') {
      this.fireEvent('onInputFocus', el);      
      if(! nofocus) { this.callEvent(el.retrieve('input'), 'focus'); }
    }
    else { this.fireEvent('onBoxFocus', el); }
    this.current = el;    
    return this;
  },
  
  blur: function(noblur) {
    if(! this.current) { return this; }
    if(this.current.retrieve('type') == 'input') {
      var input = this.current.retrieve('input');
      if(! noblur) { this.callEvent(input, 'blur'); }   
      this.fireEvent('onInputBlur', input);
    }
    else { this.fireEvent('onBoxBlur', this.current); }
    if(this.current.retrieve('small') && ! input.get('value') && this.options.hideempty) {
      this.current.setStyle('display', 'none'); }
    this.current.removeClass(this.options.className + '-' + this.current.retrieve('type') + '-focus');
    this.current = false;
    return this;
  },
  
  createBox: function(text, options) {
    return new Element('li', $extend(options, {'class': this.options.className + '-box'})).set('html', text).store('type', 'box');
  },
  
  createInput: function(options) {
    var li = new Element('li', {'class': this.options.className + '-input'});
    var el = new Element('input', $extend(options, {
      'type': 'text',
	  'id': 'via_cities_input',
      'events': {
        'click': function(e) { e = new Event(e).stop(); },
        'focus': function(e) { if(! this.isSelfEvent('focus')) { this.focus(li, true); }}.bind(this),
        'blur': function() { if(! this.isSelfEvent('blur')) {this.blur(true);}}.bind(this),
        'keydown': function(e) { this.store('lastvalue', this.value).store('lastcaret', this.getCaretPosition()); }
      }
    }));
    return li.store('type', 'input').store('input', el).adopt(el);
  },
  
  callEvent: function(el, type) {
    this.events.set(type, el);
    el[type]();
  },
  
  isSelfEvent: function(type) {
    return (this.events.get(type)) ? !! this.removeEvents(type) : false;
  },
  
  makeResizable: function(li) {
    var el = li.retrieve('input');
    el.store('resizable', new ResizableTextbox(el, $extend(this.options.resizable)));
    return this;
  },
  
  checkInput: function() {
    var input = this.current.retrieve('input');
    return (! input.retrieve('lastvalue') || (input.getCaretPosition() === 0 && input.retrieve('lastcaret') === 0));
  },
  
  move: function(direction) {
    var el = this.current['get' + (direction == 'left' ? 'Previous' : 'Next')]();
    if(el && (! this.current.retrieve('input') || ((this.checkInput() || direction == 'right')))) { this.focus(el); }
    return this;
  },
  
  moveDispose: function() {
    if(this.current.retrieve('type') == 'box') { return this.dispose(this.current); }
    if(this.checkInput() && this.bits.getKeys().length && this.current.getPrevious()) { return this.focus(this.current.getPrevious()); }
  }
  
});









