From 98013543d9bb0c51e05236498bf4fbc92af678e1 Mon Sep 17 00:00:00 2001 From: Brandon Mathis Date: Sat, 9 Mar 2013 17:14:33 -0600 Subject: [PATCH] Removed Twitter and Ender.js. Added jQuery and updated Modernizr --- .themes/classic/sass/base/_theme.scss | 1 - .themes/classic/sass/base/_typography.scss | 5 +- .themes/classic/sass/partials/_sidebar.scss | 1 - .../sass/partials/sidebar/_twitter.scss | 34 - .../source/_includes/asides/github.html | 2 +- .../source/_includes/asides/twitter.html | 19 - .themes/classic/source/_includes/head.html | 7 +- .themes/classic/source/javascripts/ender.js | 45 - .../classic/source/javascripts/libs/ender.js | 3256 ----------------- .../source/javascripts/libs/jquery.min.js | 5 + .../source/javascripts/modernizr-2.0.js | 8 +- .../classic/source/javascripts/octopress.js | 7 +- README.markdown | 2 +- 13 files changed, 22 insertions(+), 3370 deletions(-) delete mode 100644 .themes/classic/sass/partials/sidebar/_twitter.scss delete mode 100644 .themes/classic/source/_includes/asides/twitter.html delete mode 100644 .themes/classic/source/javascripts/ender.js delete mode 100644 .themes/classic/source/javascripts/libs/ender.js create mode 100644 .themes/classic/source/javascripts/libs/jquery.min.js diff --git a/.themes/classic/sass/base/_theme.scss b/.themes/classic/sass/base/_theme.scss index 9a50a8b..1a43a03 100644 --- a/.themes/classic/sass/base/_theme.scss +++ b/.themes/classic/sass/base/_theme.scss @@ -44,7 +44,6 @@ $sidebar-border: desaturate(darken($sidebar-bg, 7), 10) !default; $sidebar-border-hover: darken($sidebar-bg, 7) !default; $sidebar-link-color-subdued: lighten($sidebar-color, 20) !default; $sidebar-link-color-subdued-hover: $sidebar-link-color-hover !default; -$twitter-status-link: lighten($sidebar-link-color-subdued, 15) !default; $footer-color: #888 !default; $footer-bg: #ccc !default; diff --git a/.themes/classic/sass/base/_typography.scss b/.themes/classic/sass/base/_typography.scss index e9b6b19..85256f0 100644 --- a/.themes/classic/sass/base/_typography.scss +++ b/.themes/classic/sass/base/_typography.scss @@ -62,7 +62,8 @@ h5, section h4, section section h3 { h6, section h5, section section h4, section section section h3 { font-size: .8em; } -p, blockquote, ul, ol { margin-bottom: 1.5em; } + +p, article blockquote, ul, ol { margin-bottom: 1.5em; } ul { list-style-type: disc; ul { list-style-type: circle; margin-bottom: 0px; @@ -106,7 +107,7 @@ small { font-size: .8em; } big { font-size: 1.2em; } -blockquote { +article blockquote { $bq-margin: 1.2em; font-style: italic; position: relative; diff --git a/.themes/classic/sass/partials/_sidebar.scss b/.themes/classic/sass/partials/_sidebar.scss index eec540b..cd8c1ca 100644 --- a/.themes/classic/sass/partials/_sidebar.scss +++ b/.themes/classic/sass/partials/_sidebar.scss @@ -1,5 +1,4 @@ @import "sidebar/base"; -@import "sidebar/twitter"; @import "sidebar/googleplus"; @import "sidebar/pinboard"; @import "sidebar/delicious"; diff --git a/.themes/classic/sass/partials/sidebar/_twitter.scss b/.themes/classic/sass/partials/sidebar/_twitter.scss deleted file mode 100644 index dfd49b5..0000000 --- a/.themes/classic/sass/partials/sidebar/_twitter.scss +++ /dev/null @@ -1,34 +0,0 @@ -#tweets { - .loading { - background: inline-image('bird_32_gray.png') no-repeat center .5em; - color: darken($sidebar-bg, 18); - text-shadow: $main-bg 0 1px; - text-align: center; - padding: 2.5em 0 .5em; - &.error { - background: inline-image('bird_32_gray_fail.png') no-repeat center .5em; - } - } - p { - position: relative; - padding-right: 1em; - } - a[href*=status]:first-child { - color: $twitter-status-link; - float: right; - padding: 0 0 .1em 1em; - position: relative; right: -1.3em; - text-shadow: #fff 0 1px; - font-size: .7em; - span { font-size: 1.5em; } - text-decoration: none; - &:hover { - color: $sidebar-link-color-subdued-hover; - text-decoration: none; - } - } - a[href*='twitter.com/search']{ - @extend .aside-alt-link; - @include hover-link; - } -} diff --git a/.themes/classic/source/_includes/asides/github.html b/.themes/classic/source/_includes/asides/github.html index cb267f0..b0bf959 100644 --- a/.themes/classic/source/_includes/asides/github.html +++ b/.themes/classic/source/_includes/asides/github.html @@ -8,7 +8,7 @@ @{{site.github_user}} on GitHub {% endif %} - - {% if site.twitter_follow_button %} - Follow @{{ site.twitter_user }} - {% else %} -

Follow @{{ site.twitter_user }}

- {% endif %} - -{% endif %} diff --git a/.themes/classic/source/_includes/head.html b/.themes/classic/source/_includes/head.html index 8de6679..7a727b2 100644 --- a/.themes/classic/source/_includes/head.html +++ b/.themes/classic/source/_includes/head.html @@ -16,14 +16,15 @@ - {% capture canonical %}{{ site.url }}{% if site.permalink contains '.html' %}{{ page.url }}{% else %}{% if page.url contains site.category_dir %}/{% endif %}{{ page.url | remove:'index.html' }}{% endif %}{% endcapture %} + {% capture canonical %}{{ site.url }}{% if site.permalink contains '.html' %}{{ page.url }}{% else %}{{ page.url | remove:'index.html' | strip_slash }}{% endif %}{% endcapture %} - {% include custom/head.html %} - + + + {% include custom/head.html %} {% include google_analytics.html %} diff --git a/.themes/classic/source/javascripts/ender.js b/.themes/classic/source/javascripts/ender.js deleted file mode 100644 index 6d9c66e..0000000 --- a/.themes/classic/source/javascripts/ender.js +++ /dev/null @@ -1,45 +0,0 @@ -/*! - * ============================================================= - * Ender: open module JavaScript framework (https://ender.no.de) - * Build: ender build jeesh reqwest - * ============================================================= - */ - - -/*! - * Ender: open module JavaScript framework (client-lib) - * copyright Dustin Diaz & Jacob Thornton 2011-2012 (@ded @fat) - * http://ender.jit.su - * License MIT - */ -(function(context){function require(identifier){var module=modules["$"+identifier]||window[identifier];if(!module)throw new Error("Ender Error: Requested module '"+identifier+"' has not been defined.");return module}function provide(name,what){return modules["$"+name]=what}function aug(o,o2){for(var k in o2)k!="noConflict"&&k!="_VERSION"&&(o[k]=o2[k]);return o}function Ender(s,r){var elements,i;this.selector=s;if(typeof s=="undefined"){elements=[];this.selector=""}else typeof s=="string"||s.nodeName||s.length&&"item"in s||s==window?elements=ender._select(s,r):elements=isFinite(s.length)?s:[s];this.length=elements.length;for(i=this.length;i--;)this[i]=elements[i]}function ender(s,r){return new Ender(s,r)}context.global=context;var modules={},old=context.$,oldEnder=context.ender,oldRequire=context.require,oldProvide=context.provide;context.provide=provide;context.require=require;Ender.prototype.forEach=function(fn,opt_scope){var i,l;for(i=0,l=this.length;i0)self._completeHandlers.shift()(resp)}function success(resp){var r=resp.responseText;if(r)switch(type){case"json":try{resp=win.JSON?win.JSON.parse(r):eval("("+r+")")}catch(err){return error(resp,"Could not parse JSON in response",err)}break;case"js":resp=eval(r);break;case"html":resp=r;break;case"xml":resp=resp.responseXML}self._responseArgs.resp=resp;self._fulfilled=!0;fn(resp);while(self._fulfillmentHandlers.length>0)self._fulfillmentHandlers.shift()(resp);complete(resp)}function error(resp,msg,t){self._responseArgs.resp=resp;self._responseArgs.msg=msg;self._responseArgs.t=t;self._erred=!0;while(self._errorHandlers.length>0)self._errorHandlers.shift()(resp,msg,t);complete(resp)}this.url=typeof o=="string"?o:o.url;this.timeout=null;this._fulfilled=!1;this._fulfillmentHandlers=[];this._errorHandlers=[];this._completeHandlers=[];this._erred=!1;this._responseArgs={};var self=this,type=o.type||setType(this.url);fn=fn||function(){};o.timeout&&(this.timeout=setTimeout(function(){self.abort()},o.timeout));o.success&&this._fulfillmentHandlers.push(function(){o.success.apply(o,arguments)});o.error&&this._errorHandlers.push(function(){o.error.apply(o,arguments)});o.complete&&this._completeHandlers.push(function(){o.complete.apply(o,arguments)});this.request=getRequest(o,success,error)}function reqwest(o,fn){return new Reqwest(o,fn)}function normalize(s){return s?s.replace(/\r?\n/g,"\r\n"):""}function serial(el,cb){var n=el.name,t=el.tagName.toLowerCase(),optCb=function(o){o&&!o.disabled&&cb(n,normalize(o.attributes.value&&o.attributes.value.specified?o.value:o.text))};if(el.disabled||!n)return;switch(t){case"input":if(!/reset|button|image|file/i.test(el.type)){var ch=/checkbox/i.test(el.type),ra=/radio/i.test(el.type),val=el.value;(!ch&&!ra||el.checked)&&cb(n,normalize(ch&&val===""?"on":val))}break;case"textarea":cb(n,normalize(el.value));break;case"select":if(el.type.toLowerCase()==="select-one")optCb(el.selectedIndex>=0?el.options[el.selectedIndex]:null);else for(var i=0;el.length&&i0){typeSpec=str2arr(typeSpec);for(i=typeSpec.length;i--;)off(element,typeSpec[i],fn);return element}type=isTypeStr&&typeSpec.replace(nameRegex,"");type&&customEvents[type]&&(type=customEvents[type].base);if(!typeSpec||isTypeStr){if(namespaces=isTypeStr&&typeSpec.replace(namespaceRegex,""))namespaces=str2arr(namespaces,".");removeListener(element,type,fn,namespaces)}else if(isFunction(typeSpec))removeListener(element,null,typeSpec);else for(k in typeSpec)typeSpec.hasOwnProperty(k)&&off(element,k,typeSpec[k]);return element},on=function(element,events,selector,fn){var originalFn,type,types,i,args,entry,first;if(selector===undefined&&typeof events=="object"){for(type in events)events.hasOwnProperty(type)&&on.call(this,element,type,events[type]);return}if(!isFunction(selector)){originalFn=fn;args=slice.call(arguments,4);fn=delegate(selector,originalFn,selectorEngine)}else{args=slice.call(arguments,3);fn=originalFn=selector}types=str2arr(events);this===ONE&&(fn=once(off,element,events,fn,originalFn));for(i=types.length;i--;){first=registry.put(entry=new RegEntry(element,types[i].replace(nameRegex,""),fn,originalFn,str2arr(types[i].replace(namespaceRegex,""),"."),args,!1));entry[eventSupport]&&first&&listener(element,entry.eventType,!0,entry.customType)}return element},add=function(element,events,fn,delfn){return on.apply(null,isString(fn)?[element,fn,events,delfn].concat(arguments.length>3?slice.call(arguments,5):[]):slice.call(arguments))},one=function(){return on.apply(ONE,arguments)},fire=function(element,type,args){var types=str2arr(type),i,j,l,names,handlers;for(i=types.length;i--;){type=types[i].replace(nameRegex,"");if(names=types[i].replace(namespaceRegex,""))names=str2arr(names,".");if(!names&&!args&&element[eventSupport])fireListener(nativeEvents[type],type,element);else{handlers=registry.get(element,type,null,!1);args=[!1].concat(args);for(j=0,l=handlers.length;j0?cloneNode(self,el):el)},null,rev)},this,rev);self.length=i;each(r,function(e){self[--i]=e},null,!rev);return self}function xy(el,x,y){var $el=bonzo(el),style=$el.css("position"),offset=$el.offset(),rel="relative",isRel=style==rel,delta=[parseInt($el.css("left"),10),parseInt($el.css("top"),10)];if(style=="static"){$el.css("position",rel);style=rel}isNaN(delta[0])&&(delta[0]=isRel?0:el.offsetLeft);isNaN(delta[1])&&(delta[1]=isRel?0:el.offsetTop);x!=null&&(el.style.left=x-offset.left+delta[0]+px);y!=null&&(el.style.top=y-offset.top+delta[1]+px)}function setter(el,v){return typeof v=="function"?v(el):v}function Bonzo(elements){this.length=0;if(elements){elements=typeof elements!="string"&&!elements.nodeType&&typeof elements.length!="undefined"?elements:[elements];this.length=elements.length;for(var i=0;i/,table=["","
",1],td=["","
",3],option=["",1],noscope=["_","",0,1],tagMap={thead:table,tbody:table,tfoot:table,colgroup:table,caption:table,tr:["","
",2],th:td,td:td,col:["","
",2],fieldset:["
","
",1],legend:["
","
",2],option:option,optgroup:option,script:noscope,style:noscope,link:noscope,param:noscope,base:noscope},stateAttributes=/^(checked|selected|disabled)$/,ie=/msie/i.test(navigator.userAgent),hasClass,addClass,removeClass,uidMap={},uuids=0,digit=/^-?[\d\.]+$/,dattr=/^data-(.+)$/,px="px",setAttribute="setAttribute",getAttribute="getAttribute",byTag="getElementsByTagName",features=function(){var e=doc.createElement("p");e.innerHTML='x
';return{hrefExtended:e[byTag]("a")[0][getAttribute]("href")!="#x",autoTbody:e[byTag]("tbody").length!==0,computedStyle:doc.defaultView&&doc.defaultView.getComputedStyle,cssFloat:e[byTag]("table")[0].style.styleFloat?"styleFloat":"cssFloat",transform:function(){var props=["transform","webkitTransform","MozTransform","OTransform","msTransform"],i;for(i=0;i]+)/),el=doc.createElement("div"),els=[],p=tag?tagMap[tag[1].toLowerCase()]:null,dep=p?p[2]+1:1,ns=p&&p[3],pn=parentNode,tb=features.autoTbody&&p&&p[0]==""&&!/~+]/,normalizr=/^\s+|\s*([,\s\+\~>]|$)\s*/g,splitters=/[\s\>\+\~]/,splittersMore=/(?![\s\w\-\/\?\&\=\:\.\(\)\!,@#%<>\{\}\$\*\^'"]*\]|[\s\w\+\-]*\))/,specialChars=/([.*+?\^=!:${}()|\[\]\/\\])/g,simple=/^(\*|[a-z0-9]+)?(?:([\.\#]+[\w\-\.#]+)?)/,attr=/\[([\w\-]+)(?:([\|\^\$\*\~]?\=)['"]?([ \w\-\/\?\&\=\:\.\(\)\!,@#%<>\{\}\$\*\^]+)["']?)?\]/,pseudo=/:([\w\-]+)(\(['"]?([^()]+)['"]?\))?/,easy=new RegExp(idOnly.source+"|"+tagOnly.source+"|"+classOnly.source),dividers=new RegExp("("+splitters.source+")"+splittersMore.source,"g"),tokenizr=new RegExp(splitters.source+splittersMore.source),chunker=new RegExp(simple.source+"("+attr.source+")?"+"("+pseudo.source+")?"),walker={" ":function(node){return node&&node!==html&&node.parentNode},">":function(node,contestant){return node&&node.parentNode==contestant.parentNode&&node.parentNode},"~":function(node){return node&&node.previousSibling},"+":function(node,contestant,p1,p2){return node?(p1=previous(node))&&(p2=previous(contestant))&&p1==p2&&p1:!1}};cache.prototype={g:function(k){return this.c[k]||undefined},s:function(k,v,r){v=r?new RegExp(v):v;return this.c[k]=v}};var classCache=new cache,cleanCache=new cache,attrCache=new cache,tokenCache=new cache,isAncestor="compareDocumentPosition"in html?function(element,container){return(container.compareDocumentPosition(element)&16)==16}:"contains"in html?function(element,container){container=container[nodeType]===9||container==window?html:container;return container!==element&&container.contains(element)}:function(element,container){while(element=element.parentNode)if(element===container)return 1;return 0},getAttr=function(){var e=doc.createElement("p");return(e.innerHTML='x')&&e.firstChild.getAttribute("href")!="#x"?function(e,a){return a==="class"?e.className:a==="href"||a==="src"?e.getAttribute(a,2):e.getAttribute(a)}:function(e,a){return e.getAttribute(a)}}(),hasByClass=!!doc[byClass],hasQSA=doc.querySelector&&doc[qSA],selectQSA=function(selector,root){var result=[],ss,e;try{if(root[nodeType]===9||!splittable.test(selector))return arrayify(root[qSA](selector));each(ss=selector.split(","),collectSelector(root,function(ctx,s){e=ctx[qSA](s);e.length==1?result[result.length]=e.item(0):e.length&&(result=result.concat(arrayify(e)))}));return ss.length>1&&result.length>1?uniq(result):result}catch(ex){}return selectNonNative(selector,root)},selectNonNative=function(selector,root){var result=[],items,m,i,l,r,ss;selector=selector.replace(normalizr,"$1");if(m=selector.match(tagAndOrClass)){r=classRegex(m[2]);items=root[byTag](m[1]||"*");for(i=0,l=items.length;i1&&result.length>1?uniq(result):result},configure=function(options){typeof options[useNativeQSA]!="undefined"&&(select=options[useNativeQSA]?hasQSA?selectQSA:selectNonNative:selectNonNative)};configure({useNativeQSA:!0});qwery.configure=configure;qwery.uniq=uniq;qwery.is=is;qwery.pseudos={};return qwery});provide("qwery",module.exports);(function($){var q=function(){var r;try{r=require("qwery")}catch(ex){r=require("qwery-mobile")}finally{return r}}();$.pseudos=q.pseudos;$._select=function(s,r){return($._select=function(){var b;if(typeof $.create=="function")return function(s,r){return/^\s* 0) { - self._completeHandlers.shift()(resp) - } - } - - function success(resp) { - var r = resp.responseText - if (r) { - switch (type) { - case 'json': - try { - resp = win.JSON ? win.JSON.parse(r) : eval('(' + r + ')') - } catch (err) { - return error(resp, 'Could not parse JSON in response', err) - } - break; - case 'js': - resp = eval(r) - break; - case 'html': - resp = r - break; - case 'xml': - resp = resp.responseXML; - break; - } - } - - self._responseArgs.resp = resp - self._fulfilled = true - fn(resp) - while (self._fulfillmentHandlers.length > 0) { - self._fulfillmentHandlers.shift()(resp) - } - - complete(resp) - } - - function error(resp, msg, t) { - self._responseArgs.resp = resp - self._responseArgs.msg = msg - self._responseArgs.t = t - self._erred = true - while (self._errorHandlers.length > 0) { - self._errorHandlers.shift()(resp, msg, t) - } - complete(resp) - } - - this.request = getRequest(o, success, error) - } - - Reqwest.prototype = { - abort: function () { - this.request.abort() - } - - , retry: function () { - init.call(this, this.o, this.fn) - } - - /** - * Small deviation from the Promises A CommonJs specification - * http://wiki.commonjs.org/wiki/Promises/A - */ - - /** - * `then` will execute upon successful requests - */ - , then: function (success, fail) { - if (this._fulfilled) { - success(this._responseArgs.resp) - } else if (this._erred) { - fail(this._responseArgs.resp, this._responseArgs.msg, this._responseArgs.t) - } else { - this._fulfillmentHandlers.push(success) - this._errorHandlers.push(fail) - } - return this - } - - /** - * `always` will execute whether the request succeeds or fails - */ - , always: function (fn) { - if (this._fulfilled || this._erred) { - fn(this._responseArgs.resp) - } else { - this._completeHandlers.push(fn) - } - return this - } - - /** - * `fail` will execute when the request fails - */ - , fail: function (fn) { - if (this._erred) { - fn(this._responseArgs.resp, this._responseArgs.msg, this._responseArgs.t) - } else { - this._errorHandlers.push(fn) - } - return this - } - } - - function reqwest(o, fn) { - return new Reqwest(o, fn) - } - - // normalize newline variants according to spec -> CRLF - function normalize(s) { - return s ? s.replace(/\r?\n/g, '\r\n') : '' - } - - function serial(el, cb) { - var n = el.name - , t = el.tagName.toLowerCase() - , optCb = function (o) { - // IE gives value="" even where there is no value attribute - // 'specified' ref: http://www.w3.org/TR/DOM-Level-3-Core/core.html#ID-862529273 - if (o && !o.disabled) - cb(n, normalize(o.attributes.value && o.attributes.value.specified ? o.value : o.text)) - } - - // don't serialize elements that are disabled or without a name - if (el.disabled || !n) return; - - switch (t) { - case 'input': - if (!/reset|button|image|file/i.test(el.type)) { - var ch = /checkbox/i.test(el.type) - , ra = /radio/i.test(el.type) - , val = el.value; - // WebKit gives us "" instead of "on" if a checkbox has no value, so correct it here - (!(ch || ra) || el.checked) && cb(n, normalize(ch && val === '' ? 'on' : val)) - } - break; - case 'textarea': - cb(n, normalize(el.value)) - break; - case 'select': - if (el.type.toLowerCase() === 'select-one') { - optCb(el.selectedIndex >= 0 ? el.options[el.selectedIndex] : null) - } else { - for (var i = 0; el.length && i < el.length; i++) { - el.options[i].selected && optCb(el.options[i]) - } - } - break; - } - } - - // collect up all form elements found from the passed argument elements all - // the way down to child elements; pass a '
' or form fields. - // called with 'this'=callback to use for serial() on each element - function eachFormElement() { - var cb = this - , e, i, j - , serializeSubtags = function (e, tags) { - for (var i = 0; i < tags.length; i++) { - var fa = e[byTag](tags[i]) - for (j = 0; j < fa.length; j++) serial(fa[j], cb) - } - } - - for (i = 0; i < arguments.length; i++) { - e = arguments[i] - if (/input|select|textarea/i.test(e.tagName)) serial(e, cb) - serializeSubtags(e, [ 'input', 'select', 'textarea' ]) - } - } - - // standard query string style serialization - function serializeQueryString() { - return reqwest.toQueryString(reqwest.serializeArray.apply(null, arguments)) - } - - // { 'name': 'value', ... } style serialization - function serializeHash() { - var hash = {} - eachFormElement.apply(function (name, value) { - if (name in hash) { - hash[name] && !isArray(hash[name]) && (hash[name] = [hash[name]]) - hash[name].push(value) - } else hash[name] = value - }, arguments) - return hash - } - - // [ { name: 'name', value: 'value' }, ... ] style serialization - reqwest.serializeArray = function () { - var arr = [] - eachFormElement.apply(function (name, value) { - arr.push({name: name, value: value}) - }, arguments) - return arr - } - - reqwest.serialize = function () { - if (arguments.length === 0) return '' - var opt, fn - , args = Array.prototype.slice.call(arguments, 0) - - opt = args.pop() - opt && opt.nodeType && args.push(opt) && (opt = null) - opt && (opt = opt.type) - - if (opt == 'map') fn = serializeHash - else if (opt == 'array') fn = reqwest.serializeArray - else fn = serializeQueryString - - return fn.apply(null, args) - } - - reqwest.toQueryString = function (o) { - var qs = '', i - , enc = encodeURIComponent - , push = function (k, v) { - qs += enc(k) + '=' + enc(v) + '&' - } - - if (isArray(o)) { - for (i = 0; o && i < o.length; i++) push(o[i].name, o[i].value) - } else { - for (var k in o) { - if (!Object.hasOwnProperty.call(o, k)) continue; - var v = o[k] - if (isArray(v)) { - for (i = 0; i < v.length; i++) push(k, v[i]) - } else push(k, o[k]) - } - } - - // spaces should be + according to spec - return qs.replace(/&$/, '').replace(/%20/g, '+') - } - - reqwest.getcallbackPrefix = function (reqId) { - return callbackPrefix - } - - // jQuery and Zepto compatibility, differences can be remapped here so you can call - // .ajax.compat(options, callback) - reqwest.compat = function (o, fn) { - if (o) { - o.type && (o.method = o.type) && delete o.type - o.dataType && (o.type = o.dataType) - o.jsonpCallback && (o.jsonpCallbackName = o.jsonpCallback) && delete o.jsonpCallback - o.jsonp && (o.jsonpCallback = o.jsonp) - } - return new Reqwest(o, fn) - } - - return reqwest - }); - - - provide("reqwest", module.exports); - - !function ($) { - var r = require('reqwest') - , integrate = function(method) { - return function() { - var args = Array.prototype.slice.call(arguments, 0) - , i = (this && this.length) || 0 - while (i--) args.unshift(this[i]) - return r[method].apply(null, args) - } - } - , s = integrate('serialize') - , sa = integrate('serializeArray') - - $.ender({ - ajax: r - , serialize: r.serialize - , serializeArray: r.serializeArray - , toQueryString: r.toQueryString - }) - - $.ender({ - serialize: s - , serializeArray: sa - }, true) - }(ender); - - -}()); - -(function () { - - var module = { exports: {} }, exports = module.exports; - - /*! - * Bean - copyright (c) Jacob Thornton 2011-2012 - * https://github.com/fat/bean - * MIT license - */ - !(function (name, context, definition) { - if (typeof module != 'undefined' && module.exports) module.exports = definition(name, context); - else if (typeof define == 'function' && typeof define.amd == 'object') define(definition); - else context[name] = definition(name, context); - }('bean', this, function (name, context) { - var win = window - , old = context[name] - , namespaceRegex = /[^\.]*(?=\..*)\.|.*/ - , nameRegex = /\..*/ - , addEvent = 'addEventListener' - , removeEvent = 'removeEventListener' - , doc = document || {} - , root = doc.documentElement || {} - , W3C_MODEL = root[addEvent] - , eventSupport = W3C_MODEL ? addEvent : 'attachEvent' - , ONE = {} // singleton for quick matching making add() do one() - - , slice = Array.prototype.slice - , str2arr = function (s, d) { return s.split(d || ' ') } - , isString = function (o) { return typeof o == 'string' } - , isFunction = function (o) { return typeof o == 'function' } - - // events that we consider to be 'native', anything not in this list will - // be treated as a custom event - , standardNativeEvents = - 'click dblclick mouseup mousedown contextmenu ' + // mouse buttons - 'mousewheel mousemultiwheel DOMMouseScroll ' + // mouse wheel - 'mouseover mouseout mousemove selectstart selectend ' + // mouse movement - 'keydown keypress keyup ' + // keyboard - 'orientationchange ' + // mobile - 'focus blur change reset select submit ' + // form elements - 'load unload beforeunload resize move DOMContentLoaded ' + // window - 'readystatechange message ' + // window - 'error abort scroll ' // misc - // element.fireEvent('onXYZ'... is not forgiving if we try to fire an event - // that doesn't actually exist, so make sure we only do these on newer browsers - , w3cNativeEvents = - 'show ' + // mouse buttons - 'input invalid ' + // form elements - 'touchstart touchmove touchend touchcancel ' + // touch - 'gesturestart gesturechange gestureend ' + // gesture - 'textinput' + // TextEvent - 'readystatechange pageshow pagehide popstate ' + // window - 'hashchange offline online ' + // window - 'afterprint beforeprint ' + // printing - 'dragstart dragenter dragover dragleave drag drop dragend ' + // dnd - 'loadstart progress suspend emptied stalled loadmetadata ' + // media - 'loadeddata canplay canplaythrough playing waiting seeking ' + // media - 'seeked ended durationchange timeupdate play pause ratechange ' + // media - 'volumechange cuechange ' + // media - 'checking noupdate downloading cached updateready obsolete ' // appcache - - // convert to a hash for quick lookups - , nativeEvents = (function (hash, events, i) { - for (i = 0; i < events.length; i++) events[i] && (hash[events[i]] = 1) - return hash - }({}, str2arr(standardNativeEvents + (W3C_MODEL ? w3cNativeEvents : '')))) - - // custom events are events that we *fake*, they are not provided natively but - // we can use native events to generate them - , customEvents = (function () { - var isAncestor = 'compareDocumentPosition' in root - ? function (element, container) { - return container.compareDocumentPosition && (container.compareDocumentPosition(element) & 16) === 16 - } - : 'contains' in root - ? function (element, container) { - container = container.nodeType === 9 || container === window ? root : container - return container !== element && container.contains(element) - } - : function (element, container) { - while (element = element.parentNode) if (element === container) return 1 - return 0 - } - , check = function (event) { - var related = event.relatedTarget - return !related - ? related == null - : (related !== this && related.prefix !== 'xul' && !/document/.test(this.toString()) - && !isAncestor(related, this)) - } - - return { - mouseenter: { base: 'mouseover', condition: check } - , mouseleave: { base: 'mouseout', condition: check } - , mousewheel: { base: /Firefox/.test(navigator.userAgent) ? 'DOMMouseScroll' : 'mousewheel' } - } - }()) - - // we provide a consistent Event object across browsers by taking the actual DOM - // event object and generating a new one from its properties. - , Event = (function () { - // a whitelist of properties (for different event types) tells us what to check for and copy - var commonProps = str2arr('altKey attrChange attrName bubbles cancelable ctrlKey currentTarget ' + - 'detail eventPhase getModifierState isTrusted metaKey relatedNode relatedTarget shiftKey ' + - 'srcElement target timeStamp type view which propertyName') - , mouseProps = commonProps.concat(str2arr('button buttons clientX clientY dataTransfer ' + - 'fromElement offsetX offsetY pageX pageY screenX screenY toElement')) - , mouseWheelProps = mouseProps.concat(str2arr('wheelDelta wheelDeltaX wheelDeltaY wheelDeltaZ ' + - 'axis')) // 'axis' is FF specific - , keyProps = commonProps.concat(str2arr('char charCode key keyCode keyIdentifier ' + - 'keyLocation location')) - , textProps = commonProps.concat(str2arr('data')) - , touchProps = commonProps.concat(str2arr('touches targetTouches changedTouches scale rotation')) - , messageProps = commonProps.concat(str2arr('data origin source')) - , stateProps = commonProps.concat(str2arr('state')) - , overOutRegex = /over|out/ - // some event types need special handling and some need special properties, do that all here - , typeFixers = [ - { // key events - reg: /key/i - , fix: function (event, newEvent) { - newEvent.keyCode = event.keyCode || event.which - return keyProps - } - } - , { // mouse events - reg: /click|mouse(?!(.*wheel|scroll))|menu|drag|drop/i - , fix: function (event, newEvent, type) { - newEvent.rightClick = event.which === 3 || event.button === 2 - newEvent.pos = { x: 0, y: 0 } - if (event.pageX || event.pageY) { - newEvent.clientX = event.pageX - newEvent.clientY = event.pageY - } else if (event.clientX || event.clientY) { - newEvent.clientX = event.clientX + doc.body.scrollLeft + root.scrollLeft - newEvent.clientY = event.clientY + doc.body.scrollTop + root.scrollTop - } - if (overOutRegex.test(type)) { - newEvent.relatedTarget = event.relatedTarget - || event[(type == 'mouseover' ? 'from' : 'to') + 'Element'] - } - return mouseProps - } - } - , { // mouse wheel events - reg: /mouse.*(wheel|scroll)/i - , fix: function () { return mouseWheelProps } - } - , { // TextEvent - reg: /^text/i - , fix: function () { return textProps } - } - , { // touch and gesture events - reg: /^touch|^gesture/i - , fix: function () { return touchProps } - } - , { // message events - reg: /^message$/i - , fix: function () { return messageProps } - } - , { // popstate events - reg: /^popstate$/i - , fix: function () { return stateProps } - } - , { // everything else - reg: /.*/ - , fix: function () { return commonProps } - } - ] - , typeFixerMap = {} // used to map event types to fixer functions (above), a basic cache mechanism - - , Event = function (event, element, isNative) { - if (!arguments.length) return - event = event || ((element.ownerDocument || element.document || element).parentWindow || win).event - this.originalEvent = event - this.isNative = isNative - this.isBean = true - - if (!event) return - - var type = event.type - , target = event.target || event.srcElement - , i, l, p, props, fixer - - this.target = target && target.nodeType === 3 ? target.parentNode : target - - if (isNative) { // we only need basic augmentation on custom events, the rest expensive & pointless - fixer = typeFixerMap[type] - if (!fixer) { // haven't encountered this event type before, map a fixer function for it - for (i = 0, l = typeFixers.length; i < l; i++) { - if (typeFixers[i].reg.test(type)) { // guaranteed to match at least one, last is .* - typeFixerMap[type] = fixer = typeFixers[i].fix - break - } - } - } - - props = fixer(event, this, type) - for (i = props.length; i--;) { - if (!((p = props[i]) in this) && p in event) this[p] = event[p] - } - } - } - - // preventDefault() and stopPropagation() are a consistent interface to those functions - // on the DOM, stop() is an alias for both of them together - Event.prototype.preventDefault = function () { - if (this.originalEvent.preventDefault) this.originalEvent.preventDefault() - else this.originalEvent.returnValue = false - } - Event.prototype.stopPropagation = function () { - if (this.originalEvent.stopPropagation) this.originalEvent.stopPropagation() - else this.originalEvent.cancelBubble = true - } - Event.prototype.stop = function () { - this.preventDefault() - this.stopPropagation() - this.stopped = true - } - // stopImmediatePropagation() has to be handled internally because we manage the event list for - // each element - // note that originalElement may be a Bean#Event object in some situations - Event.prototype.stopImmediatePropagation = function () { - if (this.originalEvent.stopImmediatePropagation) this.originalEvent.stopImmediatePropagation() - this.isImmediatePropagationStopped = function () { return true } - } - Event.prototype.isImmediatePropagationStopped = function () { - return this.originalEvent.isImmediatePropagationStopped && this.originalEvent.isImmediatePropagationStopped() - } - Event.prototype.clone = function (currentTarget) { - //TODO: this is ripe for optimisation, new events are *expensive* - // improving this will speed up delegated events - var ne = new Event(this, this.element, this.isNative) - ne.currentTarget = currentTarget - return ne - } - - return Event - }()) - - // if we're in old IE we can't do onpropertychange on doc or win so we use doc.documentElement for both - , targetElement = function (element, isNative) { - return !W3C_MODEL && !isNative && (element === doc || element === win) ? root : element - } - - /** - * Bean maintains an internal registry for event listeners. We don't touch elements, objects - * or functions to identify them, instead we store everything in the registry. - * Each event listener has a RegEntry object, we have one 'registry' for the whole instance. - */ - , RegEntry = (function () { - // each handler is wrapped so we can handle delegation and custom events - var wrappedHandler = function (element, fn, condition, args) { - var call = function (event, eargs) { - return fn.apply(element, args ? slice.call(eargs, event ? 0 : 1).concat(args) : eargs) - } - , findTarget = function (event, eventElement) { - return fn.__beanDel ? fn.__beanDel.ft(event.target, element) : eventElement - } - , handler = condition - ? function (event) { - var target = findTarget(event, this) // deleated event - if (condition.apply(target, arguments)) { - if (event) event.currentTarget = target - return call(event, arguments) - } - } - : function (event) { - if (fn.__beanDel) event = event.clone(findTarget(event)) // delegated event, fix the fix - return call(event, arguments) - } - handler.__beanDel = fn.__beanDel - return handler - } - - , RegEntry = function (element, type, handler, original, namespaces, args, root) { - var customType = customEvents[type] - , isNative - - if (type == 'unload') { - // self clean-up - handler = once(removeListener, element, type, handler, original) - } - - if (customType) { - if (customType.condition) { - handler = wrappedHandler(element, handler, customType.condition, args) - } - type = customType.base || type - } - - this.isNative = isNative = nativeEvents[type] && !!element[eventSupport] - this.customType = !W3C_MODEL && !isNative && type - this.element = element - this.type = type - this.original = original - this.namespaces = namespaces - this.eventType = W3C_MODEL || isNative ? type : 'propertychange' - this.target = targetElement(element, isNative) - this[eventSupport] = !!this.target[eventSupport] - this.root = root - this.handler = wrappedHandler(element, handler, null, args) - } - - // given a list of namespaces, is our entry in any of them? - RegEntry.prototype.inNamespaces = function (checkNamespaces) { - var i, j, c = 0 - if (!checkNamespaces) return true - if (!this.namespaces) return false - for (i = checkNamespaces.length; i--;) { - for (j = this.namespaces.length; j--;) { - if (checkNamespaces[i] == this.namespaces[j]) c++ - } - } - return checkNamespaces.length === c - } - - // match by element, original fn (opt), handler fn (opt) - RegEntry.prototype.matches = function (checkElement, checkOriginal, checkHandler) { - return this.element === checkElement && - (!checkOriginal || this.original === checkOriginal) && - (!checkHandler || this.handler === checkHandler) - } - - return RegEntry - }()) - - , registry = (function () { - // our map stores arrays by event type, just because it's better than storing - // everything in a single array. - // uses '$' as a prefix for the keys for safety and 'r' as a special prefix for - // rootListeners so we can look them up fast - var map = {} - - // generic functional search of our registry for matching listeners, - // `fn` returns false to break out of the loop - , forAll = function (element, type, original, handler, root, fn) { - var pfx = root ? 'r' : '$' - if (!type || type == '*') { - // search the whole registry - for (var t in map) { - if (t.charAt(0) == pfx) { - forAll(element, t.substr(1), original, handler, root, fn) - } - } - } else { - var i = 0, l, list = map[pfx + type], all = element == '*' - if (!list) return - for (l = list.length; i < l; i++) { - if ((all || list[i].matches(element, original, handler)) && !fn(list[i], list, i, type)) return - } - } - } - - , has = function (element, type, original, root) { - // we're not using forAll here simply because it's a bit slower and this - // needs to be fast - var i, list = map[(root ? 'r' : '$') + type] - if (list) { - for (i = list.length; i--;) { - if (!list[i].root && list[i].matches(element, original, null)) return true - } - } - return false - } - - , get = function (element, type, original, root) { - var entries = [] - forAll(element, type, original, null, root, function (entry) { - return entries.push(entry) - }) - return entries - } - - , put = function (entry) { - var has = !entry.root && !this.has(entry.element, entry.type, null, false) - , key = (entry.root ? 'r' : '$') + entry.type - ;(map[key] || (map[key] = [])).push(entry) - return has - } - - , del = function (entry) { - forAll(entry.element, entry.type, null, entry.handler, entry.root, function (entry, list, i) { - list.splice(i, 1) - entry.removed = true - if (list.length === 0) delete map[(entry.root ? 'r' : '$') + entry.type] - return false - }) - } - - // dump all entries, used for onunload - , entries = function () { - var t, entries = [] - for (t in map) { - if (t.charAt(0) == '$') entries = entries.concat(map[t]) - } - return entries - } - - return { has: has, get: get, put: put, del: del, entries: entries } - }()) - - // we need a selector engine for delegated events, use querySelectorAll if it exists - // but for older browsers we need Qwery, Sizzle or similar - , selectorEngine - , setSelectorEngine = function (e) { - if (!arguments.length) { - selectorEngine = doc.querySelectorAll - ? function (s, r) { - return r.querySelectorAll(s) - } - : function () { - throw new Error('Bean: No selector engine installed') // eeek - } - } else { - selectorEngine = e - } - } - - // we attach this listener to each DOM event that we need to listen to, only once - // per event type per DOM element - , rootListener = function (event, type) { - if (!W3C_MODEL && type && event && event.propertyName != '_on' + type) return - - var listeners = registry.get(this, type || event.type, null, false) - , l = listeners.length - , i = 0 - - event = new Event(event, this, true) - if (type) event.type = type - - // iterate through all handlers registered for this type, calling them unless they have - // been removed by a previous handler or stopImmediatePropagation() has been called - for (; i < l && !event.isImmediatePropagationStopped(); i++) { - if (!listeners[i].removed) listeners[i].handler.call(this, event) - } - } - - // add and remove listeners to DOM elements - , listener = W3C_MODEL - ? function (element, type, add) { - // new browsers - element[add ? addEvent : removeEvent](type, rootListener, false) - } - : function (element, type, add, custom) { - // IE8 and below, use attachEvent/detachEvent and we have to piggy-back propertychange events - // to simulate event bubbling etc. - var entry - if (add) { - registry.put(entry = new RegEntry( - element - , custom || type - , function (event) { // handler - rootListener.call(element, event, custom) - } - , rootListener - , null - , null - , true // is root - )) - if (custom && element['_on' + custom] == null) element['_on' + custom] = 0 - entry.target.attachEvent('on' + entry.eventType, entry.handler) - } else { - entry = registry.get(element, custom || type, rootListener, true)[0] - if (entry) { - entry.target.detachEvent('on' + entry.eventType, entry.handler) - registry.del(entry) - } - } - } - - , once = function (rm, element, type, fn, originalFn) { - // wrap the handler in a handler that does a remove as well - return function () { - fn.apply(this, arguments) - rm(element, type, originalFn) - } - } - - , removeListener = function (element, orgType, handler, namespaces) { - var type = orgType && orgType.replace(nameRegex, '') - , handlers = registry.get(element, type, null, false) - , removed = {} - , i, l - - for (i = 0, l = handlers.length; i < l; i++) { - if ((!handler || handlers[i].original === handler) && handlers[i].inNamespaces(namespaces)) { - // TODO: this is problematic, we have a registry.get() and registry.del() that - // both do registry searches so we waste cycles doing this. Needs to be rolled into - // a single registry.forAll(fn) that removes while finding, but the catch is that - // we'll be splicing the arrays that we're iterating over. Needs extra tests to - // make sure we don't screw it up. @rvagg - registry.del(handlers[i]) - if (!removed[handlers[i].eventType] && handlers[i][eventSupport]) - removed[handlers[i].eventType] = { t: handlers[i].eventType, c: handlers[i].type } - } - } - // check each type/element for removed listeners and remove the rootListener where it's no longer needed - for (i in removed) { - if (!registry.has(element, removed[i].t, null, false)) { - // last listener of this type, remove the rootListener - listener(element, removed[i].t, false, removed[i].c) - } - } - } - - // set up a delegate helper using the given selector, wrap the handler function - , delegate = function (selector, fn) { - //TODO: findTarget (therefore $) is called twice, once for match and once for - // setting e.currentTarget, fix this so it's only needed once - var findTarget = function (target, root) { - var i, array = isString(selector) ? selectorEngine(selector, root) : selector - for (; target && target !== root; target = target.parentNode) { - for (i = array.length; i--;) { - if (array[i] === target) return target - } - } - } - , handler = function (e) { - var match = findTarget(e.target, this) - if (match) fn.apply(match, arguments) - } - - // __beanDel isn't pleasant but it's a private function, not exposed outside of Bean - handler.__beanDel = { - ft : findTarget // attach it here for customEvents to use too - , selector : selector - } - return handler - } - - , fireListener = W3C_MODEL ? function (isNative, type, element) { - // modern browsers, do a proper dispatchEvent() - var evt = doc.createEvent(isNative ? 'HTMLEvents' : 'UIEvents') - evt[isNative ? 'initEvent' : 'initUIEvent'](type, true, true, win, 1) - element.dispatchEvent(evt) - } : function (isNative, type, element) { - // old browser use onpropertychange, just increment a custom property to trigger the event - element = targetElement(element, isNative) - isNative ? element.fireEvent('on' + type, doc.createEventObject()) : element['_on' + type]++ - } - - /** - * Public API: off(), on(), add(), (remove()), one(), fire(), clone() - */ - - /** - * off(element[, eventType(s)[, handler ]]) - */ - , off = function (element, typeSpec, fn) { - var isTypeStr = isString(typeSpec) - , k, type, namespaces, i - - if (isTypeStr && typeSpec.indexOf(' ') > 0) { - // off(el, 't1 t2 t3', fn) or off(el, 't1 t2 t3') - typeSpec = str2arr(typeSpec) - for (i = typeSpec.length; i--;) - off(element, typeSpec[i], fn) - return element - } - - type = isTypeStr && typeSpec.replace(nameRegex, '') - if (type && customEvents[type]) type = customEvents[type].base - - if (!typeSpec || isTypeStr) { - // off(el) or off(el, t1.ns) or off(el, .ns) or off(el, .ns1.ns2.ns3) - if (namespaces = isTypeStr && typeSpec.replace(namespaceRegex, '')) namespaces = str2arr(namespaces, '.') - removeListener(element, type, fn, namespaces) - } else if (isFunction(typeSpec)) { - // off(el, fn) - removeListener(element, null, typeSpec) - } else { - // off(el, { t1: fn1, t2, fn2 }) - for (k in typeSpec) { - if (typeSpec.hasOwnProperty(k)) off(element, k, typeSpec[k]) - } - } - - return element - } - - /** - * on(element, eventType(s)[, selector], handler[, args ]) - */ - , on = function(element, events, selector, fn) { - var originalFn, type, types, i, args, entry, first - - //TODO: the undefined check means you can't pass an 'args' argument, fix this perhaps? - if (selector === undefined && typeof events == 'object') { - //TODO: this can't handle delegated events - for (type in events) { - if (events.hasOwnProperty(type)) { - on.call(this, element, type, events[type]) - } - } - return - } - - if (!isFunction(selector)) { - // delegated event - originalFn = fn - args = slice.call(arguments, 4) - fn = delegate(selector, originalFn, selectorEngine) - } else { - args = slice.call(arguments, 3) - fn = originalFn = selector - } - - types = str2arr(events) - - // special case for one(), wrap in a self-removing handler - if (this === ONE) { - fn = once(off, element, events, fn, originalFn) - } - - for (i = types.length; i--;) { - // add new handler to the registry and check if it's the first for this element/type - first = registry.put(entry = new RegEntry( - element - , types[i].replace(nameRegex, '') // event type - , fn - , originalFn - , str2arr(types[i].replace(namespaceRegex, ''), '.') // namespaces - , args - , false // not root - )) - if (entry[eventSupport] && first) { - // first event of this type on this element, add root listener - listener(element, entry.eventType, true, entry.customType) - } - } - - return element - } - - /** - * add(element[, selector], eventType(s), handler[, args ]) - * - * Deprecated: kept (for now) for backward-compatibility - */ - , add = function (element, events, fn, delfn) { - return on.apply( - null - , !isString(fn) - ? slice.call(arguments) - : [ element, fn, events, delfn ].concat(arguments.length > 3 ? slice.call(arguments, 5) : []) - ) - } - - /** - * one(element, eventType(s)[, selector], handler[, args ]) - */ - , one = function () { - return on.apply(ONE, arguments) - } - - /** - * fire(element, eventType(s)[, args ]) - * - * The optional 'args' argument must be an array, if no 'args' argument is provided - * then we can use the browser's DOM event system, otherwise we trigger handlers manually - */ - , fire = function (element, type, args) { - var types = str2arr(type) - , i, j, l, names, handlers - - for (i = types.length; i--;) { - type = types[i].replace(nameRegex, '') - if (names = types[i].replace(namespaceRegex, '')) names = str2arr(names, '.') - if (!names && !args && element[eventSupport]) { - fireListener(nativeEvents[type], type, element) - } else { - // non-native event, either because of a namespace, arguments or a non DOM element - // iterate over all listeners and manually 'fire' - handlers = registry.get(element, type, null, false) - args = [false].concat(args) - for (j = 0, l = handlers.length; j < l; j++) { - if (handlers[j].inNamespaces(names)) { - handlers[j].handler.apply(element, args) - } - } - } - } - return element - } - - /** - * clone(dstElement, srcElement[, eventType ]) - * - * TODO: perhaps for consistency we should allow the same flexibility in type specifiers? - */ - , clone = function (element, from, type) { - var handlers = registry.get(from, type, null, false) - , l = handlers.length - , i = 0 - , args, beanDel - - for (; i < l; i++) { - if (handlers[i].original) { - args = [ element, handlers[i].type ] - if (beanDel = handlers[i].handler.__beanDel) args.push(beanDel.selector) - args.push(handlers[i].original) - on.apply(null, args) - } - } - return element - } - - , bean = { - on : on - , add : add - , one : one - , off : off - , remove : off - , clone : clone - , fire : fire - , setSelectorEngine : setSelectorEngine - , noConflict : function () { - context[name] = old - return this - } - } - - // for IE, clean up on unload to avoid leaks - if (win.attachEvent) { - var cleanup = function () { - var i, entries = registry.entries() - for (i in entries) { - if (entries[i].type && entries[i].type !== 'unload') off(entries[i].element, entries[i].type) - } - win.detachEvent('onunload', cleanup) - win.CollectGarbage && win.CollectGarbage() - } - win.attachEvent('onunload', cleanup) - } - - // initialize selector engine to internal default (qSA or throw Error) - setSelectorEngine() - - return bean - })); - - - provide("bean", module.exports); - - !function ($) { - var b = require('bean') - - , integrate = function (method, type, method2) { - var _args = type ? [type] : [] - return function () { - for (var i = 0, l = this.length; i < l; i++) { - if (!arguments.length && method == 'on' && type) method = 'fire' - b[method].apply(this, [this[i]].concat(_args, Array.prototype.slice.call(arguments, 0))) - } - return this - } - } - - , add = integrate('add') - , on = integrate('on') - , one = integrate('one') - , off = integrate('off') - , fire = integrate('fire') - , clone = integrate('clone') - - , hover = function (enter, leave, i) { // i for internal - for (i = this.length; i--;) { - b.on.call(this, this[i], 'mouseenter', enter) - b.on.call(this, this[i], 'mouseleave', leave) - } - return this - } - - , methods = { - on : on - , addListener : on - , bind : on - , listen : on - , delegate : add // jQuery compat, same arg order as add() - - , one : one - - , off : off - , unbind : off - , unlisten : off - , removeListener : off - , undelegate : off - - , emit : fire - , trigger : fire - - , cloneEvents : clone - - , hover : hover - } - - , shortcuts = - ('blur change click dblclick error focus focusin focusout keydown keypress ' - + 'keyup load mousedown mouseenter mouseleave mouseout mouseover mouseup ' - + 'mousemove resize scroll select submit unload').split(' ') - - for (var i = shortcuts.length; i--;) { - methods[shortcuts[i]] = integrate('on', shortcuts[i]) - } - - b.setSelectorEngine($) - - $.ender(methods, true) - }(ender); - -}()); - -(function () { - - var module = { exports: {} }, exports = module.exports; - - /*! - * Bonzo: DOM Utility (c) Dustin Diaz 2012 - * https://github.com/ded/bonzo - * License MIT - */ - (function (name, context, definition) { - if (typeof module != 'undefined' && module.exports) module.exports = definition() - else if (typeof context['define'] == 'function' && context['define']['amd']) define(definition) - else context[name] = definition() - })('bonzo', this, function() { - var win = window - , doc = win.document - , html = doc.documentElement - , parentNode = 'parentNode' - , specialAttributes = /^(checked|value|selected|disabled)$/i - , specialTags = /^(select|fieldset|table|tbody|tfoot|td|tr|colgroup)$/i // tags that we have trouble inserting *into* - , simpleScriptTagRe = /\s*