// Global variable definitions
// DB column numbers
var OPT_ID = 0;
var OPT_TITLE = 1;
var OPT_VOTES = 2;

var votedID;
jQuery.noConflict();
jQuery(document).ready(function($){
  $("#poll").submit(formProcess); // setup the submit handler
  
  if ($("#poll-results").length > 0 ) {
    animateResults();
  };
  
  var pid = $("#poll_id").attr("value");
  if ($.cookie('vote_id') && $.cookie('poll_id') == pid) {
    $("#poll-container").empty();
    votedID = $.cookie('vote_id');
    $.getJSON("/poll_submit?vote=none&pid="+pid,loadResults);
  };


function formProcess(event){
  event.preventDefault();
  
  var pid = $("#poll_id").attr("value");
  var id = $("input[@name='poll']:checked").attr("value");
  if (id) {
    id = id.replace("opt",'');
  
    $("#poll-container").fadeOut("slow",function(){
      $(this).empty();
    
      votedID = id;
      $.getJSON("/poll_submit?vote="+id+"&pid="+pid,loadResults);
    
      $.cookie('vote_id', id, {expires: 365});
      $.cookie('poll_id', pid, {expires: 365});
    });
  }
};

function animateResults(){
  //$.scrollTo("#poll-container"); 
  $("#poll-results div").each(function(){
      var percentage = $(this).next().text();
      $(this).css({width: "0%"}).animate({
            width: percentage}, 'slow');
  });
};

function loadResults(data) {
  var total_votes = 0;
  var percent;

  for (id in data) {
    total_votes = total_votes+parseInt(data[id][OPT_VOTES]);
  }
  
  var results_html = "<div id='poll-results'><h4>Poll Results</h4>\n<dl class='graph'>\n";
  for (id in data) {
    percent = Math.round((parseInt(data[id][OPT_VOTES])/parseInt(total_votes))*100);
    if (data[id][OPT_ID] !== votedID) {
      results_html = results_html+"<dt class='bar-title'>"+data[id][OPT_TITLE]+"</dt><dd class='bar-container'><div id='bar"+data[id][OPT_ID]+"'style='width:0%;'>&nbsp;</div><strong>"+percent+"%</strong></dd>\n";
    } else {
      results_html = results_html+"<dt class='bar-title'>"+data[id][OPT_TITLE]+"</dt><dd class='bar-container'><div id='bar"+data[id][OPT_ID]+"'style='width:0%;background-color:#0066cc;'>&nbsp;</div><strong>"+percent+"%</strong></dd>\n";
    }
  }
  
  results_html = results_html+"</dl><p style='clear:both;'></p><p class='total-votes'>Total Votes: "+total_votes+"</p></div>\n";
  
  $("#poll-container").append(results_html).fadeIn("slow",function(){
    animateResults();});
}
});