//jQuery Rater Plugin 1.1 Copyright 2008 Jarrett Vance http://jvance.com
$.fn.rater = function(options) {
    var opts = $.extend({}, $.fn.rater.defaults, options);
    return this.each(function() {
        var $this = $(this);
        var $on = $this.find('.ui-rater-starsOn');
        var $off = $this.find('.ui-rater-starsOff');
        if (opts.size == undefined) opts.size = $off.height();
        if (opts.rating == undefined) opts.rating = $on.width() / opts.size;
        if (opts.id == undefined) opts.id = $this.attr('id');
        if (opts.noFloat == undefined) opts.noFloat = ($this.attr('name').substring(0,$this.attr('name').indexOf('.')) == 0 ? false : true);
	if (opts.textCount == undefined) opts.textCount = ($this.attr('name').substring($this.attr('name').indexOf('.')+1).substr(0,$this.attr('name').indexOf('_')-2) == 0 ? false : true);
	if (opts.textRating == undefined) opts.textRating = ($this.attr('name').substring($this.attr('name').indexOf('.')).substring($this.attr('name').indexOf('_')) == 0 ? false : true);
        if (opts.textRating) var $rating = $this.find('.ui-rater-rating');
        $off.mousemove(function(e) {
            var left = e.clientX - $off.offset().left;
            var width = $off.width() - ($off.width() - left);
            //width = Math.min(Math.ceil(width / (opts.size / opts.step)) * opts.size / opts.step, opts.size * opts.ratings.length)
            width = Math.ceil(width / (opts.size / opts.step)) * opts.size / opts.step;
            $on.width(width);
            //$this.attr('title', opts.ratings[r - 1] == undefined ? r : opts.ratings[r - 1]);
            if(opts.textRating) {
              var r = Math.round($on.width() / $off.width() * (opts.ratings.length * opts.step)) / opts.step;
              $rating.text(""+(opts.ratings[r - 1] == undefined ? r : opts.ratings[r - 1]));
              $rating.css('color', '#ffb931');
            }
        }).hover(function(e) { $on.addClass('ui-rater-starsHover'); }, function(e) {
            $on.removeClass('ui-rater-starsHover'); 
            $on.width(opts.rating * opts.size); 
            if(opts.textRating) {
              var r = Math.round($on.width() / $off.width() * (opts.ratings.length * opts.step)) / opts.step;
	      $rating.css('color', '');
              $rating.text(""+(opts.ratings[r - 1] == undefined ? r : opts.ratings[r - 1]));
            }
        }).click(function(e) {
	    var r = Math.round($on.width() / $off.width() * (opts.ratings.length * opts.step)) / opts.step;
	    $off.unbind('click').unbind('mousemove').unbind('mouseenter').unbind('mouseleave');
            if(opts.textRating) $rating.css('color', '');
            $.fn.rater.rate($this, opts, r);
        }).css('cursor', 'pointer'); $on.css('cursor', 'pointer');
    });
};

$.fn.rater.defaults = {
    postHref: location.href,
    ratings: ['1', '2', '3', '4', '5', '6', '7', '8', '9', '10', '11', '12', '13', '14', '15', '16', '17', '18', '19', '20', '21', '22', '23', '24', '25', '26', '27', '28', '29', '30', '31', '32', '33', '34', '35', '36', '37', '38', '39', '40', '41', '42', '43', '44', '45', '46', '47', '48', '49', '50', '51', '52', '53', '54', '55', '56', '57', '58', '59', '60', '61', '62', '63', '64', '65', '66', '67', '68', '69', '70', '71', '72', '73', '74', '75', '76', '77', '78', '79', '80', '81', '82', '83', '84', '85', '86', '87', '88', '89', '90', '91', '92', '93', '94', '95', '96', '97', '98', '99', '100'],
    step: 1,
    size: 0.9
};

$.fn.rater.rate = function($this, opts, rating) {
    var $on = $this.find('.ui-rater-starsOn');
    var $off = $this.find('.ui-rater-starsOff');
    $off.fadeTo(500, 0.4, function() {
        $.ajax({
            url: opts.postHref,
            type: "POST",
            data: 'id=' + opts.id + '&rating=' + rating,
            complete: function(req) {
                if (req.status == 200) { //success
		    if(opts.noFloat) { opts.rating = parseInt(req.responseText); }
		    else { opts.rating = parseFloat(req.responseText); }
                    //$off.unbind('click').unbind('mousemove').unbind('mouseenter').unbind('mouseleave');
                    $off.css('cursor', 'default'); $on.css('cursor', 'default');
                    $off.fadeTo(600, 1, function() {
                        $on.removeClass('ui-rater-starsHover').width(opts.rating * opts.size);
//                        var $count = $this.find('.ui-rater-rateCount');
//                        if(opts.textCount) $count.text(parseInt($count.text()) + 1);
			if(opts.textRating) {
                          $this.find('.ui-rater-rating').text((opts.noFloat ? parseInt(opts.rating.toFixed(1)) : opts.rating.toFixed(1)));
			}
                        $off.fadeTo(500, 1);
			if(!opts.noFloat) $this.attr('title', 'Your rating: ' + rating.toFixed(1));
                    });
                } else { //failure
                    alert(req.responseText);
                    $off.fadeTo(2200, 1);
                }
            }
        });
    });
};

