/** Verify.js - v0.0.1 - 2013/06/12 * https://github.com/jpillora/verify * Copyright (c) 2013 Jaime Pillora - MIT */ (function(window,document,undefined) { (function(window,document,undefined) { 'use strict'; var Notification, addStyle, coreStyle, createElem, defaults, getAnchorElement, getStyle, globalAnchors, hAligns, incr, inherit, insertCSS, mainPositions, opposites, parsePosition, pluginClassName, pluginName, pluginOptions, positions, realign, stylePrefixes, styles, vAligns, __indexOf = [].indexOf || function(item) { for (var i = 0, l = this.length; i < l; i++) { if (i in this && this[i] === item) return i; } return -1; }; pluginName = 'notify'; pluginClassName = pluginName + 'js'; positions = { t: 'top', m: 'middle', b: 'bottom', l: 'left', c: 'center', r: 'right' }; hAligns = ['l', 'c', 'r']; vAligns = ['t', 'm', 'b']; mainPositions = ['t', 'b', 'l', 'r']; opposites = { t: 'b', m: null, b: 't', l: 'r', c: null, r: 'l' }; parsePosition = function(str) { var pos; pos = []; $.each(str.split(/\W+/), function(i, word) { var w; w = word.toLowerCase().charAt(0); if (positions[w]) { return pos.push(w); } }); return pos; }; styles = {}; coreStyle = { name: 'core', html: "
\n
\n
\n
", css: "." + pluginClassName + "-corner {\n position: fixed;\n margin: 5px;\n z-index: 1050;\n}\n\n." + pluginClassName + "-corner ." + pluginClassName + "-wrapper,\n." + pluginClassName + "-corner ." + pluginClassName + "-container {\n position: relative;\n display: block;\n height: inherit;\n width: inherit;\n margin: 3px;\n}\n\n." + pluginClassName + "-wrapper {\n z-index: 1;\n position: absolute;\n display: inline-block;\n height: 0;\n width: 0;\n}\n\n." + pluginClassName + "-container {\n display: none;\n z-index: 1;\n position: absolute;\n cursor: pointer;\n}\n\n." + pluginClassName + "-text {\n position: relative;\n}\n\n." + pluginClassName + "-arrow {\n position: absolute;\n z-index: 2;\n width: 0;\n height: 0;\n}" }; stylePrefixes = { "border-radius": ["-webkit-", "-moz-"] }; getStyle = function(name) { return styles[name]; }; addStyle = function(name, def) { var cssText, _ref; if (!name) { throw "Missing Style name"; } if (!def) { throw "Missing Style definition"; } if ((_ref = styles[name]) != null ? _ref.cssElem : void 0) { if (window.console) { console.warn("" + pluginName + ": overwriting style '" + name + "'"); } styles[name].cssElem.remove(); } def.name = name; styles[name] = def; cssText = ""; if (def.classes) { $.each(def.classes, function(className, props) { cssText += "." + pluginClassName + "-" + def.name + "-" + className + " {\n"; $.each(props, function(name, val) { if (stylePrefixes[name]) { $.each(stylePrefixes[name], function(i, prefix) { return cssText += " " + prefix + name + ": " + val + ";\n"; }); } return cssText += " " + name + ": " + val + ";\n"; }); return cssText += "}\n"; }); } if (def.css) { cssText += "/* styles for " + def.name + " */\n" + def.css; } if (!cssText) { return; } def.cssElem = insertCSS(cssText); return def.cssElem.attr('id', "notify-" + def.name); }; insertCSS = function(cssText) { var elem; elem = createElem("style"); elem.attr('type', 'text/css'); $("head").append(elem); try { elem.html(cssText); } catch (e) { elem[0].styleSheet.cssText = cssText; } return elem; }; pluginOptions = { clickToHide: true, autoHide: true, autoHideDelay: 5000, arrowShow: true, arrowSize: 5, elementPosition: 'bottom', globalPosition: 'top right', style: 'bootstrap', className: 'error', showAnimation: 'slideDown', showDuration: 400, hideAnimation: 'slideUp', hideDuration: 200, gap: 5 }; inherit = function(a, b) { var F; F = function() {}; F.prototype = a; return $.extend(true, new F(), b); }; defaults = function(opts) { return $.extend(pluginOptions, opts); }; createElem = function(tag) { return $("<" + tag + ">"); }; globalAnchors = {}; getAnchorElement = function(element) { var radios; if (element.is('[type=radio]')) { radios = element.parents('form:first').find('[type=radio]').filter(function(i, e) { return $(e).attr('name') === element.attr('name'); }); element = radios.first(); } return element; }; incr = function(obj, pos, val) { var opp, temp; if (typeof val === 'string') { val = parseInt(val, 10); } else if (typeof val !== 'number') { return; } if (isNaN(val)) { return; } opp = positions[opposites[pos.charAt(0)]]; temp = pos; if (obj[opp] !== undefined) { pos = positions[opp.charAt(0)]; val = -val; } if (obj[pos] === undefined) { obj[pos] = val; } else { obj[pos] += val; } return null; }; realign = function(alignment, inner, outer) { if (alignment === 'l' || alignment === 't') { return 0; } else if (alignment === 'c' || alignment === 'm') { return outer / 2 - inner / 2; } else if (alignment === 'r' || alignment === 'b') { return outer - inner; } throw "Invalid alignment"; }; Notification = (function() { function Notification(elem, data, options) { if (typeof options === 'string') { options = { className: options }; } this.options = inherit(pluginOptions, $.isPlainObject(options) ? options : {}); this.loadHTML(); this.wrapper = $(coreStyle.html); this.wrapper.data(pluginClassName, this); this.arrow = this.wrapper.find("." + pluginClassName + "-arrow"); this.container = this.wrapper.find("." + pluginClassName + "-container"); this.container.append(this.userContainer); if (elem && elem.length) { this.elementType = elem.attr('type'); this.originalElement = elem; this.elem = getAnchorElement(elem); this.elem.data(pluginClassName, this); this.elem.before(this.wrapper); } this.container.hide(); this.run(data); } Notification.prototype.loadHTML = function() { var style; style = this.getStyle(); this.userContainer = $(style.html); this.text = this.userContainer.find('[data-notify-text]'); if (this.text.length === 0) { this.text = this.userContainer.find('[data-notify-html]'); this.rawHTML = true; } if (this.text.length === 0) { throw "style: '" + name + "' HTML is missing a: 'data-notify-text' or 'data-notify-html' attribute"; } return this.text.addClass("" + pluginClassName + "-text"); }; Notification.prototype.show = function(show, userCallback) { var args, callback, elems, fn, hidden, _this = this; callback = function() { if (!show && !_this.elem) { _this.destroy(); } if (userCallback) { return userCallback(); } }; hidden = this.container.parent().parents(':hidden').length > 0; elems = this.container.add(this.arrow); args = []; if (hidden && show) { fn = 'show'; } else if (hidden && !show) { fn = 'hide'; } else if (!hidden && show) { fn = this.options.showAnimation; args.push(this.options.showDuration); } else if (!hidden && !show) { fn = this.options.hideAnimation; args.push(this.options.hideDuration); } else { return callback(); } args.push(callback); return elems[fn].apply(elems, args); }; Notification.prototype.setGlobalPosition = function() { var align, anchor, css, key, main, pAlign, pMain, position; position = this.getPosition(); pMain = position[0], pAlign = position[1]; main = positions[pMain]; align = positions[pAlign]; key = pMain + "|" + pAlign; anchor = globalAnchors[key]; if (!anchor) { anchor = globalAnchors[key] = createElem("div"); css = {}; css[main] = 0; if (align === 'middle') { css.top = '45%'; } else if (align === 'center') { css.left = '45%'; } else { css[align] = 0; } anchor.css(css).addClass("" + pluginClassName + "-corner"); $("body").append(anchor); } return anchor.prepend(this.wrapper); }; Notification.prototype.setElementPosition = function() { var arrowColor, arrowCss, arrowSize, color, contH, contW, css, elemH, elemIH, elemIW, elemPos, elemW, gap, mainFull, margin, opp, oppFull, pAlign, pArrow, pMain, pos, posFull, position, wrapPos, _i, _j, _len, _len1, _ref; position = this.getPosition(); pMain = position[0], pAlign = position[1], pArrow = position[2]; elemPos = this.elem.position(); elemH = this.elem.outerHeight(); elemW = this.elem.outerWidth(); elemIH = this.elem.innerHeight(); elemIW = this.elem.innerWidth(); wrapPos = this.wrapper.position(); contH = this.container.height(); contW = this.container.width(); mainFull = positions[pMain]; opp = opposites[pMain]; oppFull = positions[opp]; css = {}; css[oppFull] = pMain === 'b' ? elemH : pMain === 'r' ? elemW : 0; incr(css, 'top', elemPos.top - wrapPos.top); incr(css, 'left', elemPos.left - wrapPos.left); _ref = ['top', 'left']; for (_i = 0, _len = _ref.length; _i < _len; _i++) { pos = _ref[_i]; margin = parseInt(this.elem.css("margin-" + pos), 10); if (margin) { incr(css, pos, margin); } } gap = Math.max(0, this.options.gap - (this.options.arrowShow ? arrowSize : 0)); incr(css, oppFull, gap); if (!this.options.arrowShow) { this.arrow.hide(); } else { arrowSize = this.options.arrowSize; arrowCss = $.extend({}, css); arrowColor = this.userContainer.css("border-color") || this.userContainer.css("background-color") || 'white'; for (_j = 0, _len1 = mainPositions.length; _j < _len1; _j++) { pos = mainPositions[_j]; posFull = positions[pos]; if (pos === opp) { continue; } color = posFull === mainFull ? arrowColor : 'transparent'; arrowCss["border-" + posFull] = "" + arrowSize + "px solid " + color; } incr(css, positions[opp], arrowSize); if (__indexOf.call(mainPositions, pAlign) >= 0) { incr(arrowCss, positions[pAlign], arrowSize * 2); } } if (__indexOf.call(vAligns, pMain) >= 0) { incr(css, 'left', realign(pAlign, contW, elemW)); if (arrowCss) { incr(arrowCss, 'left', realign(pAlign, arrowSize, elemIW)); } } else if (__indexOf.call(hAligns, pMain) >= 0) { incr(css, 'top', realign(pAlign, contH, elemH)); if (arrowCss) { incr(arrowCss, 'top', realign(pAlign, arrowSize, elemIH)); } } if (this.container.is(":visible")) { css.display = 'block'; } this.container.removeAttr('style').css(css); if (arrowCss) { return this.arrow.removeAttr('style').css(arrowCss); } }; Notification.prototype.getPosition = function() { var pos, text, _ref, _ref1, _ref2, _ref3, _ref4, _ref5; text = this.options.position || (this.elem ? this.options.elementPosition : this.options.globalPosition); pos = parsePosition(text); if (pos.length === 0) { pos[0] = 'b'; } if (_ref = pos[0], __indexOf.call(mainPositions, _ref) < 0) { throw "Must be one of [" + mainPositions + "]"; } if (pos.length === 1 || ((_ref1 = pos[0], __indexOf.call(vAligns, _ref1) >= 0) && (_ref2 = pos[1], __indexOf.call(hAligns, _ref2) < 0)) || ((_ref3 = pos[0], __indexOf.call(hAligns, _ref3) >= 0) && (_ref4 = pos[1], __indexOf.call(vAligns, _ref4) < 0))) { pos[1] = (_ref5 = pos[0], __indexOf.call(hAligns, _ref5) >= 0) ? 'm' : 'l'; } if (pos.length === 2) { pos[2] = pos[1]; } return pos; }; Notification.prototype.getStyle = function(name) { var style; if (!name) { name = this.options.style; } if (!name) { name = 'default'; } style = styles[name]; if (!style) { throw "Missing style: " + name; } return style; }; Notification.prototype.updateClasses = function() { var classes, style; classes = ['base']; if ($.isArray(this.options.className)) { classes = classes.concat(this.options.className); } else if (this.options.className) { classes.push(this.options.className); } style = this.getStyle(); classes = $.map(classes, function(n) { return "" + pluginClassName + "-" + style.name + "-" + n; }).join(' '); return this.userContainer.attr('class', classes); }; Notification.prototype.run = function(data, options) { var _this = this; if ($.isPlainObject(options)) { $.extend(this.options, options); } else if ($.type(options) === 'string') { this.options.color = options; } if (this.container && !data) { this.show(false); return; } else if (!this.container && !data) { return; } this.text[this.rawHTML ? 'html' : 'text'](data); this.updateClasses(); if (this.elem) { this.setElementPosition(); } else { this.setGlobalPosition(); } this.show(true); if (this.options.autoHide) { clearTimeout(this.autohideTimer); return this.autohideTimer = setTimeout(function() { return _this.show(false); }, this.options.autoHideDelay); } }; Notification.prototype.destroy = function() { return this.wrapper.remove(); }; return Notification; })(); $[pluginName] = function(elem, data, options) { if ((elem && elem.nodeName) || elem.jquery) { $(elem)[pluginName](data, options); } else { options = data; data = elem; new Notification(null, data, options); } return elem; }; $.fn[pluginName] = function(data, options) { $(this).each(function() { var inst; inst = getAnchorElement($(this)).data(pluginClassName); if (inst) { return inst.run(data, options); } else { return new Notification($(this), data, options); } }); return this; }; $.extend($[pluginName], { defaults: defaults, addStyle: addStyle, pluginOptions: pluginOptions, getStyle: getStyle, insertCSS: insertCSS }); $(function() { insertCSS(coreStyle.css).attr('id', 'core-notify'); return $(document).on('click notify-hide', "." + pluginClassName + "-wrapper", function(e) { var inst; inst = $(this).data(pluginClassName); if (inst && (inst.options.clickToHide || e.type === 'notify-hide')) { return inst.show(false); } }); }); }(window,document)); $.notify.addStyle("bootstrap", { html: "
\n\n
", classes: { base: { "font-weight": "bold", "padding": "8px 15px 8px 14px", "text-shadow": "0 1px 0 rgba(255, 255, 255, 0.5)", "background-color": "#fcf8e3", "border": "1px solid #fbeed5", "border-radius": "4px", "white-space": "nowrap", "padding-left": "25px", "background-repeat": "no-repeat", "background-position": "3px 7px" }, error: { "color": "#B94A48", "background-color": "#F2DEDE", "border-color": "#EED3D7", "background-image": "url()" }, success: { "color": "#468847", "background-color": "#DFF0D8", "border-color": "#D6E9C6", "background-image": "url()" }, info: { "color": "#3A87AD", "background-color": "#D9EDF7", "border-color": "#BCE8F1", "background-image": "url()" }, warn: { "color": "#C09853", "background-color": "#FCF8E3", "border-color": "#FBEED5", "background-image": "url()" } } }); (function($) { if(window.console === undefined) window.console = { isFake: true }; var fns = ["log","warn","info","group","groupCollapsed","groupEnd"]; for (var i = fns.length - 1; i >= 0; i--) if(window.console[fns[i]] === undefined) window.console[fns[i]] = $.noop; if(!$) return; var I = function(i){ return i; }; function log() { if(this.suppressLog) return; cons('log', this, arguments); } function warn() { cons('warn', this, arguments); } function info() { cons('info', this, arguments); } function cons(type, opts, args) { if(window.console === undefined || window.console.isFake === true) return; var a = $.map(args,I); a[0] = [opts.prefix, a[0], opts.postfix].join(''); var grp = $.type(a[a.length-1]) === 'boolean' ? a.pop() : null; //if(a[0]) a[0] = getName(this) + a[0]; if(grp === true) window.console.group(a[0]); if(a[0] && grp === null) if(window.navigator.userAgent.indexOf("MSIE") >= 0) window.console.log(a.join(',')); else window.console[type].apply(window.console, a); if(grp === false) window.console.groupEnd(); } function withOptions(opts) { return { log: function() { log.apply(opts, arguments); }, warn: function() { warn.apply(opts, arguments); }, info: function() { info.apply(opts, arguments); } }; } var console = function(opts) { opts = $.extend({}, console.defaults, opts); return withOptions(opts); }; console.defaults = { suppressLog: false, prefix: '', postfix: '' }; $.extend(console, withOptions(console.defaults)); if($.console === undefined) $.console = console; $.consoleNoConflict = console; }(jQuery)); //plugin wide ajax cache var ajaxCache = { loading: {}, loaded: {} } ; //callable from user defined rules. alias: r.ajax function ajaxHelper(userOpts, r) { var defaults = { method: "GET", timeout: 15 * 1000 }, exec = r._exec, promptContainer = exec.type === "GroupRuleExecution" ? exec.element.domElem : r.field, userSuccess = userOpts.success, userError = userOpts.error, options = exec.element.options, serialised = JSON ? JSON.stringify(userOpts) : guid(); function onErrorDefault(e) { log("ajax error"); r.callback("There has been an error"); } var userCallbacks = { success: userSuccess, error: userError || onErrorDefault }; //already completed if(ajaxCache.loaded[serialised]) { var args = ajaxCache.loaded[serialised], success = userCallbacks.success; success.apply(r, args); return; } //this request is in progress, //store callbacks for when first request completes if(!ajaxCache.loading[serialised]) ajaxCache.loading[serialised] = []; ajaxCache.loading[serialised].push(userCallbacks); if(ajaxCache.loading[serialised].length !== 1) return; options.prompt(promptContainer, "Checking...", "load"); function intercept() { options.prompt(promptContainer, false); var reqs = ajaxCache.loading[serialised]; while(reqs.length) reqs.pop().success.apply(r,arguments); ajaxCache.loaded[serialised] = arguments; } var realCallbacks = { success: intercept, error: intercept }; exec.ajax = $.ajax($.extend(defaults, userOpts, realCallbacks)); } // var guid = function() { // return (((1 + Math.random()) * 65536) | 0).toString(16).substring(1); // }; var guid = function() { return guid.curr++; }; guid.curr = 1; $.fn.verifyScrollView = function(onComplete) { var field = $(this).first(); if(field.length !== 1) return $(this); return $(this).verifyScrollTo(field, onComplete); }; $.fn.verifyScrollTo = function( target, options, callback ){ if(typeof options == 'function' && arguments.length == 2){ callback = options; options = target; } var settings = $.extend({ scrollTarget : target, offsetTop : 50, duration : 500, easing : 'swing' }, options); return this.each(function(){ var scrollPane = $(this); var scrollTarget = (typeof settings.scrollTarget == "number") ? settings.scrollTarget : $(settings.scrollTarget); var scrollY = (typeof scrollTarget == "number") ? scrollTarget : scrollTarget.offset().top + scrollPane.scrollTop() - parseInt(settings.offsetTop, 10); scrollPane.animate({scrollTop : scrollY }, parseInt(settings.duration, 10), settings.easing, function(){ if (typeof callback == 'function') { callback.call(this); } }); }); }; $.fn.equals = function(that) { if($(this).length !== that.length) return false; for(var i=0,l=$(this).length;i