function AjaxErrorBadStatusCode(message) { this.name = 'AjaxErrorBadStatusCode'; this.message = message; }; AjaxErrorBadStatusCode.prototype = new Error(); var ajax = {}; ajax.create = function() { if(typeof XMLHttpRequest !== 'undefined') { return new XMLHttpRequest(); }; var versions = [ "MSXML2.XmlHttp.6.0", "MSXML2.XmlHttp.5.0", "MSXML2.XmlHttp.4.0", "MSXML2.XmlHttp.3.0", "MSXML2.XmlHttp.2.0", "Microsoft.XmlHttp" ]; var xhr; for(var i = 0; i < versions.length; i++) { try { xhr = new ActiveXObject(versions[i]); break; } catch(e) { // Silent }; }; return xhr; }; ajax.send = function(url, callback, method, data, async) { if(async === undefined) { async = true; }; var a = ajax.create(); a.open(method, url, async); a.onreadystatechange = function() { // a.readyState: // 0 - UNSENT // 1 - OPENED // 2 - HEADERS_RECEIVED // 3 - LOADING // 4 - DONE callback(method, data, a.readyState, a.status, a.responseText); }; if(method == 'POST') { a.setRequestHeader('Content-type', 'application/x-www-form-urlencoded'); }; a.send(data); }; ajax.get = function(url, data, callback, async) { var query = []; for(var key in data) { query.push(encodeURIComponent(key) + '=' + encodeURIComponent(data[key])); }; ajax.send(url + (query.length ? '?' + query.join('&') : ''), callback, 'GET', null, async); }; ajax.getJSON = function(url, data, callbackSuccess, callbackError, async) { ajax.get(url, data, function(method, data, readyState, status, responseText) { if(readyState == 4) { if(status == 200) { try { var r = JSON.parse(responseText); if(callbackSuccess) { callbackSuccess(method, data, readyState, status, r); }; } catch(e) { if(callbackError) { callbackError(method, data, readyState, status, e); }; }; } else { if(callbackError) { var e = new AjaxErrorBadStatusCode('Bad status code '+status); callbackError(method, data, readyState, status, e); }; }; }; }, async); }; ajax.post = function(url, data, callback, async) { var query = []; for (var key in data) { query.push(encodeURIComponent(key) + '=' + encodeURIComponent(data[key])); }; ajax.send(url, callback, 'POST', query.join('&'), async); }; ajax.postJSON = function(url, data, callbackSuccess, callbackError, async) { ajax.post(url, data, function(method, data, readyState, status, responseText) { if(readyState == 4) { if(status == 200) { try { var r = JSON.parse(responseText); if(callbackSuccess) { callbackSuccess(method, data, readyState, status, r); }; } catch(e) { if(callbackError) { callbackError(method, data, readyState, status, e); }; }; } else { if(callbackError) { var e = new AjaxErrorBadStatusCode('Bad status code '+status); callbackError(method, data, readyState, status, e); }; }; }; }, async); }; ajax.loadTag = function(tag, url, func, field) { if((typeof window[func] === 'function') || field != null) { if(!!!tag.className.match(new RegExp('(\\s|^)loading(\\s|$)'))) { tag.className += " loading"; ajax.getJSON(url, {}, function(method, data, readyState, status, responseData) { try { if(typeof window[func] === 'function') { var html = window[func](tag, responseData); tag.innerHTML = html; } else if(field != null) { tag.innerHTML = responseData[field]; }; } catch(e) { console.log('ajax.loadTag', 'e', e); }; tag.className = tag.className.replace(new RegExp('(\\s|^)loading(\\s|$)'), ' ').trim(); }, function(method, data, readyState, status, responseData) { tag.className = tag.className.replace(new RegExp('(\\s|^)loading(\\s|$)'), ' ').trim(); }); }; }; }; ajax.processTag = function(tag) { var get = tag.getAttribute('data-ajax-get'); var func = tag.getAttribute('data-ajax-func'); var field = tag.getAttribute('data-ajax-field'); var delay = tag.getAttribute('data-ajax-delay'); if((get && get != null) && ((func && func != null) || (field && field != null))) { if(delay == null) { ajax.loadTag(tag, get, func, field); } else { setTimeout(function() { ajax.loadTag(tag, get, func, field); }, delay); }; }; }; ajax.processTags = function() { var tags = document.querySelectorAll('[data-ajax-get]'); for(var key in tags) if(tags.hasOwnProperty(key)) { var tag = tags[key]; ajax.processTag(tag); }; }; ajax.reloadTag = function(tag) { ajax.processTag(tag); }; ajax.reloadTagById = function(id) { var tag = document.getElementById(id) if(tag != null) { ajax.reloadTag(tag); }; }; ajax.processFormSubmit = function(event) { event.preventDefault(); var form = event.target; var func = form.getAttribute('data-ajax-func'); if(func && func != null && typeof window[func] === 'function') { if(!!!form.className.match(new RegExp('(\\s|^)loading(\\s|$)'))) { form.className += " loading"; var data = {}; var inputs = form.querySelectorAll("input,select,textarea"); for(var i=0,m=inputs.length-1; i<=m; i++) { data[inputs[i].name] = inputs[i].value; }; var ajaxFunc = ajax.get; if(form.method == "post") { ajaxFunc = ajax.post; }; ajaxFunc(form.action, data, function(method, data, readyState, status, responseText) { var error = (readyState == 4 && status == 200); var responseData = responseText; try { var responseData = JSON.parse(responseText); } catch(e) { console.log('ajax.processFormSubmit', 'e', e); }; try { window[func](form, responseData, error, readyState, status); } catch(e) { console.log('ajax.processFormSubmit', 'e', e); }; form.className = form.className.replace(new RegExp('(\\s|^)loading(\\s|$)'), ' ').trim(); }); }; }; }; ajax.processForm = function(form) { var is = form.getAttribute('data-ajax-form'); var func = form.getAttribute('data-ajax-func'); if((is && is != null && is == "true") && (func && func != null)) { if(window.attachEvent) { form.attachEvent('onsubmit', ajax.processFormSubmit); } else if(window.addEventListener) { form.addEventListener('submit', ajax.processFormSubmit, false); }; }; }; ajax.processForms = function() { var forms = document.querySelectorAll('[data-ajax-form]'); for(var key in forms) if(forms.hasOwnProperty(key)) { var form = forms[key]; ajax.processForm(form); }; }; if(window.attachEvent) { window.attachEvent('onload', ajax.processTags); window.attachEvent('onload', ajax.processForms); } else if(window.addEventListener) { window.addEventListener('load', ajax.processTags, false); window.addEventListener('load', ajax.processForms, false); };