(function($, window, undefined){ $.vgquotes = function() { var ajaxCallback = function(type, callback) { return function(data) { if (typeof(data) === "undefined" || typeof(data.Error) === "undefined" || data.Error !== null) { callback.call(null, null); return; } callback.call(null, data.Data.records[0]); }; }; return { parseDate: function(jsonDate) { return new Date(parseInt(jsonDate.substr(6))); }, formatDate: function(date) { return date.getFullYear() + "-" + (date.getMonth() + 1) + "-" + date.getDate(); }, parseAndFormatDate: function(jsonDate) { return $.vgquotes.formatDate($.vgquotes.parseDate(jsonDate)); }, ajaxErrorHandler: function(xhr) { alert("An error occurred (" + xhr.status + ")"); }, preload: function(images) { $.each(images, function() { $('')[0].src = this; }); }, loadingGif: "/media/images/loading.gif", getResourceById: function(type, id, callback) { id = id.toString(); $.ajax("/api/" + type + "/" + id, { type: "GET", success: ajaxCallback(type, callback), error: ajaxCallback(type, callback) }); }, createDialog: function($dialog) { $("body") .append($("
").attr("id", "modal-background")) .append($dialog); $dialog.center(); }, closeDialog: function($dialog) { $("#modal-background").remove(); $dialog.remove(); } }; }(); var setupSearch = function() { var submitSearch = function() { var searchQuery = $.trim($("#search-query").val()); if (searchQuery.length > 0) { window.location = "/search/" + searchQuery; } return false; }; $(document).ready(function() { $("#search-query").keypress(function(e) { if (e.which === 13) { submitSearch(); } }); $("#search-submit").click(submitSearch); }); }; var setupVoting = function() { var voting = false; $(".vote-for, .vote-against").live("click", function() { if (voting) { alert("Please wait for the current vote to process before voting again"); return false; } voting = true; var $votingLink = $(this); var $container = $votingLink.parents(".quote-container"); var direction = $votingLink.hasClass("vote-for") ? 1 : 0; var quoteId = $container.find("input.quote-id").val(); var $score = $container.find(".quote-score"); var score = $score.text(); $.ajax("/vote", { type: "POST", data: { QuoteId: quoteId, Direction: direction }, beforeSend: function() { $score.empty().append($("").attr({ src: $.vgquotes.loadingGif, title: "submitting your vote" + String.fromCharCode(0x2026) })); }, success: function(data, status, $xhr) { if (data.Error !== null) { window.alert(data.Error); return; } score = data.Data.score; $score.attr("title", "+" + data.Data.upVotes + ", -" + data.Data.downVotes); //remove the voting arrow, and add the other one if needed $votingLink.remove(); if (direction === 1) { if ($container.find(".vote-against").length === 0) { $("") .addClass("vote-against") .attr("title", "I hate this quote") .text(String.fromCharCode(0x25BC)) .appendTo($container.find(".vote-container:last")); } } else { if ($container.find(".vote-for").length === 0) { $("") .addClass("vote-for") .attr("title", "I like this quote") .text(String.fromCharCode(0x25B2)) .appendTo($container.find(".vote-container:first")); } } }, complete: function() { voting = false; var $img = $score.find("img"); if ($img.length) { $img.remove(); } $score.text(score); } }); return false; }); }; var setupFlagLink = function() { $(".quote-flag-link").click(function() { if ($(".flag-dialog").length > 0) { return false; } var $container = $(this).parents(".quote-container"); var quoteId = $container.find("input.quote-id").val(); var $row = $("