1 /** 2 * Ajax 3 * 4 * Module for making ajax requests 5 */ 6 (function (){ 7 8 "use strict"; 9 10 // Don't bother even defining the object if the XMLHttpRequest isn't available 11 if(typeof window.XMLHttpRequest === "undefined") 12 { 13 return; 14 } 15 16 var ajax = { 17 _do: function (url, data, callback, isPost) 18 { 19 var type, 20 request = new XMLHttpRequest(); 21 22 if (typeof callback === "undefined") 23 { 24 /** 25 * @private 26 */ 27 callback = function (){}; 28 } 29 30 type = (isPost) ? "POST" : "GET"; 31 32 url += (type === "GET") ? "?"+this._serialize(data) : ''; 33 34 request.open(type, url); 35 36 request.onreadystatechange = function () 37 { 38 if (request.readyState === 4) 39 { 40 callback(request.responseText); 41 } 42 }; 43 44 if (type === "POST") 45 { 46 request.setRequestHeader("Content-Type", "application/x-www-form-urlencoded"); 47 request.send(this._serialize(data)); 48 } 49 else 50 { 51 request.send(null); 52 } 53 }, 54 _serialize: function (data) 55 { 56 var name, 57 value, 58 pairs = []; 59 60 for (name in data) 61 { 62 if (!data.hasOwnProperty(name)) 63 { 64 continue; 65 } 66 if (typeof data[name] === "function") 67 { 68 continue; 69 } 70 71 value = data[name].toString(); 72 73 name = encodeURIComponent(name); 74 value = encodeURIComponent(value); 75 76 pairs.push(name + "=" + value); 77 } 78 79 return pairs.join("&"); 80 } 81 }; 82 83 /** 84 * Sends a GET type ajax request 85 * 86 * @name get 87 * @function 88 * @memberOf $_ 89 * @param string url 90 * @param object data 91 * @param function callback 92 */ 93 $_.ext('get', function (url, data, callback){ 94 ajax._do(url, data, callback, false); 95 }); 96 97 /** 98 * Sends a POST type ajax request 99 * 100 * @name post 101 * @function 102 * @memberOf $_ 103 * @param string url 104 * @param object data 105 * @param function callback 106 */ 107 $_.ext('post', function (url, data, callback){ 108 ajax._do(url, data, callback, true); 109 }); 110 111 /** 112 * Watches for server-sent events, or falls back to ajax polling 113 * - defaults to 30 second intervals 114 * 115 * @name sse 116 * @function 117 * @memberOf $_ 118 * @param string url 119 * @param function callback 120 * @param [int] 30000 121 */ 122 $_.ext('sse', function(url, callback, poll_rate){ 123 124 var source; 125 126 //Check for server-sent event support 127 if (typeof EventSource !== 'undefined') 128 { 129 source = new EventSource(url); 130 131 // Apply the callback 132 source.onmessage = function(event){ 133 callback(event.data); 134 }; 135 } 136 else // Ajax polling fallback 137 { 138 poll_rate = poll_rate || 30000; 139 140 setInterval($_.get, poll_rate, url, {}, function(res){ 141 res.trim().replace(/data:/gim, ''); 142 res.replace(/^(event|id|retry)?\:(.*)$/gim, ''); 143 callback.call(res, res); 144 }); 145 } 146 }); 147 148 }());