mirror of
https://github.com/github/choosealicense.com
synced 2024-12-22 12:50:24 +01:00
bower *all* the things
This commit is contained in:
parent
23e7510139
commit
df100c9348
5
.gitignore
vendored
5
.gitignore
vendored
@ -2,3 +2,8 @@
|
|||||||
/_site
|
/_site
|
||||||
/node_modules
|
/node_modules
|
||||||
/.bundle
|
/.bundle
|
||||||
|
_includes/js/vendor/zeroclipboard/docs
|
||||||
|
_includes/js/vendor/zeroclipboard/src
|
||||||
|
_includes/js/vendor/zeroclipboard/test
|
||||||
|
_includes/js/vendor/selectivizr/tests
|
||||||
|
_includes/js/vendor/qtip2/basic
|
||||||
|
6
_includes/js/jquery-1.10.2.min.js
vendored
6
_includes/js/jquery-1.10.2.min.js
vendored
File diff suppressed because one or more lines are too long
27
_includes/js/vendor/html5shiv/.bower.json
vendored
Normal file
27
_includes/js/vendor/html5shiv/.bower.json
vendored
Normal file
@ -0,0 +1,27 @@
|
|||||||
|
{
|
||||||
|
"name": "html5shiv",
|
||||||
|
"version": "3.7.0",
|
||||||
|
"main": [
|
||||||
|
"dist/html5shiv.js",
|
||||||
|
"dist/html5shiv-printshiv.js"
|
||||||
|
],
|
||||||
|
"ignore": [
|
||||||
|
"**/.*",
|
||||||
|
"*.json",
|
||||||
|
"test",
|
||||||
|
"build",
|
||||||
|
"src",
|
||||||
|
"build.xml"
|
||||||
|
],
|
||||||
|
"homepage": "https://github.com/aFarkas/html5shiv",
|
||||||
|
"_release": "3.7.0",
|
||||||
|
"_resolution": {
|
||||||
|
"type": "version",
|
||||||
|
"tag": "3.7.0",
|
||||||
|
"commit": "a4d4dcbe0875ba10c4c56c54454ae93031d59584"
|
||||||
|
},
|
||||||
|
"_source": "git://github.com/aFarkas/html5shiv.git",
|
||||||
|
"_target": "~3.7.0",
|
||||||
|
"_originalSource": "html5shiv",
|
||||||
|
"_direct": true
|
||||||
|
}
|
11
_includes/js/vendor/html5shiv/dist/html5shiv-printshiv.js
vendored
Normal file
11
_includes/js/vendor/html5shiv/dist/html5shiv-printshiv.js
vendored
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
/*
|
||||||
|
HTML5 Shiv v3.7.0 | @afarkas @jdalton @jon_neal @rem | MIT/GPL2 Licensed
|
||||||
|
*/
|
||||||
|
(function(j,f){function s(a,b){var c=a.createElement("p"),m=a.getElementsByTagName("head")[0]||a.documentElement;c.innerHTML="x<style>"+b+"</style>";return m.insertBefore(c.lastChild,m.firstChild)}function o(){var a=d.elements;return"string"==typeof a?a.split(" "):a}function n(a){var b=t[a[u]];b||(b={},p++,a[u]=p,t[p]=b);return b}function v(a,b,c){b||(b=f);if(e)return b.createElement(a);c||(c=n(b));b=c.cache[a]?c.cache[a].cloneNode():y.test(a)?(c.cache[a]=c.createElem(a)).cloneNode():c.createElem(a);
|
||||||
|
return b.canHaveChildren&&!z.test(a)?c.frag.appendChild(b):b}function A(a,b){if(!b.cache)b.cache={},b.createElem=a.createElement,b.createFrag=a.createDocumentFragment,b.frag=b.createFrag();a.createElement=function(c){return!d.shivMethods?b.createElem(c):v(c,a,b)};a.createDocumentFragment=Function("h,f","return function(){var n=f.cloneNode(),c=n.createElement;h.shivMethods&&("+o().join().replace(/\w+/g,function(a){b.createElem(a);b.frag.createElement(a);return'c("'+a+'")'})+");return n}")(d,b.frag)}
|
||||||
|
function w(a){a||(a=f);var b=n(a);if(d.shivCSS&&!q&&!b.hasCSS)b.hasCSS=!!s(a,"article,aside,dialog,figcaption,figure,footer,header,hgroup,main,nav,section{display:block}mark{background:#FF0;color:#000}template{display:none}");e||A(a,b);return a}function B(a){for(var b,c=a.attributes,m=c.length,f=a.ownerDocument.createElement(l+":"+a.nodeName);m--;)b=c[m],b.specified&&f.setAttribute(b.nodeName,b.nodeValue);f.style.cssText=a.style.cssText;return f}function x(a){function b(){clearTimeout(d._removeSheetTimer);
|
||||||
|
c&&c.removeNode(!0);c=null}var c,f,d=n(a),e=a.namespaces,j=a.parentWindow;if(!C||a.printShived)return a;"undefined"==typeof e[l]&&e.add(l);j.attachEvent("onbeforeprint",function(){b();var g,i,d;d=a.styleSheets;for(var e=[],h=d.length,k=Array(h);h--;)k[h]=d[h];for(;d=k.pop();)if(!d.disabled&&D.test(d.media)){try{g=d.imports,i=g.length}catch(j){i=0}for(h=0;h<i;h++)k.push(g[h]);try{e.push(d.cssText)}catch(n){}}g=e.reverse().join("").split("{");i=g.length;h=RegExp("(^|[\\s,>+~])("+o().join("|")+")(?=[[\\s,>+~#.:]|$)",
|
||||||
|
"gi");for(k="$1"+l+"\\:$2";i--;)e=g[i]=g[i].split("}"),e[e.length-1]=e[e.length-1].replace(h,k),g[i]=e.join("}");e=g.join("{");i=a.getElementsByTagName("*");h=i.length;k=RegExp("^(?:"+o().join("|")+")$","i");for(d=[];h--;)g=i[h],k.test(g.nodeName)&&d.push(g.applyElement(B(g)));f=d;c=s(a,e)});j.attachEvent("onafterprint",function(){for(var a=f,c=a.length;c--;)a[c].removeNode();clearTimeout(d._removeSheetTimer);d._removeSheetTimer=setTimeout(b,500)});a.printShived=!0;return a}var r=j.html5||{},z=/^<|^(?:button|map|select|textarea|object|iframe|option|optgroup)$/i,
|
||||||
|
y=/^(?:a|b|code|div|fieldset|h1|h2|h3|h4|h5|h6|i|label|li|ol|p|q|span|strong|style|table|tbody|td|th|tr|ul)$/i,q,u="_html5shiv",p=0,t={},e;(function(){try{var a=f.createElement("a");a.innerHTML="<xyz></xyz>";q="hidden"in a;var b;if(!(b=1==a.childNodes.length)){f.createElement("a");var c=f.createDocumentFragment();b="undefined"==typeof c.cloneNode||"undefined"==typeof c.createDocumentFragment||"undefined"==typeof c.createElement}e=b}catch(d){e=q=!0}})();var d={elements:r.elements||"abbr article aside audio bdi canvas data datalist details dialog figcaption figure footer header hgroup main mark meter nav output progress section summary template time video",
|
||||||
|
version:"3.7.0",shivCSS:!1!==r.shivCSS,supportsUnknownElements:e,shivMethods:!1!==r.shivMethods,type:"default",shivDocument:w,createElement:v,createDocumentFragment:function(a,b){a||(a=f);if(e)return a.createDocumentFragment();for(var b=b||n(a),c=b.frag.cloneNode(),d=0,j=o(),l=j.length;d<l;d++)c.createElement(j[d]);return c}};j.html5=d;w(f);var D=/^$|\b(?:all|print)\b/,l="html5shiv",C=!e&&function(){var a=f.documentElement;return!("undefined"==typeof f.namespaces||"undefined"==typeof f.parentWindow||
|
||||||
|
"undefined"==typeof a.applyElement||"undefined"==typeof a.removeNode||"undefined"==typeof j.attachEvent)}();d.type+=" print";d.shivPrint=x;x(f)})(this,document);
|
8
_includes/js/vendor/html5shiv/dist/html5shiv.js
vendored
Normal file
8
_includes/js/vendor/html5shiv/dist/html5shiv.js
vendored
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
/*
|
||||||
|
HTML5 Shiv v3.7.0 | @afarkas @jdalton @jon_neal @rem | MIT/GPL2 Licensed
|
||||||
|
*/
|
||||||
|
(function(l,f){function m(){var a=e.elements;return"string"==typeof a?a.split(" "):a}function i(a){var b=n[a[o]];b||(b={},h++,a[o]=h,n[h]=b);return b}function p(a,b,c){b||(b=f);if(g)return b.createElement(a);c||(c=i(b));b=c.cache[a]?c.cache[a].cloneNode():r.test(a)?(c.cache[a]=c.createElem(a)).cloneNode():c.createElem(a);return b.canHaveChildren&&!s.test(a)?c.frag.appendChild(b):b}function t(a,b){if(!b.cache)b.cache={},b.createElem=a.createElement,b.createFrag=a.createDocumentFragment,b.frag=b.createFrag();
|
||||||
|
a.createElement=function(c){return!e.shivMethods?b.createElem(c):p(c,a,b)};a.createDocumentFragment=Function("h,f","return function(){var n=f.cloneNode(),c=n.createElement;h.shivMethods&&("+m().join().replace(/[\w\-]+/g,function(a){b.createElem(a);b.frag.createElement(a);return'c("'+a+'")'})+");return n}")(e,b.frag)}function q(a){a||(a=f);var b=i(a);if(e.shivCSS&&!j&&!b.hasCSS){var c,d=a;c=d.createElement("p");d=d.getElementsByTagName("head")[0]||d.documentElement;c.innerHTML="x<style>article,aside,dialog,figcaption,figure,footer,header,hgroup,main,nav,section{display:block}mark{background:#FF0;color:#000}template{display:none}</style>";
|
||||||
|
c=d.insertBefore(c.lastChild,d.firstChild);b.hasCSS=!!c}g||t(a,b);return a}var k=l.html5||{},s=/^<|^(?:button|map|select|textarea|object|iframe|option|optgroup)$/i,r=/^(?:a|b|code|div|fieldset|h1|h2|h3|h4|h5|h6|i|label|li|ol|p|q|span|strong|style|table|tbody|td|th|tr|ul)$/i,j,o="_html5shiv",h=0,n={},g;(function(){try{var a=f.createElement("a");a.innerHTML="<xyz></xyz>";j="hidden"in a;var b;if(!(b=1==a.childNodes.length)){f.createElement("a");var c=f.createDocumentFragment();b="undefined"==typeof c.cloneNode||
|
||||||
|
"undefined"==typeof c.createDocumentFragment||"undefined"==typeof c.createElement}g=b}catch(d){g=j=!0}})();var e={elements:k.elements||"abbr article aside audio bdi canvas data datalist details dialog figcaption figure footer header hgroup main mark meter nav output progress section summary template time video",version:"3.7.0",shivCSS:!1!==k.shivCSS,supportsUnknownElements:g,shivMethods:!1!==k.shivMethods,type:"default",shivDocument:q,createElement:p,createDocumentFragment:function(a,b){a||(a=f);
|
||||||
|
if(g)return a.createDocumentFragment();for(var b=b||i(a),c=b.frag.cloneNode(),d=0,e=m(),h=e.length;d<h;d++)c.createElement(e[d]);return c}};l.html5=e;q(f)})(this,document);
|
143
_includes/js/vendor/html5shiv/readme.md
vendored
Normal file
143
_includes/js/vendor/html5shiv/readme.md
vendored
Normal file
@ -0,0 +1,143 @@
|
|||||||
|
# The HTML5 Shiv
|
||||||
|
|
||||||
|
The HTML5 Shiv enables use of HTML5 sectioning elements in legacy Internet Explorer and provides basic HTML5 styling for Internet Explorer 6-9, Safari 4.x (and iPhone 3.x), and Firefox 3.x.
|
||||||
|
|
||||||
|
### What do these files do?
|
||||||
|
|
||||||
|
#### `html5shiv.js`
|
||||||
|
* This includes the basic `createElement()` shiv technique, along with monkeypatches for `document.createElement` and `document.createDocumentFragment` for IE6-8. It also applies [basic styling](https://github.com/aFarkas/html5shiv/blob/51da98dabd3c537891b7fe6114633fb10de52473/src/html5shiv.js#L216-220) for HTML5 elements for IE6-9, Safari 4.x and FF 3.x.
|
||||||
|
|
||||||
|
####`html5shiv-printshiv.js`
|
||||||
|
* This includes all of the above, as well as a mechanism allowing HTML5 elements to be styled and contain children while being printed in IE 6-8.
|
||||||
|
|
||||||
|
### Who can I get mad at now?
|
||||||
|
|
||||||
|
HTML5 Shiv is maintained by [Alexander Farkas](https://github.com/aFarkas/), [Jonathan Neal](https://twitter.com/jon_neal) and [Paul Irish](https://twitter.com/paul_irish), with many contributions from [John-David Dalton](https://twitter.com/jdalton). It is also distributed with [Modernizr](http://modernizr.com/), and the two google code projects, [html5shiv](https://code.google.com/p/html5shiv/) and [html5shim](https://code.google.com/p/html5shim/), maintained by [Remy Sharp](https://twitter.com/rem).
|
||||||
|
|
||||||
|
If you have any issues in these implementations, you can report them here! :)
|
||||||
|
|
||||||
|
For the full story of HTML5 Shiv and all of the people involved in making it, read [The Story of the HTML5 Shiv](http://paulirish.com/2011/the-history-of-the-html5-shiv/).
|
||||||
|
|
||||||
|
## Installation
|
||||||
|
|
||||||
|
###Using [Bower](http://bower.io/)
|
||||||
|
|
||||||
|
`bower install html5shiv --save-dev`
|
||||||
|
|
||||||
|
This will clone the latest version of the HTML5 shiv into the `components` directory at the root of your project and also create or update the file `bower.json` which specifies your projects dependencies.
|
||||||
|
|
||||||
|
Include the HTML5 shiv in the `<head>` of your page in a conditional comment and after any stylesheets.
|
||||||
|
|
||||||
|
```html
|
||||||
|
<!--[if lt IE 9]>
|
||||||
|
<script src="components/html5shiv/html5shiv.js"></script>
|
||||||
|
<![endif]-->
|
||||||
|
```
|
||||||
|
|
||||||
|
###Manual installation
|
||||||
|
|
||||||
|
Download and extract the [latest zip package](https://github.com/aFarkas/html5shiv/archive/master.zip) from this repositiory and copy the two files `dist/html5shiv.js` and `dist/html5shiv-printshiv.js` into your project. Then include one of them into your `<head>` as above.
|
||||||
|
|
||||||
|
## HTML5 Shiv API
|
||||||
|
|
||||||
|
HTML5 Shiv works as a simple drop-in solution. In most cases there is no need to configure HTML5 Shiv or use methods provided by HTML5 Shiv.
|
||||||
|
|
||||||
|
### `html5.elements` option
|
||||||
|
|
||||||
|
The `elements` option is a space separated string or array, which describes the **full** list of the elements to shiv.
|
||||||
|
|
||||||
|
**Configuring `elements` before `html5shiv.js` is included.**
|
||||||
|
|
||||||
|
```js
|
||||||
|
//create a global html5 options object
|
||||||
|
window.html5 = {
|
||||||
|
'elements': 'mark section customelement'
|
||||||
|
};
|
||||||
|
```
|
||||||
|
**Configuring `elements` after `html5shiv.js` is included.**
|
||||||
|
|
||||||
|
```js
|
||||||
|
//change the html5shiv options object
|
||||||
|
window.html5.elements = 'mark section customelement';
|
||||||
|
//and re-invoke the `shivDocument` method
|
||||||
|
html5.shivDocument(document);
|
||||||
|
```
|
||||||
|
|
||||||
|
### `html5.shivCSS`
|
||||||
|
|
||||||
|
If `shivCSS` is set to `true` HTML5 Shiv will add basic styles (mostly display: block) to sectioning elements (like section, article). In most cases a webpage author should include those basic styles in his normal stylesheet to ensure older browser support (i.e. Firefox 3.6) without JavaScript.
|
||||||
|
|
||||||
|
The `shivCSS` is true by default and can be set false, only before html5shiv.js is included:
|
||||||
|
|
||||||
|
```js
|
||||||
|
//create a global html5 options object
|
||||||
|
window.html5 = {
|
||||||
|
'shivCSS': false
|
||||||
|
};
|
||||||
|
```
|
||||||
|
|
||||||
|
### `html5.shivMethods`
|
||||||
|
|
||||||
|
If the `shivMethods` option is set to `true` (by default) HTML5 Shiv will override `document.createElement`/`document.createDocumentFragment` in Internet Explorer 6-8 to allow dynamic DOM creation of HTML5 elements.
|
||||||
|
|
||||||
|
Known issue: If an element is created using the overridden `createElement` method this element returns a document fragment as its `parentNode`, but should be normally `null`. If a script relays on this behavior, `shivMethods`should be set to `false`.
|
||||||
|
Note: jQuery 1.7+ has implemented his own HTML5 DOM creation fix for Internet Explorer 6-8. If all your scripts (including Third party scripts) are using jQuery's manipulation and DOM creation methods, you might want to set this option to `false`.
|
||||||
|
|
||||||
|
**Configuring `shivMethods` before `html5shiv.js` is included.**
|
||||||
|
|
||||||
|
```js
|
||||||
|
//create a global html5 options object
|
||||||
|
window.html5 = {
|
||||||
|
'shivMethods': false
|
||||||
|
};
|
||||||
|
```
|
||||||
|
**Configuring `elements` after `html5shiv.js` is included.**
|
||||||
|
|
||||||
|
```js
|
||||||
|
//change the html5shiv options object
|
||||||
|
window.html5.shivMethods = false;
|
||||||
|
```
|
||||||
|
|
||||||
|
### `html5.createElement( nodeName [, document] )`
|
||||||
|
|
||||||
|
The `html5.createElement` method creates a shived element, even if `shivMethods` is set to false.
|
||||||
|
|
||||||
|
```js
|
||||||
|
var container = html5.createElement('div');
|
||||||
|
//container is shived so we can add HTML5 elements using `innerHTML`
|
||||||
|
container.innerHTML = '<section>This is a section</section>';
|
||||||
|
```
|
||||||
|
|
||||||
|
### `html5.createDocumentFragment( [document] )`
|
||||||
|
|
||||||
|
The `html5.createDocumentFragment` method creates a shived document fragment, even if `shivMethods` is set to false.
|
||||||
|
|
||||||
|
```js
|
||||||
|
var fragment = html5.createDocumentFragment();
|
||||||
|
var container = document.createElement('div');
|
||||||
|
fragment.appendChild(container);
|
||||||
|
//fragment is shived so we can add HTML5 elements using `innerHTML`
|
||||||
|
container.innerHTML = '<section>This is a section</section>';
|
||||||
|
```
|
||||||
|
|
||||||
|
## HTML5 Shiv Known Issues and Limitations
|
||||||
|
|
||||||
|
- The `shivMethods` option (overriding `document.createElement`) and the `html5.createElement` method create elements, which are not disconnected and have a parentNode (see also issue #64)
|
||||||
|
- The cloneNode problem is currently not addressed by HTML5 Shiv. HTML5 elements can be dynamically created, but can't be cloned in all cases.
|
||||||
|
- The printshiv version of HTML5 Shiv has to alter the print styles and the whole DOM for printing. In case of complex websites and or a lot of print styles this might cause performance and/or styling issues. A possible solution could be the [htc-branch](https://github.com/aFarkas/html5shiv/tree/iepp-htc) of HTML5 Shiv, which uses another technique to implement print styles for Internet Explorer 6-8.
|
||||||
|
|
||||||
|
### What about the other HTML5 element projects?
|
||||||
|
|
||||||
|
- The original conception and community collaboration story of the project is described at [The History of the HTML5 Shiv](http://paulirish.com/2011/the-history-of-the-html5-shiv/).
|
||||||
|
- [IEPP](https://code.google.com/p/ie-print-protector), by Jon Neal, addressed the printing fault of the original `html5shiv`. It was merged into `html5shiv`.
|
||||||
|
- **Shimprove**, in April 2010, patched `cloneNode` and `createElement` was later merged into `html5shiv`
|
||||||
|
- **innerShiv**, introduced in August 2010 by JD Barlett, addressed dynamically adding new HTML5 elements into the DOM. [jQuery added support](http://blog.jquery.com/2011/11/03/jquery-1-7-released/) that made innerShiv redundant and `html5shiv` addressed the same issues as well, so the project was completed.
|
||||||
|
- The **html5shim** and **html5shiv** sites on Google Code are maintained by Remy Sharp and are identical distribution points of this `html5shiv` project.
|
||||||
|
- **Modernizr** is developed by the same people as `html5shiv` and can include the latest version in any custom builds created at modernizr.com
|
||||||
|
- This `html5shiv` repo now contains tests for all the edge cases pursued by the above libraries and has been extensively tested, both in development and production.
|
||||||
|
|
||||||
|
A [detailed changelog of html5shiv](https://github.com/aFarkas/html5shiv/wiki) is available.
|
||||||
|
|
||||||
|
### Why is it called a *shiv*?
|
||||||
|
|
||||||
|
The term **shiv** [originates](http://ejohn.org/blog/html5-shiv/) from [John Resig](https://github.com/jeresig), who was thought to have used the word for its slang meaning, *a sharp object used as a knife-like weapon*, intended for Internet Explorer. Truth be known, John probably intended to use the word [shim](http://en.wikipedia.org/wiki/Shim_(computing\)), which in computing means *an application compatibility workaround*. Rather than correct his mispelling, most developers familiar with Internet Explorer appreciated the visual imagery. And that, [kids](http://html5homi.es/), is [etymology](https://en.wikipedia.org/wiki/Etymology).
|
22
_includes/js/vendor/jquery/.bower.json
vendored
Normal file
22
_includes/js/vendor/jquery/.bower.json
vendored
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
{
|
||||||
|
"name": "jquery",
|
||||||
|
"version": "2.1.0",
|
||||||
|
"description": "jQuery component",
|
||||||
|
"keywords": [
|
||||||
|
"jquery",
|
||||||
|
"component"
|
||||||
|
],
|
||||||
|
"main": "jquery.js",
|
||||||
|
"license": "MIT",
|
||||||
|
"homepage": "https://github.com/components/jquery",
|
||||||
|
"_release": "2.1.0",
|
||||||
|
"_resolution": {
|
||||||
|
"type": "version",
|
||||||
|
"tag": "2.1.0",
|
||||||
|
"commit": "099ad075783a6189f13c1e742e03f9cc95654a27"
|
||||||
|
},
|
||||||
|
"_source": "git://github.com/components/jquery.git",
|
||||||
|
"_target": "~2.1.0",
|
||||||
|
"_originalSource": "jquery",
|
||||||
|
"_direct": true
|
||||||
|
}
|
1
_includes/js/vendor/jquery/.gitignore
vendored
Normal file
1
_includes/js/vendor/jquery/.gitignore
vendored
Normal file
@ -0,0 +1 @@
|
|||||||
|
build
|
11
_includes/js/vendor/jquery/README.md
vendored
Normal file
11
_includes/js/vendor/jquery/README.md
vendored
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
jQuery Component
|
||||||
|
================
|
||||||
|
|
||||||
|
Shim [repository](https://github.com/components/jquery) for the [jQuery](http://jquery.com).
|
||||||
|
|
||||||
|
Package Managers
|
||||||
|
----------------
|
||||||
|
|
||||||
|
* [Bower](http://bower.io/): `jquery`
|
||||||
|
* [Component](https://github.com/component/component): `components/jquery`
|
||||||
|
* [Composer](http://packagist.org/packages/components/jquery): `components/jquery`
|
11
_includes/js/vendor/jquery/bower.json
vendored
Normal file
11
_includes/js/vendor/jquery/bower.json
vendored
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
{
|
||||||
|
"name": "jquery",
|
||||||
|
"version": "2.1.0",
|
||||||
|
"description": "jQuery component",
|
||||||
|
"keywords": [
|
||||||
|
"jquery",
|
||||||
|
"component"
|
||||||
|
],
|
||||||
|
"main": "jquery.js",
|
||||||
|
"license": "MIT"
|
||||||
|
}
|
15
_includes/js/vendor/jquery/component.json
vendored
Normal file
15
_includes/js/vendor/jquery/component.json
vendored
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
{
|
||||||
|
"name": "jquery",
|
||||||
|
"repo": "components/jquery",
|
||||||
|
"version": "2.1.0",
|
||||||
|
"description": "jQuery component",
|
||||||
|
"keywords": [
|
||||||
|
"jquery",
|
||||||
|
"component"
|
||||||
|
],
|
||||||
|
"main": "jquery.js",
|
||||||
|
"scripts": [
|
||||||
|
"jquery.js"
|
||||||
|
],
|
||||||
|
"license": "MIT"
|
||||||
|
}
|
36
_includes/js/vendor/jquery/composer.json
vendored
Normal file
36
_includes/js/vendor/jquery/composer.json
vendored
Normal file
@ -0,0 +1,36 @@
|
|||||||
|
{
|
||||||
|
"name": "components/jquery",
|
||||||
|
"description": "jQuery JavaScript Library",
|
||||||
|
"type": "component",
|
||||||
|
"homepage": "http://jquery.com",
|
||||||
|
"license": "MIT",
|
||||||
|
"support": {
|
||||||
|
"irc": "irc://irc.freenode.org/jquery",
|
||||||
|
"issues": "http://bugs.jquery.com",
|
||||||
|
"forum": "http://forum.jquery.com",
|
||||||
|
"wiki": "http://docs.jquery.com/",
|
||||||
|
"source": "https://github.com/jquery/jquery"
|
||||||
|
},
|
||||||
|
"authors": [
|
||||||
|
{
|
||||||
|
"name": "John Resig",
|
||||||
|
"email": "jeresig@gmail.com"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"require": {
|
||||||
|
"robloach/component-installer": "*"
|
||||||
|
},
|
||||||
|
"extra": {
|
||||||
|
"component": {
|
||||||
|
"scripts": [
|
||||||
|
"jquery.js"
|
||||||
|
],
|
||||||
|
"files": [
|
||||||
|
"jquery.min.js",
|
||||||
|
"jquery.min.map",
|
||||||
|
"jquery-migrate.js",
|
||||||
|
"jquery-migrate.min.js"
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
521
_includes/js/vendor/jquery/jquery-migrate.js
vendored
Normal file
521
_includes/js/vendor/jquery/jquery-migrate.js
vendored
Normal file
@ -0,0 +1,521 @@
|
|||||||
|
/*!
|
||||||
|
* jQuery Migrate - v1.2.1 - 2013-05-08
|
||||||
|
* https://github.com/jquery/jquery-migrate
|
||||||
|
* Copyright 2005, 2013 jQuery Foundation, Inc. and other contributors; Licensed MIT
|
||||||
|
*/
|
||||||
|
(function( jQuery, window, undefined ) {
|
||||||
|
// See http://bugs.jquery.com/ticket/13335
|
||||||
|
// "use strict";
|
||||||
|
|
||||||
|
|
||||||
|
var warnedAbout = {};
|
||||||
|
|
||||||
|
// List of warnings already given; public read only
|
||||||
|
jQuery.migrateWarnings = [];
|
||||||
|
|
||||||
|
// Set to true to prevent console output; migrateWarnings still maintained
|
||||||
|
// jQuery.migrateMute = false;
|
||||||
|
|
||||||
|
// Show a message on the console so devs know we're active
|
||||||
|
if ( !jQuery.migrateMute && window.console && window.console.log ) {
|
||||||
|
window.console.log("JQMIGRATE: Logging is active");
|
||||||
|
}
|
||||||
|
|
||||||
|
// Set to false to disable traces that appear with warnings
|
||||||
|
if ( jQuery.migrateTrace === undefined ) {
|
||||||
|
jQuery.migrateTrace = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Forget any warnings we've already given; public
|
||||||
|
jQuery.migrateReset = function() {
|
||||||
|
warnedAbout = {};
|
||||||
|
jQuery.migrateWarnings.length = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
function migrateWarn( msg) {
|
||||||
|
var console = window.console;
|
||||||
|
if ( !warnedAbout[ msg ] ) {
|
||||||
|
warnedAbout[ msg ] = true;
|
||||||
|
jQuery.migrateWarnings.push( msg );
|
||||||
|
if ( console && console.warn && !jQuery.migrateMute ) {
|
||||||
|
console.warn( "JQMIGRATE: " + msg );
|
||||||
|
if ( jQuery.migrateTrace && console.trace ) {
|
||||||
|
console.trace();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function migrateWarnProp( obj, prop, value, msg ) {
|
||||||
|
if ( Object.defineProperty ) {
|
||||||
|
// On ES5 browsers (non-oldIE), warn if the code tries to get prop;
|
||||||
|
// allow property to be overwritten in case some other plugin wants it
|
||||||
|
try {
|
||||||
|
Object.defineProperty( obj, prop, {
|
||||||
|
configurable: true,
|
||||||
|
enumerable: true,
|
||||||
|
get: function() {
|
||||||
|
migrateWarn( msg );
|
||||||
|
return value;
|
||||||
|
},
|
||||||
|
set: function( newValue ) {
|
||||||
|
migrateWarn( msg );
|
||||||
|
value = newValue;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
return;
|
||||||
|
} catch( err ) {
|
||||||
|
// IE8 is a dope about Object.defineProperty, can't warn there
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Non-ES5 (or broken) browser; just set the property
|
||||||
|
jQuery._definePropertyBroken = true;
|
||||||
|
obj[ prop ] = value;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( document.compatMode === "BackCompat" ) {
|
||||||
|
// jQuery has never supported or tested Quirks Mode
|
||||||
|
migrateWarn( "jQuery is not compatible with Quirks Mode" );
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
var attrFn = jQuery( "<input/>", { size: 1 } ).attr("size") && jQuery.attrFn,
|
||||||
|
oldAttr = jQuery.attr,
|
||||||
|
valueAttrGet = jQuery.attrHooks.value && jQuery.attrHooks.value.get ||
|
||||||
|
function() { return null; },
|
||||||
|
valueAttrSet = jQuery.attrHooks.value && jQuery.attrHooks.value.set ||
|
||||||
|
function() { return undefined; },
|
||||||
|
rnoType = /^(?:input|button)$/i,
|
||||||
|
rnoAttrNodeType = /^[238]$/,
|
||||||
|
rboolean = /^(?:autofocus|autoplay|async|checked|controls|defer|disabled|hidden|loop|multiple|open|readonly|required|scoped|selected)$/i,
|
||||||
|
ruseDefault = /^(?:checked|selected)$/i;
|
||||||
|
|
||||||
|
// jQuery.attrFn
|
||||||
|
migrateWarnProp( jQuery, "attrFn", attrFn || {}, "jQuery.attrFn is deprecated" );
|
||||||
|
|
||||||
|
jQuery.attr = function( elem, name, value, pass ) {
|
||||||
|
var lowerName = name.toLowerCase(),
|
||||||
|
nType = elem && elem.nodeType;
|
||||||
|
|
||||||
|
if ( pass ) {
|
||||||
|
// Since pass is used internally, we only warn for new jQuery
|
||||||
|
// versions where there isn't a pass arg in the formal params
|
||||||
|
if ( oldAttr.length < 4 ) {
|
||||||
|
migrateWarn("jQuery.fn.attr( props, pass ) is deprecated");
|
||||||
|
}
|
||||||
|
if ( elem && !rnoAttrNodeType.test( nType ) &&
|
||||||
|
(attrFn ? name in attrFn : jQuery.isFunction(jQuery.fn[name])) ) {
|
||||||
|
return jQuery( elem )[ name ]( value );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Warn if user tries to set `type`, since it breaks on IE 6/7/8; by checking
|
||||||
|
// for disconnected elements we don't warn on $( "<button>", { type: "button" } ).
|
||||||
|
if ( name === "type" && value !== undefined && rnoType.test( elem.nodeName ) && elem.parentNode ) {
|
||||||
|
migrateWarn("Can't change the 'type' of an input or button in IE 6/7/8");
|
||||||
|
}
|
||||||
|
|
||||||
|
// Restore boolHook for boolean property/attribute synchronization
|
||||||
|
if ( !jQuery.attrHooks[ lowerName ] && rboolean.test( lowerName ) ) {
|
||||||
|
jQuery.attrHooks[ lowerName ] = {
|
||||||
|
get: function( elem, name ) {
|
||||||
|
// Align boolean attributes with corresponding properties
|
||||||
|
// Fall back to attribute presence where some booleans are not supported
|
||||||
|
var attrNode,
|
||||||
|
property = jQuery.prop( elem, name );
|
||||||
|
return property === true || typeof property !== "boolean" &&
|
||||||
|
( attrNode = elem.getAttributeNode(name) ) && attrNode.nodeValue !== false ?
|
||||||
|
|
||||||
|
name.toLowerCase() :
|
||||||
|
undefined;
|
||||||
|
},
|
||||||
|
set: function( elem, value, name ) {
|
||||||
|
var propName;
|
||||||
|
if ( value === false ) {
|
||||||
|
// Remove boolean attributes when set to false
|
||||||
|
jQuery.removeAttr( elem, name );
|
||||||
|
} else {
|
||||||
|
// value is true since we know at this point it's type boolean and not false
|
||||||
|
// Set boolean attributes to the same name and set the DOM property
|
||||||
|
propName = jQuery.propFix[ name ] || name;
|
||||||
|
if ( propName in elem ) {
|
||||||
|
// Only set the IDL specifically if it already exists on the element
|
||||||
|
elem[ propName ] = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
elem.setAttribute( name, name.toLowerCase() );
|
||||||
|
}
|
||||||
|
return name;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
// Warn only for attributes that can remain distinct from their properties post-1.9
|
||||||
|
if ( ruseDefault.test( lowerName ) ) {
|
||||||
|
migrateWarn( "jQuery.fn.attr('" + lowerName + "') may use property instead of attribute" );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return oldAttr.call( jQuery, elem, name, value );
|
||||||
|
};
|
||||||
|
|
||||||
|
// attrHooks: value
|
||||||
|
jQuery.attrHooks.value = {
|
||||||
|
get: function( elem, name ) {
|
||||||
|
var nodeName = ( elem.nodeName || "" ).toLowerCase();
|
||||||
|
if ( nodeName === "button" ) {
|
||||||
|
return valueAttrGet.apply( this, arguments );
|
||||||
|
}
|
||||||
|
if ( nodeName !== "input" && nodeName !== "option" ) {
|
||||||
|
migrateWarn("jQuery.fn.attr('value') no longer gets properties");
|
||||||
|
}
|
||||||
|
return name in elem ?
|
||||||
|
elem.value :
|
||||||
|
null;
|
||||||
|
},
|
||||||
|
set: function( elem, value ) {
|
||||||
|
var nodeName = ( elem.nodeName || "" ).toLowerCase();
|
||||||
|
if ( nodeName === "button" ) {
|
||||||
|
return valueAttrSet.apply( this, arguments );
|
||||||
|
}
|
||||||
|
if ( nodeName !== "input" && nodeName !== "option" ) {
|
||||||
|
migrateWarn("jQuery.fn.attr('value', val) no longer sets properties");
|
||||||
|
}
|
||||||
|
// Does not return so that setAttribute is also used
|
||||||
|
elem.value = value;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
var matched, browser,
|
||||||
|
oldInit = jQuery.fn.init,
|
||||||
|
oldParseJSON = jQuery.parseJSON,
|
||||||
|
// Note: XSS check is done below after string is trimmed
|
||||||
|
rquickExpr = /^([^<]*)(<[\w\W]+>)([^>]*)$/;
|
||||||
|
|
||||||
|
// $(html) "looks like html" rule change
|
||||||
|
jQuery.fn.init = function( selector, context, rootjQuery ) {
|
||||||
|
var match;
|
||||||
|
|
||||||
|
if ( selector && typeof selector === "string" && !jQuery.isPlainObject( context ) &&
|
||||||
|
(match = rquickExpr.exec( jQuery.trim( selector ) )) && match[ 0 ] ) {
|
||||||
|
// This is an HTML string according to the "old" rules; is it still?
|
||||||
|
if ( selector.charAt( 0 ) !== "<" ) {
|
||||||
|
migrateWarn("$(html) HTML strings must start with '<' character");
|
||||||
|
}
|
||||||
|
if ( match[ 3 ] ) {
|
||||||
|
migrateWarn("$(html) HTML text after last tag is ignored");
|
||||||
|
}
|
||||||
|
// Consistently reject any HTML-like string starting with a hash (#9521)
|
||||||
|
// Note that this may break jQuery 1.6.x code that otherwise would work.
|
||||||
|
if ( match[ 0 ].charAt( 0 ) === "#" ) {
|
||||||
|
migrateWarn("HTML string cannot start with a '#' character");
|
||||||
|
jQuery.error("JQMIGRATE: Invalid selector string (XSS)");
|
||||||
|
}
|
||||||
|
// Now process using loose rules; let pre-1.8 play too
|
||||||
|
if ( context && context.context ) {
|
||||||
|
// jQuery object as context; parseHTML expects a DOM object
|
||||||
|
context = context.context;
|
||||||
|
}
|
||||||
|
if ( jQuery.parseHTML ) {
|
||||||
|
return oldInit.call( this, jQuery.parseHTML( match[ 2 ], context, true ),
|
||||||
|
context, rootjQuery );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return oldInit.apply( this, arguments );
|
||||||
|
};
|
||||||
|
jQuery.fn.init.prototype = jQuery.fn;
|
||||||
|
|
||||||
|
// Let $.parseJSON(falsy_value) return null
|
||||||
|
jQuery.parseJSON = function( json ) {
|
||||||
|
if ( !json && json !== null ) {
|
||||||
|
migrateWarn("jQuery.parseJSON requires a valid JSON string");
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
return oldParseJSON.apply( this, arguments );
|
||||||
|
};
|
||||||
|
|
||||||
|
jQuery.uaMatch = function( ua ) {
|
||||||
|
ua = ua.toLowerCase();
|
||||||
|
|
||||||
|
var match = /(chrome)[ \/]([\w.]+)/.exec( ua ) ||
|
||||||
|
/(webkit)[ \/]([\w.]+)/.exec( ua ) ||
|
||||||
|
/(opera)(?:.*version|)[ \/]([\w.]+)/.exec( ua ) ||
|
||||||
|
/(msie) ([\w.]+)/.exec( ua ) ||
|
||||||
|
ua.indexOf("compatible") < 0 && /(mozilla)(?:.*? rv:([\w.]+)|)/.exec( ua ) ||
|
||||||
|
[];
|
||||||
|
|
||||||
|
return {
|
||||||
|
browser: match[ 1 ] || "",
|
||||||
|
version: match[ 2 ] || "0"
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
// Don't clobber any existing jQuery.browser in case it's different
|
||||||
|
if ( !jQuery.browser ) {
|
||||||
|
matched = jQuery.uaMatch( navigator.userAgent );
|
||||||
|
browser = {};
|
||||||
|
|
||||||
|
if ( matched.browser ) {
|
||||||
|
browser[ matched.browser ] = true;
|
||||||
|
browser.version = matched.version;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Chrome is Webkit, but Webkit is also Safari.
|
||||||
|
if ( browser.chrome ) {
|
||||||
|
browser.webkit = true;
|
||||||
|
} else if ( browser.webkit ) {
|
||||||
|
browser.safari = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
jQuery.browser = browser;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Warn if the code tries to get jQuery.browser
|
||||||
|
migrateWarnProp( jQuery, "browser", jQuery.browser, "jQuery.browser is deprecated" );
|
||||||
|
|
||||||
|
jQuery.sub = function() {
|
||||||
|
function jQuerySub( selector, context ) {
|
||||||
|
return new jQuerySub.fn.init( selector, context );
|
||||||
|
}
|
||||||
|
jQuery.extend( true, jQuerySub, this );
|
||||||
|
jQuerySub.superclass = this;
|
||||||
|
jQuerySub.fn = jQuerySub.prototype = this();
|
||||||
|
jQuerySub.fn.constructor = jQuerySub;
|
||||||
|
jQuerySub.sub = this.sub;
|
||||||
|
jQuerySub.fn.init = function init( selector, context ) {
|
||||||
|
if ( context && context instanceof jQuery && !(context instanceof jQuerySub) ) {
|
||||||
|
context = jQuerySub( context );
|
||||||
|
}
|
||||||
|
|
||||||
|
return jQuery.fn.init.call( this, selector, context, rootjQuerySub );
|
||||||
|
};
|
||||||
|
jQuerySub.fn.init.prototype = jQuerySub.fn;
|
||||||
|
var rootjQuerySub = jQuerySub(document);
|
||||||
|
migrateWarn( "jQuery.sub() is deprecated" );
|
||||||
|
return jQuerySub;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
// Ensure that $.ajax gets the new parseJSON defined in core.js
|
||||||
|
jQuery.ajaxSetup({
|
||||||
|
converters: {
|
||||||
|
"text json": jQuery.parseJSON
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
|
var oldFnData = jQuery.fn.data;
|
||||||
|
|
||||||
|
jQuery.fn.data = function( name ) {
|
||||||
|
var ret, evt,
|
||||||
|
elem = this[0];
|
||||||
|
|
||||||
|
// Handles 1.7 which has this behavior and 1.8 which doesn't
|
||||||
|
if ( elem && name === "events" && arguments.length === 1 ) {
|
||||||
|
ret = jQuery.data( elem, name );
|
||||||
|
evt = jQuery._data( elem, name );
|
||||||
|
if ( ( ret === undefined || ret === evt ) && evt !== undefined ) {
|
||||||
|
migrateWarn("Use of jQuery.fn.data('events') is deprecated");
|
||||||
|
return evt;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return oldFnData.apply( this, arguments );
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
var rscriptType = /\/(java|ecma)script/i,
|
||||||
|
oldSelf = jQuery.fn.andSelf || jQuery.fn.addBack;
|
||||||
|
|
||||||
|
jQuery.fn.andSelf = function() {
|
||||||
|
migrateWarn("jQuery.fn.andSelf() replaced by jQuery.fn.addBack()");
|
||||||
|
return oldSelf.apply( this, arguments );
|
||||||
|
};
|
||||||
|
|
||||||
|
// Since jQuery.clean is used internally on older versions, we only shim if it's missing
|
||||||
|
if ( !jQuery.clean ) {
|
||||||
|
jQuery.clean = function( elems, context, fragment, scripts ) {
|
||||||
|
// Set context per 1.8 logic
|
||||||
|
context = context || document;
|
||||||
|
context = !context.nodeType && context[0] || context;
|
||||||
|
context = context.ownerDocument || context;
|
||||||
|
|
||||||
|
migrateWarn("jQuery.clean() is deprecated");
|
||||||
|
|
||||||
|
var i, elem, handleScript, jsTags,
|
||||||
|
ret = [];
|
||||||
|
|
||||||
|
jQuery.merge( ret, jQuery.buildFragment( elems, context ).childNodes );
|
||||||
|
|
||||||
|
// Complex logic lifted directly from jQuery 1.8
|
||||||
|
if ( fragment ) {
|
||||||
|
// Special handling of each script element
|
||||||
|
handleScript = function( elem ) {
|
||||||
|
// Check if we consider it executable
|
||||||
|
if ( !elem.type || rscriptType.test( elem.type ) ) {
|
||||||
|
// Detach the script and store it in the scripts array (if provided) or the fragment
|
||||||
|
// Return truthy to indicate that it has been handled
|
||||||
|
return scripts ?
|
||||||
|
scripts.push( elem.parentNode ? elem.parentNode.removeChild( elem ) : elem ) :
|
||||||
|
fragment.appendChild( elem );
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
for ( i = 0; (elem = ret[i]) != null; i++ ) {
|
||||||
|
// Check if we're done after handling an executable script
|
||||||
|
if ( !( jQuery.nodeName( elem, "script" ) && handleScript( elem ) ) ) {
|
||||||
|
// Append to fragment and handle embedded scripts
|
||||||
|
fragment.appendChild( elem );
|
||||||
|
if ( typeof elem.getElementsByTagName !== "undefined" ) {
|
||||||
|
// handleScript alters the DOM, so use jQuery.merge to ensure snapshot iteration
|
||||||
|
jsTags = jQuery.grep( jQuery.merge( [], elem.getElementsByTagName("script") ), handleScript );
|
||||||
|
|
||||||
|
// Splice the scripts into ret after their former ancestor and advance our index beyond them
|
||||||
|
ret.splice.apply( ret, [i + 1, 0].concat( jsTags ) );
|
||||||
|
i += jsTags.length;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return ret;
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
var eventAdd = jQuery.event.add,
|
||||||
|
eventRemove = jQuery.event.remove,
|
||||||
|
eventTrigger = jQuery.event.trigger,
|
||||||
|
oldToggle = jQuery.fn.toggle,
|
||||||
|
oldLive = jQuery.fn.live,
|
||||||
|
oldDie = jQuery.fn.die,
|
||||||
|
ajaxEvents = "ajaxStart|ajaxStop|ajaxSend|ajaxComplete|ajaxError|ajaxSuccess",
|
||||||
|
rajaxEvent = new RegExp( "\\b(?:" + ajaxEvents + ")\\b" ),
|
||||||
|
rhoverHack = /(?:^|\s)hover(\.\S+|)\b/,
|
||||||
|
hoverHack = function( events ) {
|
||||||
|
if ( typeof( events ) !== "string" || jQuery.event.special.hover ) {
|
||||||
|
return events;
|
||||||
|
}
|
||||||
|
if ( rhoverHack.test( events ) ) {
|
||||||
|
migrateWarn("'hover' pseudo-event is deprecated, use 'mouseenter mouseleave'");
|
||||||
|
}
|
||||||
|
return events && events.replace( rhoverHack, "mouseenter$1 mouseleave$1" );
|
||||||
|
};
|
||||||
|
|
||||||
|
// Event props removed in 1.9, put them back if needed; no practical way to warn them
|
||||||
|
if ( jQuery.event.props && jQuery.event.props[ 0 ] !== "attrChange" ) {
|
||||||
|
jQuery.event.props.unshift( "attrChange", "attrName", "relatedNode", "srcElement" );
|
||||||
|
}
|
||||||
|
|
||||||
|
// Undocumented jQuery.event.handle was "deprecated" in jQuery 1.7
|
||||||
|
if ( jQuery.event.dispatch ) {
|
||||||
|
migrateWarnProp( jQuery.event, "handle", jQuery.event.dispatch, "jQuery.event.handle is undocumented and deprecated" );
|
||||||
|
}
|
||||||
|
|
||||||
|
// Support for 'hover' pseudo-event and ajax event warnings
|
||||||
|
jQuery.event.add = function( elem, types, handler, data, selector ){
|
||||||
|
if ( elem !== document && rajaxEvent.test( types ) ) {
|
||||||
|
migrateWarn( "AJAX events should be attached to document: " + types );
|
||||||
|
}
|
||||||
|
eventAdd.call( this, elem, hoverHack( types || "" ), handler, data, selector );
|
||||||
|
};
|
||||||
|
jQuery.event.remove = function( elem, types, handler, selector, mappedTypes ){
|
||||||
|
eventRemove.call( this, elem, hoverHack( types ) || "", handler, selector, mappedTypes );
|
||||||
|
};
|
||||||
|
|
||||||
|
jQuery.fn.error = function() {
|
||||||
|
var args = Array.prototype.slice.call( arguments, 0);
|
||||||
|
migrateWarn("jQuery.fn.error() is deprecated");
|
||||||
|
args.splice( 0, 0, "error" );
|
||||||
|
if ( arguments.length ) {
|
||||||
|
return this.bind.apply( this, args );
|
||||||
|
}
|
||||||
|
// error event should not bubble to window, although it does pre-1.7
|
||||||
|
this.triggerHandler.apply( this, args );
|
||||||
|
return this;
|
||||||
|
};
|
||||||
|
|
||||||
|
jQuery.fn.toggle = function( fn, fn2 ) {
|
||||||
|
|
||||||
|
// Don't mess with animation or css toggles
|
||||||
|
if ( !jQuery.isFunction( fn ) || !jQuery.isFunction( fn2 ) ) {
|
||||||
|
return oldToggle.apply( this, arguments );
|
||||||
|
}
|
||||||
|
migrateWarn("jQuery.fn.toggle(handler, handler...) is deprecated");
|
||||||
|
|
||||||
|
// Save reference to arguments for access in closure
|
||||||
|
var args = arguments,
|
||||||
|
guid = fn.guid || jQuery.guid++,
|
||||||
|
i = 0,
|
||||||
|
toggler = function( event ) {
|
||||||
|
// Figure out which function to execute
|
||||||
|
var lastToggle = ( jQuery._data( this, "lastToggle" + fn.guid ) || 0 ) % i;
|
||||||
|
jQuery._data( this, "lastToggle" + fn.guid, lastToggle + 1 );
|
||||||
|
|
||||||
|
// Make sure that clicks stop
|
||||||
|
event.preventDefault();
|
||||||
|
|
||||||
|
// and execute the function
|
||||||
|
return args[ lastToggle ].apply( this, arguments ) || false;
|
||||||
|
};
|
||||||
|
|
||||||
|
// link all the functions, so any of them can unbind this click handler
|
||||||
|
toggler.guid = guid;
|
||||||
|
while ( i < args.length ) {
|
||||||
|
args[ i++ ].guid = guid;
|
||||||
|
}
|
||||||
|
|
||||||
|
return this.click( toggler );
|
||||||
|
};
|
||||||
|
|
||||||
|
jQuery.fn.live = function( types, data, fn ) {
|
||||||
|
migrateWarn("jQuery.fn.live() is deprecated");
|
||||||
|
if ( oldLive ) {
|
||||||
|
return oldLive.apply( this, arguments );
|
||||||
|
}
|
||||||
|
jQuery( this.context ).on( types, this.selector, data, fn );
|
||||||
|
return this;
|
||||||
|
};
|
||||||
|
|
||||||
|
jQuery.fn.die = function( types, fn ) {
|
||||||
|
migrateWarn("jQuery.fn.die() is deprecated");
|
||||||
|
if ( oldDie ) {
|
||||||
|
return oldDie.apply( this, arguments );
|
||||||
|
}
|
||||||
|
jQuery( this.context ).off( types, this.selector || "**", fn );
|
||||||
|
return this;
|
||||||
|
};
|
||||||
|
|
||||||
|
// Turn global events into document-triggered events
|
||||||
|
jQuery.event.trigger = function( event, data, elem, onlyHandlers ){
|
||||||
|
if ( !elem && !rajaxEvent.test( event ) ) {
|
||||||
|
migrateWarn( "Global events are undocumented and deprecated" );
|
||||||
|
}
|
||||||
|
return eventTrigger.call( this, event, data, elem || document, onlyHandlers );
|
||||||
|
};
|
||||||
|
jQuery.each( ajaxEvents.split("|"),
|
||||||
|
function( _, name ) {
|
||||||
|
jQuery.event.special[ name ] = {
|
||||||
|
setup: function() {
|
||||||
|
var elem = this;
|
||||||
|
|
||||||
|
// The document needs no shimming; must be !== for oldIE
|
||||||
|
if ( elem !== document ) {
|
||||||
|
jQuery.event.add( document, name + "." + jQuery.guid, function() {
|
||||||
|
jQuery.event.trigger( name, null, elem, true );
|
||||||
|
});
|
||||||
|
jQuery._data( this, name, jQuery.guid++ );
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
},
|
||||||
|
teardown: function() {
|
||||||
|
if ( this !== document ) {
|
||||||
|
jQuery.event.remove( document, name + "." + jQuery._data( this, name ) );
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
|
|
||||||
|
})( jQuery, window );
|
2
_includes/js/vendor/jquery/jquery-migrate.min.js
vendored
Normal file
2
_includes/js/vendor/jquery/jquery-migrate.min.js
vendored
Normal file
File diff suppressed because one or more lines are too long
9111
_includes/js/vendor/jquery/jquery.js
vendored
Normal file
9111
_includes/js/vendor/jquery/jquery.js
vendored
Normal file
File diff suppressed because it is too large
Load Diff
4
_includes/js/vendor/jquery/jquery.min.js
vendored
Normal file
4
_includes/js/vendor/jquery/jquery.min.js
vendored
Normal file
File diff suppressed because one or more lines are too long
1
_includes/js/vendor/jquery/jquery.min.map
vendored
Normal file
1
_includes/js/vendor/jquery/jquery.min.map
vendored
Normal file
File diff suppressed because one or more lines are too long
7
_includes/js/vendor/jquery/package.json
vendored
Normal file
7
_includes/js/vendor/jquery/package.json
vendored
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
{
|
||||||
|
"name": "components-jquery",
|
||||||
|
"version": "2.1.0",
|
||||||
|
"description": "jQuery component",
|
||||||
|
"keywords": ["jquery"],
|
||||||
|
"main": "./jquery.js"
|
||||||
|
}
|
49
_includes/js/vendor/qtip2/.bower.json
vendored
Normal file
49
_includes/js/vendor/qtip2/.bower.json
vendored
Normal file
@ -0,0 +1,49 @@
|
|||||||
|
{
|
||||||
|
"name": "qtip2",
|
||||||
|
"description": "Introducing... qTip2. The second generation of the advanced qTip plugin for the ever popular jQuery framework.",
|
||||||
|
"version": "2.2.0",
|
||||||
|
"homepage": "http://qtip2.com",
|
||||||
|
"location": "https://github.com/qTip2/bower",
|
||||||
|
"repository": {
|
||||||
|
"type": "git",
|
||||||
|
"url": "git://github.com/Craga89/qTip2.git"
|
||||||
|
},
|
||||||
|
"authors": [
|
||||||
|
{
|
||||||
|
"name": "Craig Michael Thompson",
|
||||||
|
"email": "craig@craigsworks.com",
|
||||||
|
"url": "http://craigsworks.com/"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"license": [
|
||||||
|
"MIT",
|
||||||
|
"GPL"
|
||||||
|
],
|
||||||
|
"keywords": [
|
||||||
|
"tooltip",
|
||||||
|
"tooltips",
|
||||||
|
"jquery",
|
||||||
|
"qtip",
|
||||||
|
"qtip2",
|
||||||
|
"craig",
|
||||||
|
"thompson",
|
||||||
|
"craigsworks"
|
||||||
|
],
|
||||||
|
"main": [
|
||||||
|
"./jquery.qtip.js",
|
||||||
|
"./basic/jquery.qtip.js"
|
||||||
|
],
|
||||||
|
"ignore": [
|
||||||
|
"bin"
|
||||||
|
],
|
||||||
|
"_release": "2.2.0",
|
||||||
|
"_resolution": {
|
||||||
|
"type": "version",
|
||||||
|
"tag": "v2.2.0",
|
||||||
|
"commit": "f5300e9a698f203d47307cfdf90399504fd2f6b2"
|
||||||
|
},
|
||||||
|
"_source": "git://github.com/qTip2/bower.git",
|
||||||
|
"_target": "~2.2.0",
|
||||||
|
"_originalSource": "qtip2",
|
||||||
|
"_direct": true
|
||||||
|
}
|
4
_includes/js/vendor/qtip2/README.md
vendored
Normal file
4
_includes/js/vendor/qtip2/README.md
vendored
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
qTip2 Bower Package
|
||||||
|
=====
|
||||||
|
|
||||||
|
Clone into an existing `qtip2` repo clone, and run the ./bin/build script to generate the files. Then push to the repo.
|
39
_includes/js/vendor/qtip2/bower.json
vendored
Executable file
39
_includes/js/vendor/qtip2/bower.json
vendored
Executable file
@ -0,0 +1,39 @@
|
|||||||
|
{
|
||||||
|
"name": "qtip2",
|
||||||
|
"description": "Introducing... qTip2. The second generation of the advanced qTip plugin for the ever popular jQuery framework.",
|
||||||
|
"version": "2.2.0",
|
||||||
|
"homepage": "http://qtip2.com",
|
||||||
|
"location": "https://github.com/qTip2/bower",
|
||||||
|
"repository": {
|
||||||
|
"type": "git",
|
||||||
|
"url": "git://github.com/Craga89/qTip2.git"
|
||||||
|
},
|
||||||
|
"authors": [
|
||||||
|
{
|
||||||
|
"name": "Craig Michael Thompson",
|
||||||
|
"email": "craig@craigsworks.com",
|
||||||
|
"url": "http://craigsworks.com/"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"license": [
|
||||||
|
"MIT",
|
||||||
|
"GPL"
|
||||||
|
],
|
||||||
|
"keywords": [
|
||||||
|
"tooltip",
|
||||||
|
"tooltips",
|
||||||
|
"jquery",
|
||||||
|
"qtip",
|
||||||
|
"qtip2",
|
||||||
|
"craig",
|
||||||
|
"thompson",
|
||||||
|
"craigsworks"
|
||||||
|
],
|
||||||
|
"main": [
|
||||||
|
"./jquery.qtip.js",
|
||||||
|
"./basic/jquery.qtip.js"
|
||||||
|
],
|
||||||
|
"ignore": [
|
||||||
|
"bin"
|
||||||
|
]
|
||||||
|
}
|
7
_includes/js/vendor/qtip2/imagesloaded.pkg.min.js
vendored
Normal file
7
_includes/js/vendor/qtip2/imagesloaded.pkg.min.js
vendored
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
/* qTip2 v2.2.0 tips modal viewport svg imagemap ie6 | qtip2.com | Licensed MIT, GPL | Mon Nov 25 2013 11:54:49 */
|
||||||
|
/*!
|
||||||
|
* imagesLoaded v3.0.4
|
||||||
|
* JavaScript is all like "You images are done yet or what?"
|
||||||
|
*/
|
||||||
|
(function(t){"use strict";function e(t,e){for(var i in e)t[i]=e[i];return t}function i(t){return"[object Array]"===h.call(t)}function s(t){var e=[];if(i(t))e=t;else if("number"==typeof t.length)for(var s=0,o=t.length;o>s;s++)e.push(t[s]);else e.push(t);return e}function o(t,i){function o(t,i,r){if(!(this instanceof o))return new o(t,i);"string"==typeof t&&(t=document.querySelectorAll(t)),this.elements=s(t),this.options=e({},this.options),"function"==typeof i?r=i:e(this.options,i),r&&this.on("always",r),this.getImages(),n&&(this.jqDeferred=new n.Deferred);var a=this;setTimeout(function(){a.check()})}function h(t){this.img=t}o.prototype=new t,o.prototype.options={},o.prototype.getImages=function(){this.images=[];for(var t=0,e=this.elements.length;e>t;t++){var i=this.elements[t];"IMG"===i.nodeName&&this.addImage(i);for(var s=i.querySelectorAll("img"),o=0,n=s.length;n>o;o++){var r=s[o];this.addImage(r)}}},o.prototype.addImage=function(t){var e=new h(t);this.images.push(e)},o.prototype.check=function(){function t(t,o){return e.options.debug&&a&&r.log("confirm",t,o),e.progress(t),i++,i===s&&e.complete(),!0}var e=this,i=0,s=this.images.length;if(this.hasAnyBroken=!1,!s)return this.complete(),void 0;for(var o=0;s>o;o++){var n=this.images[o];n.on("confirm",t),n.check()}},o.prototype.progress=function(t){this.hasAnyBroken=this.hasAnyBroken||!t.isLoaded;var e=this;setTimeout(function(){e.emit("progress",e,t),e.jqDeferred&&e.jqDeferred.notify(e,t)})},o.prototype.complete=function(){var t=this.hasAnyBroken?"fail":"done";this.isComplete=!0;var e=this;setTimeout(function(){if(e.emit(t,e),e.emit("always",e),e.jqDeferred){var i=e.hasAnyBroken?"reject":"resolve";e.jqDeferred[i](e)}})},n&&(n.fn.imagesLoaded=function(t,e){var i=new o(this,t,e);return i.jqDeferred.promise(n(this))});var l={};return h.prototype=new t,h.prototype.check=function(){var t=l[this.img.src];if(t)return this.useCached(t),void 0;if(l[this.img.src]=this,this.img.complete&&void 0!==this.img.naturalWidth)return this.confirm(0!==this.img.naturalWidth,"naturalWidth"),void 0;var e=this.proxyImage=new Image;i.bind(e,"load",this),i.bind(e,"error",this),e.src=this.img.src},h.prototype.useCached=function(t){if(t.isConfirmed)this.confirm(t.isLoaded,"cached was confirmed");else{var e=this;t.on("confirm",function(t){return e.confirm(t.isLoaded,"cache emitted confirmed"),!0})}},h.prototype.confirm=function(t,e){this.isConfirmed=!0,this.isLoaded=t,this.emit("confirm",this,e)},h.prototype.handleEvent=function(t){var e="on"+t.type;this[e]&&this[e](t)},h.prototype.onload=function(){this.confirm(!0,"onload"),this.unbindProxyEvents()},h.prototype.onerror=function(){this.confirm(!1,"onerror"),this.unbindProxyEvents()},h.prototype.unbindProxyEvents=function(){i.unbind(this.proxyImage,"load",this),i.unbind(this.proxyImage,"error",this)},o}var n=t.jQuery,r=t.console,a=r!==void 0,h=Object.prototype.toString;"function"==typeof define&&define.amd?define(["eventEmitter/EventEmitter","eventie/eventie"],o):t.imagesLoaded=o(t.EventEmitter,t.eventie)})(window);
|
||||||
|
//@ sourceMappingURL=http://cdnjs.cloudflare.com/ajax/libs/qtip2/2.2.0/imagesloaded.pkg.min.map
|
623
_includes/js/vendor/qtip2/jquery.qtip.css
vendored
Normal file
623
_includes/js/vendor/qtip2/jquery.qtip.css
vendored
Normal file
@ -0,0 +1,623 @@
|
|||||||
|
/*
|
||||||
|
* qTip2 - Pretty powerful tooltips - v2.2.0
|
||||||
|
* http://qtip2.com
|
||||||
|
*
|
||||||
|
* Copyright (c) 2013 Craig Michael Thompson
|
||||||
|
* Released under the MIT, GPL licenses
|
||||||
|
* http://jquery.org/license
|
||||||
|
*
|
||||||
|
* Date: Mon Nov 25 2013 11:54 GMT+0000
|
||||||
|
* Plugins: tips modal viewport svg imagemap ie6
|
||||||
|
* Styles: basic css3
|
||||||
|
*/
|
||||||
|
.qtip{
|
||||||
|
position: absolute;
|
||||||
|
left: -28000px;
|
||||||
|
top: -28000px;
|
||||||
|
display: none;
|
||||||
|
|
||||||
|
max-width: 280px;
|
||||||
|
min-width: 50px;
|
||||||
|
|
||||||
|
font-size: 10.5px;
|
||||||
|
line-height: 12px;
|
||||||
|
|
||||||
|
direction: ltr;
|
||||||
|
|
||||||
|
box-shadow: none;
|
||||||
|
padding: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qtip-content{
|
||||||
|
position: relative;
|
||||||
|
padding: 5px 9px;
|
||||||
|
overflow: hidden;
|
||||||
|
|
||||||
|
text-align: left;
|
||||||
|
word-wrap: break-word;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qtip-titlebar{
|
||||||
|
position: relative;
|
||||||
|
padding: 5px 35px 5px 10px;
|
||||||
|
overflow: hidden;
|
||||||
|
|
||||||
|
border-width: 0 0 1px;
|
||||||
|
font-weight: bold;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qtip-titlebar + .qtip-content{ border-top-width: 0 !important; }
|
||||||
|
|
||||||
|
/* Default close button class */
|
||||||
|
.qtip-close{
|
||||||
|
position: absolute;
|
||||||
|
right: -9px; top: -9px;
|
||||||
|
|
||||||
|
cursor: pointer;
|
||||||
|
outline: medium none;
|
||||||
|
|
||||||
|
border-width: 1px;
|
||||||
|
border-style: solid;
|
||||||
|
border-color: transparent;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qtip-titlebar .qtip-close{
|
||||||
|
right: 4px; top: 50%;
|
||||||
|
margin-top: -9px;
|
||||||
|
}
|
||||||
|
|
||||||
|
* html .qtip-titlebar .qtip-close{ top: 16px; } /* IE fix */
|
||||||
|
|
||||||
|
.qtip-titlebar .ui-icon,
|
||||||
|
.qtip-icon .ui-icon{
|
||||||
|
display: block;
|
||||||
|
text-indent: -1000em;
|
||||||
|
direction: ltr;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qtip-icon, .qtip-icon .ui-icon{
|
||||||
|
-moz-border-radius: 3px;
|
||||||
|
-webkit-border-radius: 3px;
|
||||||
|
border-radius: 3px;
|
||||||
|
text-decoration: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qtip-icon .ui-icon{
|
||||||
|
width: 18px;
|
||||||
|
height: 14px;
|
||||||
|
|
||||||
|
line-height: 14px;
|
||||||
|
text-align: center;
|
||||||
|
text-indent: 0;
|
||||||
|
font: normal bold 10px/13px Tahoma,sans-serif;
|
||||||
|
|
||||||
|
color: inherit;
|
||||||
|
background: transparent none no-repeat -100em -100em;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Applied to 'focused' tooltips e.g. most recently displayed/interacted with */
|
||||||
|
.qtip-focus{}
|
||||||
|
|
||||||
|
/* Applied on hover of tooltips i.e. added/removed on mouseenter/mouseleave respectively */
|
||||||
|
.qtip-hover{}
|
||||||
|
|
||||||
|
/* Default tooltip style */
|
||||||
|
.qtip-default{
|
||||||
|
border-width: 1px;
|
||||||
|
border-style: solid;
|
||||||
|
border-color: #F1D031;
|
||||||
|
|
||||||
|
background-color: #FFFFA3;
|
||||||
|
color: #555;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qtip-default .qtip-titlebar{
|
||||||
|
background-color: #FFEF93;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qtip-default .qtip-icon{
|
||||||
|
border-color: #CCC;
|
||||||
|
background: #F1F1F1;
|
||||||
|
color: #777;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qtip-default .qtip-titlebar .qtip-close{
|
||||||
|
border-color: #AAA;
|
||||||
|
color: #111;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/*! Light tooltip style */
|
||||||
|
.qtip-light{
|
||||||
|
background-color: white;
|
||||||
|
border-color: #E2E2E2;
|
||||||
|
color: #454545;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qtip-light .qtip-titlebar{
|
||||||
|
background-color: #f1f1f1;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/*! Dark tooltip style */
|
||||||
|
.qtip-dark{
|
||||||
|
background-color: #505050;
|
||||||
|
border-color: #303030;
|
||||||
|
color: #f3f3f3;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qtip-dark .qtip-titlebar{
|
||||||
|
background-color: #404040;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qtip-dark .qtip-icon{
|
||||||
|
border-color: #444;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qtip-dark .qtip-titlebar .ui-state-hover{
|
||||||
|
border-color: #303030;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/*! Cream tooltip style */
|
||||||
|
.qtip-cream{
|
||||||
|
background-color: #FBF7AA;
|
||||||
|
border-color: #F9E98E;
|
||||||
|
color: #A27D35;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qtip-cream .qtip-titlebar{
|
||||||
|
background-color: #F0DE7D;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qtip-cream .qtip-close .qtip-icon{
|
||||||
|
background-position: -82px 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/*! Red tooltip style */
|
||||||
|
.qtip-red{
|
||||||
|
background-color: #F78B83;
|
||||||
|
border-color: #D95252;
|
||||||
|
color: #912323;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qtip-red .qtip-titlebar{
|
||||||
|
background-color: #F06D65;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qtip-red .qtip-close .qtip-icon{
|
||||||
|
background-position: -102px 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qtip-red .qtip-icon{
|
||||||
|
border-color: #D95252;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qtip-red .qtip-titlebar .ui-state-hover{
|
||||||
|
border-color: #D95252;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/*! Green tooltip style */
|
||||||
|
.qtip-green{
|
||||||
|
background-color: #CAED9E;
|
||||||
|
border-color: #90D93F;
|
||||||
|
color: #3F6219;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qtip-green .qtip-titlebar{
|
||||||
|
background-color: #B0DE78;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qtip-green .qtip-close .qtip-icon{
|
||||||
|
background-position: -42px 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/*! Blue tooltip style */
|
||||||
|
.qtip-blue{
|
||||||
|
background-color: #E5F6FE;
|
||||||
|
border-color: #ADD9ED;
|
||||||
|
color: #5E99BD;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qtip-blue .qtip-titlebar{
|
||||||
|
background-color: #D0E9F5;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qtip-blue .qtip-close .qtip-icon{
|
||||||
|
background-position: -2px 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
.qtip-shadow{
|
||||||
|
-webkit-box-shadow: 1px 1px 3px 1px rgba(0, 0, 0, 0.15);
|
||||||
|
-moz-box-shadow: 1px 1px 3px 1px rgba(0, 0, 0, 0.15);
|
||||||
|
box-shadow: 1px 1px 3px 1px rgba(0, 0, 0, 0.15);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Add rounded corners to your tooltips in: FF3+, Chrome 2+, Opera 10.6+, IE9+, Safari 2+ */
|
||||||
|
.qtip-rounded,
|
||||||
|
.qtip-tipsy,
|
||||||
|
.qtip-bootstrap{
|
||||||
|
-moz-border-radius: 5px;
|
||||||
|
-webkit-border-radius: 5px;
|
||||||
|
border-radius: 5px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qtip-rounded .qtip-titlebar{
|
||||||
|
-moz-border-radius: 4px 4px 0 0;
|
||||||
|
-webkit-border-radius: 4px 4px 0 0;
|
||||||
|
border-radius: 4px 4px 0 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Youtube tooltip style */
|
||||||
|
.qtip-youtube{
|
||||||
|
-moz-border-radius: 2px;
|
||||||
|
-webkit-border-radius: 2px;
|
||||||
|
border-radius: 2px;
|
||||||
|
|
||||||
|
-webkit-box-shadow: 0 0 3px #333;
|
||||||
|
-moz-box-shadow: 0 0 3px #333;
|
||||||
|
box-shadow: 0 0 3px #333;
|
||||||
|
|
||||||
|
color: white;
|
||||||
|
border-width: 0;
|
||||||
|
|
||||||
|
background: #4A4A4A;
|
||||||
|
background-image: -webkit-gradient(linear,left top,left bottom,color-stop(0,#4A4A4A),color-stop(100%,black));
|
||||||
|
background-image: -webkit-linear-gradient(top,#4A4A4A 0,black 100%);
|
||||||
|
background-image: -moz-linear-gradient(top,#4A4A4A 0,black 100%);
|
||||||
|
background-image: -ms-linear-gradient(top,#4A4A4A 0,black 100%);
|
||||||
|
background-image: -o-linear-gradient(top,#4A4A4A 0,black 100%);
|
||||||
|
}
|
||||||
|
|
||||||
|
.qtip-youtube .qtip-titlebar{
|
||||||
|
background-color: #4A4A4A;
|
||||||
|
background-color: rgba(0,0,0,0);
|
||||||
|
}
|
||||||
|
|
||||||
|
.qtip-youtube .qtip-content{
|
||||||
|
padding: .75em;
|
||||||
|
font: 12px arial,sans-serif;
|
||||||
|
|
||||||
|
filter: progid:DXImageTransform.Microsoft.Gradient(GradientType=0,StartColorStr=#4a4a4a,EndColorStr=#000000);
|
||||||
|
-ms-filter: "progid:DXImageTransform.Microsoft.Gradient(GradientType=0,StartColorStr=#4a4a4a,EndColorStr=#000000);";
|
||||||
|
}
|
||||||
|
|
||||||
|
.qtip-youtube .qtip-icon{
|
||||||
|
border-color: #222;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qtip-youtube .qtip-titlebar .ui-state-hover{
|
||||||
|
border-color: #303030;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* jQuery TOOLS Tooltip style */
|
||||||
|
.qtip-jtools{
|
||||||
|
background: #232323;
|
||||||
|
background: rgba(0, 0, 0, 0.7);
|
||||||
|
background-image: -webkit-gradient(linear, left top, left bottom, from(#717171), to(#232323));
|
||||||
|
background-image: -moz-linear-gradient(top, #717171, #232323);
|
||||||
|
background-image: -webkit-linear-gradient(top, #717171, #232323);
|
||||||
|
background-image: -ms-linear-gradient(top, #717171, #232323);
|
||||||
|
background-image: -o-linear-gradient(top, #717171, #232323);
|
||||||
|
|
||||||
|
border: 2px solid #ddd;
|
||||||
|
border: 2px solid rgba(241,241,241,1);
|
||||||
|
|
||||||
|
-moz-border-radius: 2px;
|
||||||
|
-webkit-border-radius: 2px;
|
||||||
|
border-radius: 2px;
|
||||||
|
|
||||||
|
-webkit-box-shadow: 0 0 12px #333;
|
||||||
|
-moz-box-shadow: 0 0 12px #333;
|
||||||
|
box-shadow: 0 0 12px #333;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* IE Specific */
|
||||||
|
.qtip-jtools .qtip-titlebar{
|
||||||
|
background-color: transparent;
|
||||||
|
filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=#717171,endColorstr=#4A4A4A);
|
||||||
|
-ms-filter: "progid:DXImageTransform.Microsoft.gradient(startColorstr=#717171,endColorstr=#4A4A4A)";
|
||||||
|
}
|
||||||
|
.qtip-jtools .qtip-content{
|
||||||
|
filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=#4A4A4A,endColorstr=#232323);
|
||||||
|
-ms-filter: "progid:DXImageTransform.Microsoft.gradient(startColorstr=#4A4A4A,endColorstr=#232323)";
|
||||||
|
}
|
||||||
|
|
||||||
|
.qtip-jtools .qtip-titlebar,
|
||||||
|
.qtip-jtools .qtip-content{
|
||||||
|
background: transparent;
|
||||||
|
color: white;
|
||||||
|
border: 0 dashed transparent;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qtip-jtools .qtip-icon{
|
||||||
|
border-color: #555;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qtip-jtools .qtip-titlebar .ui-state-hover{
|
||||||
|
border-color: #333;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* Cluetip style */
|
||||||
|
.qtip-cluetip{
|
||||||
|
-webkit-box-shadow: 4px 4px 5px rgba(0, 0, 0, 0.4);
|
||||||
|
-moz-box-shadow: 4px 4px 5px rgba(0, 0, 0, 0.4);
|
||||||
|
box-shadow: 4px 4px 5px rgba(0, 0, 0, 0.4);
|
||||||
|
|
||||||
|
background-color: #D9D9C2;
|
||||||
|
color: #111;
|
||||||
|
border: 0 dashed transparent;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qtip-cluetip .qtip-titlebar{
|
||||||
|
background-color: #87876A;
|
||||||
|
color: white;
|
||||||
|
border: 0 dashed transparent;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qtip-cluetip .qtip-icon{
|
||||||
|
border-color: #808064;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qtip-cluetip .qtip-titlebar .ui-state-hover{
|
||||||
|
border-color: #696952;
|
||||||
|
color: #696952;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* Tipsy style */
|
||||||
|
.qtip-tipsy{
|
||||||
|
background: black;
|
||||||
|
background: rgba(0, 0, 0, .87);
|
||||||
|
|
||||||
|
color: white;
|
||||||
|
border: 0 solid transparent;
|
||||||
|
|
||||||
|
font-size: 11px;
|
||||||
|
font-family: 'Lucida Grande', sans-serif;
|
||||||
|
font-weight: bold;
|
||||||
|
line-height: 16px;
|
||||||
|
text-shadow: 0 1px black;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qtip-tipsy .qtip-titlebar{
|
||||||
|
padding: 6px 35px 0 10px;
|
||||||
|
background-color: transparent;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qtip-tipsy .qtip-content{
|
||||||
|
padding: 6px 10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qtip-tipsy .qtip-icon{
|
||||||
|
border-color: #222;
|
||||||
|
text-shadow: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qtip-tipsy .qtip-titlebar .ui-state-hover{
|
||||||
|
border-color: #303030;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* Tipped style */
|
||||||
|
.qtip-tipped{
|
||||||
|
border: 3px solid #959FA9;
|
||||||
|
|
||||||
|
-moz-border-radius: 3px;
|
||||||
|
-webkit-border-radius: 3px;
|
||||||
|
border-radius: 3px;
|
||||||
|
|
||||||
|
background-color: #F9F9F9;
|
||||||
|
color: #454545;
|
||||||
|
|
||||||
|
font-weight: normal;
|
||||||
|
font-family: serif;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qtip-tipped .qtip-titlebar{
|
||||||
|
border-bottom-width: 0;
|
||||||
|
|
||||||
|
color: white;
|
||||||
|
background: #3A79B8;
|
||||||
|
background-image: -webkit-gradient(linear, left top, left bottom, from(#3A79B8), to(#2E629D));
|
||||||
|
background-image: -webkit-linear-gradient(top, #3A79B8, #2E629D);
|
||||||
|
background-image: -moz-linear-gradient(top, #3A79B8, #2E629D);
|
||||||
|
background-image: -ms-linear-gradient(top, #3A79B8, #2E629D);
|
||||||
|
background-image: -o-linear-gradient(top, #3A79B8, #2E629D);
|
||||||
|
filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=#3A79B8,endColorstr=#2E629D);
|
||||||
|
-ms-filter: "progid:DXImageTransform.Microsoft.gradient(startColorstr=#3A79B8,endColorstr=#2E629D)";
|
||||||
|
}
|
||||||
|
|
||||||
|
.qtip-tipped .qtip-icon{
|
||||||
|
border: 2px solid #285589;
|
||||||
|
background: #285589;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qtip-tipped .qtip-icon .ui-icon{
|
||||||
|
background-color: #FBFBFB;
|
||||||
|
color: #555;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Twitter Bootstrap style.
|
||||||
|
*
|
||||||
|
* Tested with IE 8, IE 9, Chrome 18, Firefox 9, Opera 11.
|
||||||
|
* Does not work with IE 7.
|
||||||
|
*/
|
||||||
|
.qtip-bootstrap{
|
||||||
|
/** Taken from Bootstrap body */
|
||||||
|
font-size: 14px;
|
||||||
|
line-height: 20px;
|
||||||
|
color: #333333;
|
||||||
|
|
||||||
|
/** Taken from Bootstrap .popover */
|
||||||
|
padding: 1px;
|
||||||
|
background-color: #ffffff;
|
||||||
|
border: 1px solid #ccc;
|
||||||
|
border: 1px solid rgba(0, 0, 0, 0.2);
|
||||||
|
-webkit-border-radius: 6px;
|
||||||
|
-moz-border-radius: 6px;
|
||||||
|
border-radius: 6px;
|
||||||
|
-webkit-box-shadow: 0 5px 10px rgba(0, 0, 0, 0.2);
|
||||||
|
-moz-box-shadow: 0 5px 10px rgba(0, 0, 0, 0.2);
|
||||||
|
box-shadow: 0 5px 10px rgba(0, 0, 0, 0.2);
|
||||||
|
-webkit-background-clip: padding-box;
|
||||||
|
-moz-background-clip: padding;
|
||||||
|
background-clip: padding-box;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qtip-bootstrap .qtip-titlebar{
|
||||||
|
/** Taken from Bootstrap .popover-title */
|
||||||
|
padding: 8px 14px;
|
||||||
|
margin: 0;
|
||||||
|
font-size: 14px;
|
||||||
|
font-weight: normal;
|
||||||
|
line-height: 18px;
|
||||||
|
background-color: #f7f7f7;
|
||||||
|
border-bottom: 1px solid #ebebeb;
|
||||||
|
-webkit-border-radius: 5px 5px 0 0;
|
||||||
|
-moz-border-radius: 5px 5px 0 0;
|
||||||
|
border-radius: 5px 5px 0 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qtip-bootstrap .qtip-titlebar .qtip-close{
|
||||||
|
/**
|
||||||
|
* Overrides qTip2:
|
||||||
|
* .qtip-titlebar .qtip-close{
|
||||||
|
* [...]
|
||||||
|
* right: 4px;
|
||||||
|
* top: 50%;
|
||||||
|
* [...]
|
||||||
|
* border-style: solid;
|
||||||
|
* }
|
||||||
|
*/
|
||||||
|
right: 11px;
|
||||||
|
top: 45%;
|
||||||
|
border-style: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qtip-bootstrap .qtip-content{
|
||||||
|
/** Taken from Bootstrap .popover-content */
|
||||||
|
padding: 9px 14px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qtip-bootstrap .qtip-icon{
|
||||||
|
/**
|
||||||
|
* Overrides qTip2:
|
||||||
|
* .qtip-default .qtip-icon {
|
||||||
|
* border-color: #CCC;
|
||||||
|
* background: #F1F1F1;
|
||||||
|
* color: #777;
|
||||||
|
* }
|
||||||
|
*/
|
||||||
|
background: transparent;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qtip-bootstrap .qtip-icon .ui-icon{
|
||||||
|
/**
|
||||||
|
* Overrides qTip2:
|
||||||
|
* .qtip-icon .ui-icon{
|
||||||
|
* width: 18px;
|
||||||
|
* height: 14px;
|
||||||
|
* }
|
||||||
|
*/
|
||||||
|
width: auto;
|
||||||
|
height: auto;
|
||||||
|
|
||||||
|
/* Taken from Bootstrap .close */
|
||||||
|
float: right;
|
||||||
|
font-size: 20px;
|
||||||
|
font-weight: bold;
|
||||||
|
line-height: 18px;
|
||||||
|
color: #000000;
|
||||||
|
text-shadow: 0 1px 0 #ffffff;
|
||||||
|
opacity: 0.2;
|
||||||
|
filter: alpha(opacity=20);
|
||||||
|
}
|
||||||
|
|
||||||
|
.qtip-bootstrap .qtip-icon .ui-icon:hover{
|
||||||
|
/* Taken from Bootstrap .close:hover */
|
||||||
|
color: #000000;
|
||||||
|
text-decoration: none;
|
||||||
|
cursor: pointer;
|
||||||
|
opacity: 0.4;
|
||||||
|
filter: alpha(opacity=40);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* IE9 fix - removes all filters */
|
||||||
|
.qtip:not(.ie9haxors) div.qtip-content,
|
||||||
|
.qtip:not(.ie9haxors) div.qtip-titlebar{
|
||||||
|
filter: none;
|
||||||
|
-ms-filter: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
.qtip .qtip-tip{
|
||||||
|
margin: 0 auto;
|
||||||
|
overflow: hidden;
|
||||||
|
z-index: 10;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Opera bug #357 - Incorrect tip position
|
||||||
|
https://github.com/Craga89/qTip2/issues/367 */
|
||||||
|
x:-o-prefocus, .qtip .qtip-tip{
|
||||||
|
visibility: hidden;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qtip .qtip-tip,
|
||||||
|
.qtip .qtip-tip .qtip-vml,
|
||||||
|
.qtip .qtip-tip canvas{
|
||||||
|
position: absolute;
|
||||||
|
|
||||||
|
color: #123456;
|
||||||
|
background: transparent;
|
||||||
|
border: 0 dashed transparent;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qtip .qtip-tip canvas{ top: 0; left: 0; }
|
||||||
|
|
||||||
|
.qtip .qtip-tip .qtip-vml{
|
||||||
|
behavior: url(#default#VML);
|
||||||
|
display: inline-block;
|
||||||
|
visibility: visible;
|
||||||
|
}
|
||||||
|
|
||||||
|
#qtip-overlay{
|
||||||
|
position: fixed;
|
||||||
|
left: 0; top: 0;
|
||||||
|
width: 100%; height: 100%;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Applied to modals with show.modal.blur set to true */
|
||||||
|
#qtip-overlay.blurs{ cursor: pointer; }
|
||||||
|
|
||||||
|
/* Change opacity of overlay here */
|
||||||
|
#qtip-overlay div{
|
||||||
|
position: absolute;
|
||||||
|
left: 0; top: 0;
|
||||||
|
width: 100%; height: 100%;
|
||||||
|
|
||||||
|
background-color: black;
|
||||||
|
|
||||||
|
opacity: 0.7;
|
||||||
|
filter:alpha(opacity=70);
|
||||||
|
-ms-filter:"progid:DXImageTransform.Microsoft.Alpha(Opacity=70)";
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
.qtipmodal-ie6fix{
|
||||||
|
position: absolute !important;
|
||||||
|
}
|
3433
_includes/js/vendor/qtip2/jquery.qtip.js
vendored
Normal file
3433
_includes/js/vendor/qtip2/jquery.qtip.js
vendored
Normal file
File diff suppressed because it is too large
Load Diff
2
_includes/js/vendor/qtip2/jquery.qtip.min.css
vendored
Normal file
2
_includes/js/vendor/qtip2/jquery.qtip.min.css
vendored
Normal file
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
1
_includes/js/vendor/qtip2/jquery.qtip.min.map
vendored
Normal file
1
_includes/js/vendor/qtip2/jquery.qtip.min.map
vendored
Normal file
File diff suppressed because one or more lines are too long
15
_includes/js/vendor/selectivizr/.bower.json
vendored
Normal file
15
_includes/js/vendor/selectivizr/.bower.json
vendored
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
{
|
||||||
|
"name": "selectivizr",
|
||||||
|
"homepage": "https://github.com/keithclark/selectivizr",
|
||||||
|
"version": "1.0.2",
|
||||||
|
"_release": "1.0.2",
|
||||||
|
"_resolution": {
|
||||||
|
"type": "version",
|
||||||
|
"tag": "1.0.2",
|
||||||
|
"commit": "994f65755ac4e7ead1d14534f6eeb90cda21e909"
|
||||||
|
},
|
||||||
|
"_source": "git://github.com/keithclark/selectivizr.git",
|
||||||
|
"_target": "~1.0.2",
|
||||||
|
"_originalSource": "selectivizr",
|
||||||
|
"_direct": true
|
||||||
|
}
|
29
_includes/js/vendor/selectivizr/README.markdown
vendored
Normal file
29
_includes/js/vendor/selectivizr/README.markdown
vendored
Normal file
@ -0,0 +1,29 @@
|
|||||||
|
Selectivizr
|
||||||
|
-----------
|
||||||
|
|
||||||
|
**CSS3 selectors for IE**
|
||||||
|
|
||||||
|
|
||||||
|
_selectivizr_ is a JavaScript utility that emulates CSS3 pseudo-classes
|
||||||
|
and attribute selectors in Internet Explorer 6-8. Simply include the
|
||||||
|
script in your pages and selectivizr will do the rest.
|
||||||
|
|
||||||
|
To use the library, you'll need to include one of the supported libraries:
|
||||||
|
|
||||||
|
* jQuery (1.3+/1.4+)
|
||||||
|
* Dojo (1.5.0+)
|
||||||
|
* Prototype (1.6.1+)
|
||||||
|
* Yahoo UI Library (2.8.0+)
|
||||||
|
* DOMAssistant (2.8.0+)
|
||||||
|
* MooTools (1.3+)
|
||||||
|
* NWMatcher (1.2.3+)
|
||||||
|
|
||||||
|
Then add the following conditional comment:
|
||||||
|
|
||||||
|
<!--[if (gte IE 6)&(lte IE 8)]>
|
||||||
|
<script type="text/javascript" src="selectivizr.js"></script>
|
||||||
|
<noscript><link rel="stylesheet" href="[fallback css]" /></noscript>
|
||||||
|
<![endif]-->
|
||||||
|
|
||||||
|
This adds the `selectivizr.js` and fallback CSS file to IE6-8 while hiding
|
||||||
|
for other browsers.
|
112
_includes/js/vendor/selectivizr/changelog.txt
vendored
Normal file
112
_includes/js/vendor/selectivizr/changelog.txt
vendored
Normal file
@ -0,0 +1,112 @@
|
|||||||
|
selectivizr - change log
|
||||||
|
========================
|
||||||
|
|
||||||
|
|
||||||
|
v1.0.2
|
||||||
|
------
|
||||||
|
|
||||||
|
* BUG - fixed Google Closure Compiler issue that added 2 global vars - sorry about that!
|
||||||
|
* NEW - removed the eval() from determineSelectorMethod()
|
||||||
|
* BUG - selectivizr incorrectly detects Yahoo! profiler as YUI selector library
|
||||||
|
* NEW - selectivizr can now be "lazy-loaded"
|
||||||
|
* NEW - switched DOMReady back to Diego Perini's (new) ContentLoaded.
|
||||||
|
* BUG - asset urls using the 'data:' scheme (i.e. background-image) resolved to a path (Chris Korhonen)
|
||||||
|
* BUG - resolveUrl() failed if the context url contained a hash followed by a '/' (Zee Agency)
|
||||||
|
* BUG - IE version detection wasn't IE>9 friendly (reported by Paul Irish)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
v1.0.1
|
||||||
|
------
|
||||||
|
|
||||||
|
* BUG - @import urls not wrapped with "url()" are now correctly processed
|
||||||
|
* BUG - relative urls are now correctly resolved
|
||||||
|
* BUG - patched [*=""] selector in IE8 (returns elements it shouldn't)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
v1.0.0
|
||||||
|
------
|
||||||
|
|
||||||
|
ie-css3.js is now stable enough to be released with out a beta suffix - say hello to selectivizr v1!
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
v0.9.7b
|
||||||
|
-------
|
||||||
|
|
||||||
|
* NEW - Complete rewrite of the stylesheet parser.
|
||||||
|
* NEW - :not() pseudo support.
|
||||||
|
* NEW - Attribute selector support in IE6 [att] [att="x"] [att~="x"] [att^="x"] [att$="x"] [att*="x"] and [att|="x"]
|
||||||
|
* NEW - Fixes native empty attribute selector support in IE7 [att^=""] [att$=""] [att*=""] and IE8 [att^=""] [att$=""]
|
||||||
|
* BUG - :enabled and :disabled elements now change state properly. (Uses polling)
|
||||||
|
* BUG - Emulation no longer fails in IE6 when more than 2 classes are applied to an element
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
v0.9.6b
|
||||||
|
-------
|
||||||
|
|
||||||
|
* BUG - IE8 :target pseudo-class emulation fails with jQuery (but not with Sizzle) (reported by Tom Law)
|
||||||
|
* BUG - ie-css3.js won't run if page is in an iframe (switched DOM Load detection to Dean Edwards defered script method)
|
||||||
|
* BUG - A selector that begins with a attribute selector incorrected parsed (reported by Stephanie Sullivan)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
v0.9.5b
|
||||||
|
-------
|
||||||
|
|
||||||
|
* NEW - Reworked DOM Load detection (using a cut down version of Diego Perini's ContentLoaded technique)
|
||||||
|
* NEW - Enabled Dojo detection (lowest priority) - Warning: some of Dojo's CSS3 selectors seem very buggy!
|
||||||
|
* BUG - Fixed mixed content warning when using over SSL
|
||||||
|
* NEW - :target pseudo for IE8 when running standards mode. Sorry, no support for pre-IE8 or quirks mode
|
||||||
|
* NWMatcher now higher priority that DOMAssistant when auto-detecting best library
|
||||||
|
* Internal rewrites / refactoring - more features, but a smaller file :o)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
v0.9.4b
|
||||||
|
-------
|
||||||
|
|
||||||
|
* NEW - added support for :hover (for IE 5.5 - 6) and :focus (for IE 5.5 - 7)
|
||||||
|
* NEW - added support for ::first-child and ::first-letter (suggested by Philip Renich)
|
||||||
|
* BUG - style sheets without href values shouldn't get parsed (reported by Jeff Smith)
|
||||||
|
* BUG - remotely hosted style sheets are now ignored when used in @imports
|
||||||
|
* BUG - @import rules now honor the <base> href if its specified (reported by Andrea and Tim)
|
||||||
|
* BUG - various minor bug fixes
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
v0.9.3b
|
||||||
|
-------
|
||||||
|
|
||||||
|
* No longer dependent on DOMAssistant.
|
||||||
|
* Auto-detects best suited selector library from these:
|
||||||
|
- DOMAssistant (recommended)
|
||||||
|
- NWmatcher
|
||||||
|
- Prototype
|
||||||
|
- YUI 2
|
||||||
|
- MooTools
|
||||||
|
- Sizzle / jQuery
|
||||||
|
* NEW - pseudo selectors :enabled, :disabled, :checked and :root.
|
||||||
|
* BUG - Fixed IE 5.5/6 issue with illegal character in replacement class name.
|
||||||
|
* BUG - Fixed extra spaces issue with modified class names.
|
||||||
|
* BUG - Stopped triggering a DOM redraw when there are no className changes
|
||||||
|
* Dynamic building of CSS_PSEUDOS regexp based on IE version so we only patch what's needed.
|
||||||
|
* XHR compatability test (reported from twitter.com/kangax).
|
||||||
|
* Reworked DOMLoaded detection.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
v0.9.2b
|
||||||
|
-------
|
||||||
|
|
||||||
|
* CSS parser updated to crawl @import statements (suggested by Andy "Malarkey" Clarke).
|
||||||
|
* @font rules support.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
v0.9.1b
|
||||||
|
-------
|
||||||
|
|
||||||
|
* Public beta release.
|
561
_includes/js/vendor/selectivizr/selectivizr.js
vendored
Normal file
561
_includes/js/vendor/selectivizr/selectivizr.js
vendored
Normal file
@ -0,0 +1,561 @@
|
|||||||
|
/*
|
||||||
|
selectivizr v1.0.2b - (c) Keith Clark, freely distributable under the terms
|
||||||
|
of the MIT license.
|
||||||
|
|
||||||
|
selectivizr.com
|
||||||
|
*/
|
||||||
|
/*
|
||||||
|
|
||||||
|
Notes about this source
|
||||||
|
-----------------------
|
||||||
|
|
||||||
|
* The #DEBUG_START and #DEBUG_END comments are used to mark blocks of code
|
||||||
|
that will be removed prior to building a final release version (using a
|
||||||
|
pre-compression script)
|
||||||
|
|
||||||
|
|
||||||
|
References:
|
||||||
|
-----------
|
||||||
|
|
||||||
|
* CSS Syntax : http://www.w3.org/TR/2003/WD-css3-syntax-20030813/#style
|
||||||
|
* Selectors : http://www.w3.org/TR/css3-selectors/#selectors
|
||||||
|
* IE Compatability : http://msdn.microsoft.com/en-us/library/cc351024(VS.85).aspx
|
||||||
|
* W3C Selector Tests : http://www.w3.org/Style/CSS/Test/CSS3/Selectors/current/html/tests/
|
||||||
|
|
||||||
|
*/
|
||||||
|
|
||||||
|
(function(win) {
|
||||||
|
|
||||||
|
// If browser isn't IE, then stop execution! This handles the script
|
||||||
|
// being loaded by non IE browsers because the developer didn't use
|
||||||
|
// conditional comments.
|
||||||
|
if (/*@cc_on!@*/true) return;
|
||||||
|
|
||||||
|
// =========================== Init Objects ============================
|
||||||
|
|
||||||
|
var doc = document;
|
||||||
|
var root = doc.documentElement;
|
||||||
|
var xhr = getXHRObject();
|
||||||
|
var ieVersion = /MSIE (\d+)/.exec(navigator.userAgent)[1];
|
||||||
|
|
||||||
|
// If were not in standards mode, IE is too old / new or we can't create
|
||||||
|
// an XMLHttpRequest object then we should get out now.
|
||||||
|
if (doc.compatMode != 'CSS1Compat' || ieVersion<6 || ieVersion>8 || !xhr) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// ========================= Common Objects ============================
|
||||||
|
|
||||||
|
// Compatiable selector engines in order of CSS3 support. Note: '*' is
|
||||||
|
// a placholder for the object key name. (basically, crude compression)
|
||||||
|
var selectorEngines = {
|
||||||
|
"NW" : "*.Dom.select",
|
||||||
|
"MooTools" : "$$",
|
||||||
|
"DOMAssistant" : "*.$",
|
||||||
|
"Prototype" : "$$",
|
||||||
|
"YAHOO" : "*.util.Selector.query",
|
||||||
|
"Sizzle" : "*",
|
||||||
|
"jQuery" : "*",
|
||||||
|
"dojo" : "*.query"
|
||||||
|
};
|
||||||
|
|
||||||
|
var selectorMethod;
|
||||||
|
var enabledWatchers = []; // array of :enabled/:disabled elements to poll
|
||||||
|
var ie6PatchID = 0; // used to solve ie6's multiple class bug
|
||||||
|
var patchIE6MultipleClasses = true; // if true adds class bloat to ie6
|
||||||
|
var namespace = "slvzr";
|
||||||
|
|
||||||
|
// Stylesheet parsing regexp's
|
||||||
|
var RE_COMMENT = /(\/\*[^*]*\*+([^\/][^*]*\*+)*\/)\s*/g;
|
||||||
|
var RE_IMPORT = /@import\s*(?:(?:(?:url\(\s*(['"]?)(.*)\1)\s*\))|(?:(['"])(.*)\3))[^;]*;/g;
|
||||||
|
var RE_ASSET_URL = /\burl\(\s*(["']?)(?!data:)([^"')]+)\1\s*\)/g;
|
||||||
|
var RE_PSEUDO_STRUCTURAL = /^:(empty|(first|last|only|nth(-last)?)-(child|of-type))$/;
|
||||||
|
var RE_PSEUDO_ELEMENTS = /:(:first-(?:line|letter))/g;
|
||||||
|
var RE_SELECTOR_GROUP = /(^|})\s*([^\{]*?[\[:][^{]+)/g;
|
||||||
|
var RE_SELECTOR_PARSE = /([ +~>])|(:[a-z-]+(?:\(.*?\)+)?)|(\[.*?\])/g;
|
||||||
|
var RE_LIBRARY_INCOMPATIBLE_PSEUDOS = /(:not\()?:(hover|enabled|disabled|focus|checked|target|active|visited|first-line|first-letter)\)?/g;
|
||||||
|
var RE_PATCH_CLASS_NAME_REPLACE = /[^\w-]/g;
|
||||||
|
|
||||||
|
// HTML UI element regexp's
|
||||||
|
var RE_INPUT_ELEMENTS = /^(INPUT|SELECT|TEXTAREA|BUTTON)$/;
|
||||||
|
var RE_INPUT_CHECKABLE_TYPES = /^(checkbox|radio)$/;
|
||||||
|
|
||||||
|
// Broken attribute selector implementations (IE7/8 native [^=""], [$=""] and [*=""])
|
||||||
|
var BROKEN_ATTR_IMPLEMENTATIONS = ieVersion>6 ? /[\$\^*]=(['"])\1/ : null;
|
||||||
|
|
||||||
|
// Whitespace normalization regexp's
|
||||||
|
var RE_TIDY_TRAILING_WHITESPACE = /([(\[+~])\s+/g;
|
||||||
|
var RE_TIDY_LEADING_WHITESPACE = /\s+([)\]+~])/g;
|
||||||
|
var RE_TIDY_CONSECUTIVE_WHITESPACE = /\s+/g;
|
||||||
|
var RE_TIDY_TRIM_WHITESPACE = /^\s*((?:[\S\s]*\S)?)\s*$/;
|
||||||
|
|
||||||
|
// String constants
|
||||||
|
var EMPTY_STRING = "";
|
||||||
|
var SPACE_STRING = " ";
|
||||||
|
var PLACEHOLDER_STRING = "$1";
|
||||||
|
|
||||||
|
// =========================== Patching ================================
|
||||||
|
|
||||||
|
// --[ patchStyleSheet() ]----------------------------------------------
|
||||||
|
// Scans the passed cssText for selectors that require emulation and
|
||||||
|
// creates one or more patches for each matched selector.
|
||||||
|
function patchStyleSheet( cssText ) {
|
||||||
|
return cssText.replace(RE_PSEUDO_ELEMENTS, PLACEHOLDER_STRING).
|
||||||
|
replace(RE_SELECTOR_GROUP, function(m, prefix, selectorText) {
|
||||||
|
var selectorGroups = selectorText.split(",");
|
||||||
|
for (var c = 0, cs = selectorGroups.length; c < cs; c++) {
|
||||||
|
var selector = normalizeSelectorWhitespace(selectorGroups[c]) + SPACE_STRING;
|
||||||
|
var patches = [];
|
||||||
|
selectorGroups[c] = selector.replace(RE_SELECTOR_PARSE,
|
||||||
|
function(match, combinator, pseudo, attribute, index) {
|
||||||
|
if (combinator) {
|
||||||
|
if (patches.length>0) {
|
||||||
|
applyPatches( selector.substring(0, index), patches );
|
||||||
|
patches = [];
|
||||||
|
}
|
||||||
|
return combinator;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
var patch = (pseudo) ? patchPseudoClass( pseudo ) : patchAttribute( attribute );
|
||||||
|
if (patch) {
|
||||||
|
patches.push(patch);
|
||||||
|
return "." + patch.className;
|
||||||
|
}
|
||||||
|
return match;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
);
|
||||||
|
}
|
||||||
|
return prefix + selectorGroups.join(",");
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
// --[ patchAttribute() ]-----------------------------------------------
|
||||||
|
// returns a patch for an attribute selector.
|
||||||
|
function patchAttribute( attr ) {
|
||||||
|
return (!BROKEN_ATTR_IMPLEMENTATIONS || BROKEN_ATTR_IMPLEMENTATIONS.test(attr)) ?
|
||||||
|
{ className: createClassName(attr), applyClass: true } : null;
|
||||||
|
};
|
||||||
|
|
||||||
|
// --[ patchPseudoClass() ]---------------------------------------------
|
||||||
|
// returns a patch for a pseudo-class
|
||||||
|
function patchPseudoClass( pseudo ) {
|
||||||
|
|
||||||
|
var applyClass = true;
|
||||||
|
var className = createClassName(pseudo.slice(1));
|
||||||
|
var isNegated = pseudo.substring(0, 5) == ":not(";
|
||||||
|
var activateEventName;
|
||||||
|
var deactivateEventName;
|
||||||
|
|
||||||
|
// if negated, remove :not()
|
||||||
|
if (isNegated) {
|
||||||
|
pseudo = pseudo.slice(5, -1);
|
||||||
|
}
|
||||||
|
|
||||||
|
// bracket contents are irrelevant - remove them
|
||||||
|
var bracketIndex = pseudo.indexOf("(")
|
||||||
|
if (bracketIndex > -1) {
|
||||||
|
pseudo = pseudo.substring(0, bracketIndex);
|
||||||
|
}
|
||||||
|
|
||||||
|
// check we're still dealing with a pseudo-class
|
||||||
|
if (pseudo.charAt(0) == ":") {
|
||||||
|
switch (pseudo.slice(1)) {
|
||||||
|
|
||||||
|
case "root":
|
||||||
|
applyClass = function(e) {
|
||||||
|
return isNegated ? e != root : e == root;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
|
case "target":
|
||||||
|
// :target is only supported in IE8
|
||||||
|
if (ieVersion == 8) {
|
||||||
|
applyClass = function(e) {
|
||||||
|
var handler = function() {
|
||||||
|
var hash = location.hash;
|
||||||
|
var hashID = hash.slice(1);
|
||||||
|
return isNegated ? (hash == EMPTY_STRING || e.id != hashID) : (hash != EMPTY_STRING && e.id == hashID);
|
||||||
|
};
|
||||||
|
addEvent( win, "hashchange", function() {
|
||||||
|
toggleElementClass(e, className, handler());
|
||||||
|
})
|
||||||
|
return handler();
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
|
||||||
|
case "checked":
|
||||||
|
applyClass = function(e) {
|
||||||
|
if (RE_INPUT_CHECKABLE_TYPES.test(e.type)) {
|
||||||
|
addEvent( e, "propertychange", function() {
|
||||||
|
if (event.propertyName == "checked") {
|
||||||
|
toggleElementClass( e, className, e.checked !== isNegated );
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
return e.checked !== isNegated;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
|
case "disabled":
|
||||||
|
isNegated = !isNegated;
|
||||||
|
|
||||||
|
case "enabled":
|
||||||
|
applyClass = function(e) {
|
||||||
|
if (RE_INPUT_ELEMENTS.test(e.tagName)) {
|
||||||
|
addEvent( e, "propertychange", function() {
|
||||||
|
if (event.propertyName == "$disabled") {
|
||||||
|
toggleElementClass( e, className, e.$disabled === isNegated );
|
||||||
|
}
|
||||||
|
});
|
||||||
|
enabledWatchers.push(e);
|
||||||
|
e.$disabled = e.disabled;
|
||||||
|
return e.disabled === isNegated;
|
||||||
|
}
|
||||||
|
return pseudo == ":enabled" ? isNegated : !isNegated;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
|
case "focus":
|
||||||
|
activateEventName = "focus";
|
||||||
|
deactivateEventName = "blur";
|
||||||
|
|
||||||
|
case "hover":
|
||||||
|
if (!activateEventName) {
|
||||||
|
activateEventName = "mouseenter";
|
||||||
|
deactivateEventName = "mouseleave";
|
||||||
|
}
|
||||||
|
applyClass = function(e) {
|
||||||
|
addEvent( e, isNegated ? deactivateEventName : activateEventName, function() {
|
||||||
|
toggleElementClass( e, className, true );
|
||||||
|
})
|
||||||
|
addEvent( e, isNegated ? activateEventName : deactivateEventName, function() {
|
||||||
|
toggleElementClass( e, className, false );
|
||||||
|
})
|
||||||
|
return isNegated;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
|
// everything else
|
||||||
|
default:
|
||||||
|
// If we don't support this pseudo-class don't create
|
||||||
|
// a patch for it
|
||||||
|
if (!RE_PSEUDO_STRUCTURAL.test(pseudo)) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return { className: className, applyClass: applyClass };
|
||||||
|
};
|
||||||
|
|
||||||
|
// --[ applyPatches() ]-------------------------------------------------
|
||||||
|
// uses the passed selector text to find DOM nodes and patch them
|
||||||
|
function applyPatches(selectorText, patches) {
|
||||||
|
var elms;
|
||||||
|
|
||||||
|
// Although some selector libraries can find :checked :enabled etc.
|
||||||
|
// we need to find all elements that could have that state because
|
||||||
|
// it can be changed by the user.
|
||||||
|
var domSelectorText = selectorText.replace(RE_LIBRARY_INCOMPATIBLE_PSEUDOS, EMPTY_STRING);
|
||||||
|
|
||||||
|
// If the dom selector equates to an empty string or ends with
|
||||||
|
// whitespace then we need to append a universal selector (*) to it.
|
||||||
|
if (domSelectorText == EMPTY_STRING || domSelectorText.charAt(domSelectorText.length - 1) == SPACE_STRING) {
|
||||||
|
domSelectorText += "*";
|
||||||
|
}
|
||||||
|
|
||||||
|
// Ensure we catch errors from the selector library
|
||||||
|
try {
|
||||||
|
elms = selectorMethod( domSelectorText );
|
||||||
|
} catch (ex) {
|
||||||
|
// #DEBUG_START
|
||||||
|
log( "Selector '" + selectorText + "' threw exception '" + ex + "'" );
|
||||||
|
// #DEBUG_END
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
if (elms) {
|
||||||
|
for (var d = 0, dl = elms.length; d < dl; d++) {
|
||||||
|
var elm = elms[d];
|
||||||
|
var cssClasses = elm.className;
|
||||||
|
for (var f = 0, fl = patches.length; f < fl; f++) {
|
||||||
|
var patch = patches[f];
|
||||||
|
|
||||||
|
if (!hasPatch(elm, patch)) {
|
||||||
|
if (patch.applyClass && (patch.applyClass === true || patch.applyClass(elm) === true)) {
|
||||||
|
cssClasses = toggleClass(cssClasses, patch.className, true );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
elm.className = cssClasses;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
// --[ hasPatch() ]-----------------------------------------------------
|
||||||
|
// checks for the exsistence of a patch on an element
|
||||||
|
function hasPatch( elm, patch ) {
|
||||||
|
return new RegExp("(^|\\s)" + patch.className + "(\\s|$)").test(elm.className);
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
// =========================== Utility =================================
|
||||||
|
|
||||||
|
function createClassName( className ) {
|
||||||
|
return namespace + "-" + ((ieVersion == 6 && patchIE6MultipleClasses) ?
|
||||||
|
ie6PatchID++
|
||||||
|
:
|
||||||
|
className.replace(RE_PATCH_CLASS_NAME_REPLACE, function(a) { return a.charCodeAt(0) }));
|
||||||
|
};
|
||||||
|
|
||||||
|
// --[ log() ]----------------------------------------------------------
|
||||||
|
// #DEBUG_START
|
||||||
|
function log( message ) {
|
||||||
|
if (win.console) {
|
||||||
|
win.console.log(message);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
// #DEBUG_END
|
||||||
|
|
||||||
|
// --[ trim() ]---------------------------------------------------------
|
||||||
|
// removes leading, trailing whitespace from a string
|
||||||
|
function trim( text ) {
|
||||||
|
return text.replace(RE_TIDY_TRIM_WHITESPACE, PLACEHOLDER_STRING);
|
||||||
|
};
|
||||||
|
|
||||||
|
// --[ normalizeWhitespace() ]------------------------------------------
|
||||||
|
// removes leading, trailing and consecutive whitespace from a string
|
||||||
|
function normalizeWhitespace( text ) {
|
||||||
|
return trim(text).replace(RE_TIDY_CONSECUTIVE_WHITESPACE, SPACE_STRING);
|
||||||
|
};
|
||||||
|
|
||||||
|
// --[ normalizeSelectorWhitespace() ]----------------------------------
|
||||||
|
// tidies whitespace around selector brackets and combinators
|
||||||
|
function normalizeSelectorWhitespace( selectorText ) {
|
||||||
|
return normalizeWhitespace(selectorText.
|
||||||
|
replace(RE_TIDY_TRAILING_WHITESPACE, PLACEHOLDER_STRING).
|
||||||
|
replace(RE_TIDY_LEADING_WHITESPACE, PLACEHOLDER_STRING)
|
||||||
|
);
|
||||||
|
};
|
||||||
|
|
||||||
|
// --[ toggleElementClass() ]-------------------------------------------
|
||||||
|
// toggles a single className on an element
|
||||||
|
function toggleElementClass( elm, className, on ) {
|
||||||
|
var oldClassName = elm.className;
|
||||||
|
var newClassName = toggleClass(oldClassName, className, on);
|
||||||
|
if (newClassName != oldClassName) {
|
||||||
|
elm.className = newClassName;
|
||||||
|
elm.parentNode.className += EMPTY_STRING;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
// --[ toggleClass() ]--------------------------------------------------
|
||||||
|
// adds / removes a className from a string of classNames. Used to
|
||||||
|
// manage multiple class changes without forcing a DOM redraw
|
||||||
|
function toggleClass( classList, className, on ) {
|
||||||
|
var re = RegExp("(^|\\s)" + className + "(\\s|$)");
|
||||||
|
var classExists = re.test(classList);
|
||||||
|
if (on) {
|
||||||
|
return classExists ? classList : classList + SPACE_STRING + className;
|
||||||
|
} else {
|
||||||
|
return classExists ? trim(classList.replace(re, PLACEHOLDER_STRING)) : classList;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
// --[ addEvent() ]-----------------------------------------------------
|
||||||
|
function addEvent(elm, eventName, eventHandler) {
|
||||||
|
elm.attachEvent("on" + eventName, eventHandler);
|
||||||
|
};
|
||||||
|
|
||||||
|
// --[ getXHRObject() ]-------------------------------------------------
|
||||||
|
function getXHRObject()
|
||||||
|
{
|
||||||
|
if (win.XMLHttpRequest) {
|
||||||
|
return new XMLHttpRequest;
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
return new ActiveXObject('Microsoft.XMLHTTP');
|
||||||
|
} catch(e) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
// --[ loadStyleSheet() ]-----------------------------------------------
|
||||||
|
function loadStyleSheet( url ) {
|
||||||
|
xhr.open("GET", url, false);
|
||||||
|
xhr.send();
|
||||||
|
return (xhr.status==200) ? xhr.responseText : EMPTY_STRING;
|
||||||
|
};
|
||||||
|
|
||||||
|
// --[ resolveUrl() ]---------------------------------------------------
|
||||||
|
// Converts a URL fragment to a fully qualified URL using the specified
|
||||||
|
// context URL. Returns null if same-origin policy is broken
|
||||||
|
function resolveUrl( url, contextUrl ) {
|
||||||
|
|
||||||
|
function getProtocolAndHost( url ) {
|
||||||
|
return url.substring(0, url.indexOf("/", 8));
|
||||||
|
};
|
||||||
|
|
||||||
|
// absolute path
|
||||||
|
if (/^https?:\/\//i.test(url)) {
|
||||||
|
return getProtocolAndHost(contextUrl) == getProtocolAndHost(url) ? url : null;
|
||||||
|
}
|
||||||
|
|
||||||
|
// root-relative path
|
||||||
|
if (url.charAt(0)=="/") {
|
||||||
|
return getProtocolAndHost(contextUrl) + url;
|
||||||
|
}
|
||||||
|
|
||||||
|
// relative path
|
||||||
|
var contextUrlPath = contextUrl.split(/[?#]/)[0]; // ignore query string in the contextUrl
|
||||||
|
if (url.charAt(0) != "?" && contextUrlPath.charAt(contextUrlPath.length - 1) != "/") {
|
||||||
|
contextUrlPath = contextUrlPath.substring(0, contextUrlPath.lastIndexOf("/") + 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
return contextUrlPath + url;
|
||||||
|
};
|
||||||
|
|
||||||
|
// --[ parseStyleSheet() ]----------------------------------------------
|
||||||
|
// Downloads the stylesheet specified by the URL, removes it's comments
|
||||||
|
// and recursivly replaces @import rules with their contents, ultimately
|
||||||
|
// returning the full cssText.
|
||||||
|
function parseStyleSheet( url ) {
|
||||||
|
if (url) {
|
||||||
|
return loadStyleSheet(url).replace(RE_COMMENT, EMPTY_STRING).
|
||||||
|
replace(RE_IMPORT, function( match, quoteChar, importUrl, quoteChar2, importUrl2 ) {
|
||||||
|
return parseStyleSheet(resolveUrl(importUrl || importUrl2, url));
|
||||||
|
}).
|
||||||
|
replace(RE_ASSET_URL, function( match, quoteChar, assetUrl ) {
|
||||||
|
quoteChar = quoteChar || EMPTY_STRING;
|
||||||
|
return " url(" + quoteChar + resolveUrl(assetUrl, url) + quoteChar + ") ";
|
||||||
|
});
|
||||||
|
}
|
||||||
|
return EMPTY_STRING;
|
||||||
|
};
|
||||||
|
|
||||||
|
// --[ init() ]---------------------------------------------------------
|
||||||
|
function init() {
|
||||||
|
// honour the <base> tag
|
||||||
|
var url, stylesheet;
|
||||||
|
var baseTags = doc.getElementsByTagName("BASE");
|
||||||
|
var baseUrl = (baseTags.length > 0) ? baseTags[0].href : doc.location.href;
|
||||||
|
|
||||||
|
/* Note: This code prevents IE from freezing / crashing when using
|
||||||
|
@font-face .eot files but it modifies the <head> tag and could
|
||||||
|
trigger the IE stylesheet limit. It will also cause FOUC issues.
|
||||||
|
If you choose to use it, make sure you comment out the for loop
|
||||||
|
directly below this comment.
|
||||||
|
|
||||||
|
var head = doc.getElementsByTagName("head")[0];
|
||||||
|
for (var c=doc.styleSheets.length-1; c>=0; c--) {
|
||||||
|
stylesheet = doc.styleSheets[c]
|
||||||
|
head.appendChild(doc.createElement("style"))
|
||||||
|
var patchedStylesheet = doc.styleSheets[doc.styleSheets.length-1];
|
||||||
|
|
||||||
|
if (stylesheet.href != EMPTY_STRING) {
|
||||||
|
url = resolveUrl(stylesheet.href, baseUrl)
|
||||||
|
if (url) {
|
||||||
|
patchedStylesheet.cssText = patchStyleSheet( parseStyleSheet( url ) )
|
||||||
|
stylesheet.disabled = true
|
||||||
|
setTimeout( function () {
|
||||||
|
stylesheet.owningElement.parentNode.removeChild(stylesheet.owningElement)
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
*/
|
||||||
|
|
||||||
|
for (var c = 0; c < doc.styleSheets.length; c++) {
|
||||||
|
stylesheet = doc.styleSheets[c]
|
||||||
|
if (stylesheet.href != EMPTY_STRING) {
|
||||||
|
url = resolveUrl(stylesheet.href, baseUrl);
|
||||||
|
if (url) {
|
||||||
|
stylesheet.cssText = patchStyleSheet( parseStyleSheet( url ) );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// :enabled & :disabled polling script (since we can't hook
|
||||||
|
// onpropertychange event when an element is disabled)
|
||||||
|
if (enabledWatchers.length > 0) {
|
||||||
|
setInterval( function() {
|
||||||
|
for (var c = 0, cl = enabledWatchers.length; c < cl; c++) {
|
||||||
|
var e = enabledWatchers[c];
|
||||||
|
if (e.disabled !== e.$disabled) {
|
||||||
|
if (e.disabled) {
|
||||||
|
e.disabled = false;
|
||||||
|
e.$disabled = true;
|
||||||
|
e.disabled = true;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
e.$disabled = e.disabled;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},250)
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
// Bind selectivizr to the ContentLoaded event.
|
||||||
|
ContentLoaded(win, function() {
|
||||||
|
// Determine the "best fit" selector engine
|
||||||
|
for (var engine in selectorEngines) {
|
||||||
|
var members, member, context = win;
|
||||||
|
if (win[engine]) {
|
||||||
|
members = selectorEngines[engine].replace("*", engine).split(".");
|
||||||
|
while ((member = members.shift()) && (context = context[member])) {}
|
||||||
|
if (typeof context == "function") {
|
||||||
|
selectorMethod = context;
|
||||||
|
init();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* ContentLoaded.js by Diego Perini, modified for IE<9 only (to save space)
|
||||||
|
*
|
||||||
|
* Author: Diego Perini (diego.perini at gmail.com)
|
||||||
|
* Summary: cross-browser wrapper for DOMContentLoaded
|
||||||
|
* Updated: 20101020
|
||||||
|
* License: MIT
|
||||||
|
* Version: 1.2
|
||||||
|
*
|
||||||
|
* URL:
|
||||||
|
* http://javascript.nwbox.com/ContentLoaded/
|
||||||
|
* http://javascript.nwbox.com/ContentLoaded/MIT-LICENSE
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
// @w window reference
|
||||||
|
// @f function reference
|
||||||
|
function ContentLoaded(win, fn) {
|
||||||
|
|
||||||
|
var done = false, top = true,
|
||||||
|
init = function(e) {
|
||||||
|
if (e.type == "readystatechange" && doc.readyState != "complete") return;
|
||||||
|
(e.type == "load" ? win : doc).detachEvent("on" + e.type, init, false);
|
||||||
|
if (!done && (done = true)) fn.call(win, e.type || e);
|
||||||
|
},
|
||||||
|
poll = function() {
|
||||||
|
try { root.doScroll("left"); } catch(e) { setTimeout(poll, 50); return; }
|
||||||
|
init('poll');
|
||||||
|
};
|
||||||
|
|
||||||
|
if (doc.readyState == "complete") fn.call(win, EMPTY_STRING);
|
||||||
|
else {
|
||||||
|
if (doc.createEventObject && root.doScroll) {
|
||||||
|
try { top = !win.frameElement; } catch(e) { }
|
||||||
|
if (top) poll();
|
||||||
|
}
|
||||||
|
addEvent(doc,"readystatechange", init);
|
||||||
|
addEvent(win,"load", init);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
})(this);
|
47
_includes/js/vendor/zeroclipboard/.bower.json
vendored
Normal file
47
_includes/js/vendor/zeroclipboard/.bower.json
vendored
Normal file
@ -0,0 +1,47 @@
|
|||||||
|
{
|
||||||
|
"name": "zeroclipboard",
|
||||||
|
"description": "The ZeroClipboard library provides an easy way to copy text to the clipboard using an invisible Adobe Flash movie and a JavaScript interface.",
|
||||||
|
"version": "1.3.2",
|
||||||
|
"main": [
|
||||||
|
"./ZeroClipboard.js",
|
||||||
|
"./ZeroClipboard.swf"
|
||||||
|
],
|
||||||
|
"keywords": [
|
||||||
|
"flash",
|
||||||
|
"clipboard",
|
||||||
|
"copy",
|
||||||
|
"cut",
|
||||||
|
"paste",
|
||||||
|
"zclip",
|
||||||
|
"clip",
|
||||||
|
"clippy"
|
||||||
|
],
|
||||||
|
"license": "https://github.com/zeroclipboard/zeroclipboard/blob/master/LICENSE",
|
||||||
|
"authors": [
|
||||||
|
{
|
||||||
|
"name": "Jon Rohan",
|
||||||
|
"url": "http://jonrohan.me/"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "James M. Greene",
|
||||||
|
"email": "james.m.greene@gmail.com",
|
||||||
|
"url": "http://jamesgreene.net/"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"homepage": "http://zeroclipboard.org/",
|
||||||
|
"repository": {
|
||||||
|
"type": "git",
|
||||||
|
"url": "https://github.com/zeroclipboard/zeroclipboard.git"
|
||||||
|
},
|
||||||
|
"location": "git://github.com/zeroclipboard/zeroclipboard.git",
|
||||||
|
"_release": "1.3.2",
|
||||||
|
"_resolution": {
|
||||||
|
"type": "version",
|
||||||
|
"tag": "v1.3.2",
|
||||||
|
"commit": "028ce9abf2f2960fd79e0fae13b3446924be0e8c"
|
||||||
|
},
|
||||||
|
"_source": "git://github.com/zeroclipboard/zeroclipboard.git",
|
||||||
|
"_target": "~1.3.2",
|
||||||
|
"_originalSource": "zeroclipboard",
|
||||||
|
"_direct": true
|
||||||
|
}
|
3
_includes/js/vendor/zeroclipboard/.gitignore
vendored
Normal file
3
_includes/js/vendor/zeroclipboard/.gitignore
vendored
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
node_modules
|
||||||
|
npm-debug.log
|
||||||
|
bin/*
|
13
_includes/js/vendor/zeroclipboard/.jshintrc
vendored
Normal file
13
_includes/js/vendor/zeroclipboard/.jshintrc
vendored
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
{
|
||||||
|
"boss": true,
|
||||||
|
"browser": true,
|
||||||
|
"camelcase": true,
|
||||||
|
"eqeqeq": true,
|
||||||
|
"eqnull": true,
|
||||||
|
"es3": true,
|
||||||
|
"es5": false,
|
||||||
|
"indent": 2,
|
||||||
|
"multistr": true,
|
||||||
|
"strict": false,
|
||||||
|
"trailing": true
|
||||||
|
}
|
3
_includes/js/vendor/zeroclipboard/.npmignore
vendored
Normal file
3
_includes/js/vendor/zeroclipboard/.npmignore
vendored
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
docs/
|
||||||
|
test/
|
||||||
|
.DS_Store
|
5
_includes/js/vendor/zeroclipboard/.travis.yml
vendored
Normal file
5
_includes/js/vendor/zeroclipboard/.travis.yml
vendored
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
language: node_js
|
||||||
|
node_js:
|
||||||
|
- "0.10"
|
||||||
|
before_script:
|
||||||
|
- npm install -g grunt-cli
|
25
_includes/js/vendor/zeroclipboard/CONTRIBUTING.md
vendored
Normal file
25
_includes/js/vendor/zeroclipboard/CONTRIBUTING.md
vendored
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
Contributing
|
||||||
|
==============
|
||||||
|
|
||||||
|
If you find an issue, submitting a pull request is always better than a bug report! Please fork and submit your code fixes.
|
||||||
|
|
||||||
|
If you want to build some new features, we have a [roadmap.md](docs/roadmap.md) of features we want. You can add features you want there, or just code the feature and send a pull request.
|
||||||
|
|
||||||
|
### Cloning
|
||||||
|
|
||||||
|
$ git clone https://github.com/zeroclipboard/zeroclipboard.git
|
||||||
|
$ cd zeroclipboard/
|
||||||
|
$ npm install -g grunt-cli
|
||||||
|
$ npm install
|
||||||
|
$ grunt
|
||||||
|
|
||||||
|
|
||||||
|
### Developing
|
||||||
|
|
||||||
|
$ npm install
|
||||||
|
$ grunt
|
||||||
|
|
||||||
|
|
||||||
|
### Testing
|
||||||
|
|
||||||
|
$ grunt test
|
176
_includes/js/vendor/zeroclipboard/Gruntfile.js
vendored
Normal file
176
_includes/js/vendor/zeroclipboard/Gruntfile.js
vendored
Normal file
@ -0,0 +1,176 @@
|
|||||||
|
/*jshint -W106 */
|
||||||
|
/*jshint node:true */
|
||||||
|
module.exports = function(grunt) {
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
// Metadata
|
||||||
|
var pkg = grunt.file.readJSON('package.json');
|
||||||
|
|
||||||
|
// Shared configuration
|
||||||
|
var localPort = 7320; // "ZERO"
|
||||||
|
|
||||||
|
// Project configuration.
|
||||||
|
grunt.initConfig({
|
||||||
|
// Task configuration
|
||||||
|
jshint: {
|
||||||
|
options: {
|
||||||
|
jshintrc: '.jshintrc'
|
||||||
|
},
|
||||||
|
Gruntfile: ['Gruntfile.js'],
|
||||||
|
js: ['src/javascript/ZeroClipboard/**/*.js'],
|
||||||
|
test: {
|
||||||
|
options: {
|
||||||
|
jshintrc: 'test/.jshintrc'
|
||||||
|
},
|
||||||
|
src: ['test/*.js']
|
||||||
|
}
|
||||||
|
},
|
||||||
|
clean: {
|
||||||
|
src: ['ZeroClipboard.*'],
|
||||||
|
meta: ['bower.json', 'composer.json', 'LICENSE']
|
||||||
|
},
|
||||||
|
concat: {
|
||||||
|
options: {
|
||||||
|
stripBanners: true,
|
||||||
|
process: {
|
||||||
|
data: pkg
|
||||||
|
}
|
||||||
|
},
|
||||||
|
js: {
|
||||||
|
src: [
|
||||||
|
'src/meta/source-banner.tmpl',
|
||||||
|
'src/javascript/start.js',
|
||||||
|
'src/javascript/ZeroClipboard/state.js',
|
||||||
|
'src/javascript/ZeroClipboard/utils.js',
|
||||||
|
'src/javascript/ZeroClipboard/flash.js',
|
||||||
|
'src/javascript/ZeroClipboard/client.js',
|
||||||
|
'src/javascript/ZeroClipboard/core.js',
|
||||||
|
'src/javascript/ZeroClipboard/dom.js',
|
||||||
|
'src/javascript/ZeroClipboard/event.js',
|
||||||
|
'src/javascript/ZeroClipboard/deprecated.js',
|
||||||
|
'src/javascript/end.js'
|
||||||
|
],
|
||||||
|
dest: 'ZeroClipboard.js'
|
||||||
|
}
|
||||||
|
},
|
||||||
|
uglify: {
|
||||||
|
options: {
|
||||||
|
preserveComments: 'some',
|
||||||
|
report: 'min'
|
||||||
|
},
|
||||||
|
js: {
|
||||||
|
options: {
|
||||||
|
beautify: {
|
||||||
|
beautify: true,
|
||||||
|
// `indent_level` requires jshint -W106
|
||||||
|
indent_level: 2
|
||||||
|
},
|
||||||
|
mangle: false,
|
||||||
|
compress: false
|
||||||
|
},
|
||||||
|
src: ['ZeroClipboard.js'],
|
||||||
|
dest: 'ZeroClipboard.js'
|
||||||
|
},
|
||||||
|
minjs: {
|
||||||
|
src: ['ZeroClipboard.js'],
|
||||||
|
dest: 'ZeroClipboard.min.js'
|
||||||
|
}
|
||||||
|
},
|
||||||
|
mxmlc: {
|
||||||
|
options: {
|
||||||
|
rawConfig: '-static-link-runtime-shared-libraries=true'
|
||||||
|
},
|
||||||
|
swf: {
|
||||||
|
files: {
|
||||||
|
'ZeroClipboard.swf': ['src/flash/ZeroClipboard.as']
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
template: {
|
||||||
|
options: {
|
||||||
|
data: pkg
|
||||||
|
},
|
||||||
|
bower: {
|
||||||
|
files: {
|
||||||
|
'bower.json': ['src/meta/bower.json.tmpl']
|
||||||
|
}
|
||||||
|
},
|
||||||
|
composer: {
|
||||||
|
files: {
|
||||||
|
'composer.json': ['src/meta/composer.json.tmpl']
|
||||||
|
}
|
||||||
|
},
|
||||||
|
LICENSE: {
|
||||||
|
files: {
|
||||||
|
'LICENSE': ['src/meta/LICENSE.tmpl']
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
chmod: {
|
||||||
|
options: {
|
||||||
|
mode: '444'
|
||||||
|
},
|
||||||
|
src: ['ZeroClipboard.*'],
|
||||||
|
meta: ['bower.json', 'composer.json', 'LICENSE']
|
||||||
|
},
|
||||||
|
connect: {
|
||||||
|
server: {
|
||||||
|
options: {
|
||||||
|
port: localPort
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
qunit: {
|
||||||
|
file: ['test/**/*.js.html'],
|
||||||
|
http: {
|
||||||
|
options: {
|
||||||
|
urls: grunt.file.expand(['test/**/*.js.html']).map(function(testPage) {
|
||||||
|
return 'http://localhost:' + localPort + '/' + testPage + '?noglobals=true';
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
watch: {
|
||||||
|
options: {
|
||||||
|
spawn: false
|
||||||
|
},
|
||||||
|
Gruntfile: {
|
||||||
|
files: '<%= jshint.Gruntfile %>',
|
||||||
|
tasks: ['jshint:Gruntfile']
|
||||||
|
},
|
||||||
|
js: {
|
||||||
|
files: '<%= jshint.js %>',
|
||||||
|
tasks: ['jshint:js', 'unittest']
|
||||||
|
},
|
||||||
|
test: {
|
||||||
|
files: '<%= jshint.test %>',
|
||||||
|
tasks: ['jshint:test', 'unittest']
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
// These plugins provide necessary tasks
|
||||||
|
grunt.loadNpmTasks('grunt-contrib-jshint');
|
||||||
|
grunt.loadNpmTasks('grunt-contrib-clean');
|
||||||
|
grunt.loadNpmTasks('grunt-contrib-concat');
|
||||||
|
grunt.loadNpmTasks('grunt-contrib-uglify');
|
||||||
|
grunt.loadNpmTasks('grunt-mxmlc');
|
||||||
|
grunt.loadNpmTasks('grunt-template');
|
||||||
|
grunt.loadNpmTasks('grunt-chmod');
|
||||||
|
grunt.loadNpmTasks('grunt-contrib-connect');
|
||||||
|
grunt.loadNpmTasks('grunt-contrib-qunit');
|
||||||
|
grunt.loadNpmTasks('grunt-contrib-watch');
|
||||||
|
|
||||||
|
|
||||||
|
//
|
||||||
|
// Task aliases and chains
|
||||||
|
//
|
||||||
|
|
||||||
|
grunt.registerTask('unittest', ['connect', 'qunit']);
|
||||||
|
grunt.registerTask('test', ['jshint', 'clean:src', 'concat', 'mxmlc', 'chmod:src', 'unittest']);
|
||||||
|
grunt.registerTask('travis', ['test']);
|
||||||
|
|
||||||
|
// Default task
|
||||||
|
grunt.registerTask('default', ['jshint', 'clean', 'concat', 'uglify', 'mxmlc', 'template', 'chmod', 'unittest']);
|
||||||
|
|
||||||
|
};
|
8
_includes/js/vendor/zeroclipboard/LICENSE
vendored
Normal file
8
_includes/js/vendor/zeroclipboard/LICENSE
vendored
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
The MIT License (MIT)
|
||||||
|
Copyright (c) 2014 Jon Rohan, James M. Greene
|
||||||
|
|
||||||
|
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
|
||||||
|
|
||||||
|
The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
|
||||||
|
|
||||||
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
71
_includes/js/vendor/zeroclipboard/README.md
vendored
Normal file
71
_includes/js/vendor/zeroclipboard/README.md
vendored
Normal file
@ -0,0 +1,71 @@
|
|||||||
|
# ZeroClipboard
|
||||||
|
|
||||||
|
The ZeroClipboard library provides an easy way to copy text to the clipboard using an invisible [Adobe Flash](http://en.wikipedia.org/wiki/Adobe_Flash) movie and a [JavaScript](http://en.wikipedia.org/wiki/JavaScript) interface. The "Zero" signifies that the library is invisible and the user interface is left entirely up to you.
|
||||||
|
|
||||||
|
|
||||||
|
## Simple Example
|
||||||
|
|
||||||
|
``` html
|
||||||
|
<html>
|
||||||
|
<body>
|
||||||
|
<button id="copy-button" data-clipboard-text="Copy Me!" title="Click to copy me.">Copy to Clipboard</button>
|
||||||
|
<script src="ZeroClipboard.js"></script>
|
||||||
|
<script src="main.js"></script>
|
||||||
|
</body>
|
||||||
|
</html>
|
||||||
|
```
|
||||||
|
|
||||||
|
``` js
|
||||||
|
// main.js
|
||||||
|
var client = new ZeroClipboard( document.getElementById("copy-button"), {
|
||||||
|
moviePath: "/path/to/ZeroClipboard.swf"
|
||||||
|
} );
|
||||||
|
|
||||||
|
client.on( "load", function(client) {
|
||||||
|
// alert( "movie is loaded" );
|
||||||
|
|
||||||
|
client.on( "complete", function(client, args) {
|
||||||
|
// `this` is the element that was clicked
|
||||||
|
this.style.display = "none";
|
||||||
|
alert("Copied text to clipboard: " + args.text );
|
||||||
|
} );
|
||||||
|
} );
|
||||||
|
```
|
||||||
|
|
||||||
|
See the [instructions](docs/instructions.md) for more advanced options in using the library on your site.
|
||||||
|
|
||||||
|
Here is a working [test page](http://zeroclipboard.org/#demo) where you can try out ZeroClipboard in your browser.
|
||||||
|
|
||||||
|
|
||||||
|
## Testing ZeroClipboard Locally
|
||||||
|
|
||||||
|
To test the page [demo page](http://zeroclipboard.org/#demo) locally, clone the [website repo](https://github.com/zeroclipboard/zeroclipboard.org).
|
||||||
|
|
||||||
|
|
||||||
|
## Support
|
||||||
|
|
||||||
|
This library is fully compatible with Flash Player 10, which requires that the clipboard copy operation be initiated by a user click event inside the Flash movie. This is achieved by automatically floating the invisible movie on top of a [DOM](http://en.wikipedia.org/wiki/Document_Object_Model) element of your choice. Standard mouse events are even propagated out to your DOM element, so you can still have rollover and mouse down effects.
|
||||||
|
|
||||||
|
Works in IE7+ and all of the evergreen browsers.
|
||||||
|
|
||||||
|
|
||||||
|
## Contributing
|
||||||
|
|
||||||
|
see [CONTRIBUTING.md](CONTRIBUTING.md)
|
||||||
|
|
||||||
|
|
||||||
|
## Releases
|
||||||
|
|
||||||
|
Starting with version [1.1.7](https://github.com/zeroclipboard/zeroclipboard/releases/tag/v1.1.7), ZeroClipboard uses [semantic versioning](http://semver.org/).
|
||||||
|
|
||||||
|
see [releases](https://github.com/zeroclipboard/zeroclipboard/releases)
|
||||||
|
|
||||||
|
|
||||||
|
## Roadmap
|
||||||
|
|
||||||
|
see [roadmap.md](docs/roadmap.md)
|
||||||
|
|
||||||
|
|
||||||
|
## Last Build
|
||||||
|
|
||||||
|
[![Build Status](https://secure.travis-ci.org/zeroclipboard/zeroclipboard.png?branch=master)](https://travis-ci.org/zeroclipboard/zeroclipboard)
|
1010
_includes/js/vendor/zeroclipboard/ZeroClipboard.js
vendored
Normal file
1010
_includes/js/vendor/zeroclipboard/ZeroClipboard.js
vendored
Normal file
File diff suppressed because it is too large
Load Diff
File diff suppressed because one or more lines are too long
BIN
_includes/js/vendor/zeroclipboard/ZeroClipboard.swf
vendored
Normal file
BIN
_includes/js/vendor/zeroclipboard/ZeroClipboard.swf
vendored
Normal file
Binary file not shown.
12
_includes/js/vendor/zeroclipboard/bower.json
vendored
Normal file
12
_includes/js/vendor/zeroclipboard/bower.json
vendored
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
{
|
||||||
|
"name": "zeroclipboard",
|
||||||
|
"description": "The ZeroClipboard library provides an easy way to copy text to the clipboard using an invisible Adobe Flash movie and a JavaScript interface.",
|
||||||
|
"version": "1.3.2",
|
||||||
|
"main": ["./ZeroClipboard.js", "./ZeroClipboard.swf"],
|
||||||
|
"keywords": ["flash","clipboard","copy","cut","paste","zclip","clip","clippy"],
|
||||||
|
"license": "https://github.com/zeroclipboard/zeroclipboard/blob/master/LICENSE",
|
||||||
|
"authors": [{"name":"Jon Rohan","url":"http://jonrohan.me/"},{"name":"James M. Greene","email":"james.m.greene@gmail.com","url":"http://jamesgreene.net/"}],
|
||||||
|
"homepage": "http://zeroclipboard.org/",
|
||||||
|
"repository": {"type":"git","url":"https://github.com/zeroclipboard/zeroclipboard.git"},
|
||||||
|
"location": "git://github.com/zeroclipboard/zeroclipboard.git"
|
||||||
|
}
|
14
_includes/js/vendor/zeroclipboard/composer.json
vendored
Normal file
14
_includes/js/vendor/zeroclipboard/composer.json
vendored
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
{
|
||||||
|
"name": "zeroclipboard/zeroclipboard",
|
||||||
|
"description": "The ZeroClipboard library provides an easy way to copy text to the clipboard using an invisible Adobe Flash movie and a JavaScript interface.",
|
||||||
|
"version": "1.3.2",
|
||||||
|
"type": "library",
|
||||||
|
"keywords": ["flash","clipboard","copy","cut","paste","zclip","clip","clippy"],
|
||||||
|
"license": "MIT",
|
||||||
|
"authors": [{"name":"Jon Rohan","homepage":"http://jonrohan.me/","role":"Developer"},{"name":"James M. Greene","email":"james.m.greene@gmail.com","homepage":"http://jamesgreene.net/","role":"Developer"}],
|
||||||
|
"homepage": "http://zeroclipboard.org/",
|
||||||
|
"support": {
|
||||||
|
"source": "https://github.com/zeroclipboard/zeroclipboard.git",
|
||||||
|
"issues": "https://github.com/zeroclipboard/zeroclipboard/issues"
|
||||||
|
}
|
||||||
|
}
|
31
_includes/js/vendor/zeroclipboard/index.js
vendored
Normal file
31
_includes/js/vendor/zeroclipboard/index.js
vendored
Normal file
@ -0,0 +1,31 @@
|
|||||||
|
|
||||||
|
/**
|
||||||
|
* Module exports.
|
||||||
|
*/
|
||||||
|
|
||||||
|
exports = module.exports = setup;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Module dependencies.
|
||||||
|
*/
|
||||||
|
|
||||||
|
var http = require('http');
|
||||||
|
var send = require('send');
|
||||||
|
var root = __dirname;
|
||||||
|
var swf = '/ZeroClipboard.swf';
|
||||||
|
|
||||||
|
function setup () {
|
||||||
|
return http.createServer(onReq);
|
||||||
|
}
|
||||||
|
|
||||||
|
function onReq (req, res) {
|
||||||
|
send(req, swf)
|
||||||
|
.root(root)
|
||||||
|
.on('error', onError)
|
||||||
|
.pipe(res);
|
||||||
|
}
|
||||||
|
|
||||||
|
function onError (err) {
|
||||||
|
res.statusCode = err.status || 500;
|
||||||
|
res.end(err.message);
|
||||||
|
}
|
68
_includes/js/vendor/zeroclipboard/package.json
vendored
Normal file
68
_includes/js/vendor/zeroclipboard/package.json
vendored
Normal file
@ -0,0 +1,68 @@
|
|||||||
|
{
|
||||||
|
"name": "zeroclipboard",
|
||||||
|
"title": "ZeroClipboard",
|
||||||
|
"version": "1.3.2",
|
||||||
|
"description": "The ZeroClipboard library provides an easy way to copy text to the clipboard using an invisible Adobe Flash movie and a JavaScript interface.",
|
||||||
|
"keywords": [
|
||||||
|
"flash",
|
||||||
|
"clipboard",
|
||||||
|
"copy",
|
||||||
|
"cut",
|
||||||
|
"paste",
|
||||||
|
"zclip",
|
||||||
|
"clip",
|
||||||
|
"clippy"
|
||||||
|
],
|
||||||
|
"homepage": "http://zeroclipboard.org/",
|
||||||
|
"licenses": [
|
||||||
|
{
|
||||||
|
"type": "MIT",
|
||||||
|
"url": "https://github.com/zeroclipboard/zeroclipboard/blob/master/LICENSE"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"contributors": [
|
||||||
|
{
|
||||||
|
"name": "Jon Rohan",
|
||||||
|
"url": "http://jonrohan.me/"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "James M. Greene",
|
||||||
|
"email": "james.m.greene@gmail.com",
|
||||||
|
"url": "http://jamesgreene.net/"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"repository": {
|
||||||
|
"type": "git",
|
||||||
|
"url": "https://github.com/zeroclipboard/zeroclipboard.git"
|
||||||
|
},
|
||||||
|
"bugs": {
|
||||||
|
"url": "https://github.com/zeroclipboard/zeroclipboard/issues"
|
||||||
|
},
|
||||||
|
"dependencies": {
|
||||||
|
"send": "0"
|
||||||
|
},
|
||||||
|
"devDependencies": {
|
||||||
|
"qunitjs": "~1.12.0",
|
||||||
|
"qunit-composite": "~1.0.1",
|
||||||
|
"grunt": "~0.4.2",
|
||||||
|
"grunt-contrib-clean": "~0.5.0",
|
||||||
|
"grunt-contrib-jshint": "~0.7.2",
|
||||||
|
"grunt-contrib-connect": "~0.5.0",
|
||||||
|
"grunt-contrib-qunit": "~0.3.0",
|
||||||
|
"grunt-contrib-concat": "~0.3.0",
|
||||||
|
"grunt-contrib-uglify": "~0.2.7",
|
||||||
|
"grunt-chmod": "~1.0.3",
|
||||||
|
"grunt-mxmlc": "~0.2.0",
|
||||||
|
"grunt-template": "~0.2.1",
|
||||||
|
"grunt-contrib-watch": "~0.5.3"
|
||||||
|
},
|
||||||
|
"main": "./ZeroClipboard.js",
|
||||||
|
"component": {
|
||||||
|
"scripts": {
|
||||||
|
"zeroclipboard": "ZeroClipboard.js"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"scripts": {
|
||||||
|
"test": "grunt travis --verbose"
|
||||||
|
}
|
||||||
|
}
|
18
bower.json
Normal file
18
bower.json
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
{
|
||||||
|
"name": "choosealicense.com",
|
||||||
|
"version": "0.0.1",
|
||||||
|
"homepage": "choosealicense.com",
|
||||||
|
"authors": [
|
||||||
|
"GitHub Inc."
|
||||||
|
],
|
||||||
|
"description": "A site to provide non-judgmental guidance on choosing a license for your open source project",
|
||||||
|
"main": "index.html",
|
||||||
|
"license": "MIT",
|
||||||
|
"dependencies": {
|
||||||
|
"zeroclipboard": "~1.3.2",
|
||||||
|
"jquery": "~2.1.0",
|
||||||
|
"html5shiv": "~3.7.0",
|
||||||
|
"selectivizr": "~1.0.2",
|
||||||
|
"qtip2": "~2.2.0"
|
||||||
|
}
|
||||||
|
}
|
11
js/html5shiv.js
vendored
11
js/html5shiv.js
vendored
@ -1,8 +1,3 @@
|
|||||||
/*
|
---
|
||||||
HTML5 Shiv v3.7.0 | @afarkas @jdalton @jon_neal @rem | MIT/GPL2 Licensed
|
---
|
||||||
*/
|
{% include js/vendor/html5shiv/dist/html5shiv.js %}
|
||||||
(function(l,f){function m(){var a=e.elements;return"string"==typeof a?a.split(" "):a}function i(a){var b=n[a[o]];b||(b={},h++,a[o]=h,n[h]=b);return b}function p(a,b,c){b||(b=f);if(g)return b.createElement(a);c||(c=i(b));b=c.cache[a]?c.cache[a].cloneNode():r.test(a)?(c.cache[a]=c.createElem(a)).cloneNode():c.createElem(a);return b.canHaveChildren&&!s.test(a)?c.frag.appendChild(b):b}function t(a,b){if(!b.cache)b.cache={},b.createElem=a.createElement,b.createFrag=a.createDocumentFragment,b.frag=b.createFrag();
|
|
||||||
a.createElement=function(c){return!e.shivMethods?b.createElem(c):p(c,a,b)};a.createDocumentFragment=Function("h,f","return function(){var n=f.cloneNode(),c=n.createElement;h.shivMethods&&("+m().join().replace(/[\w\-]+/g,function(a){b.createElem(a);b.frag.createElement(a);return'c("'+a+'")'})+");return n}")(e,b.frag)}function q(a){a||(a=f);var b=i(a);if(e.shivCSS&&!j&&!b.hasCSS){var c,d=a;c=d.createElement("p");d=d.getElementsByTagName("head")[0]||d.documentElement;c.innerHTML="x<style>article,aside,dialog,figcaption,figure,footer,header,hgroup,main,nav,section{display:block}mark{background:#FF0;color:#000}template{display:none}</style>";
|
|
||||||
c=d.insertBefore(c.lastChild,d.firstChild);b.hasCSS=!!c}g||t(a,b);return a}var k=l.html5||{},s=/^<|^(?:button|map|select|textarea|object|iframe|option|optgroup)$/i,r=/^(?:a|b|code|div|fieldset|h1|h2|h3|h4|h5|h6|i|label|li|ol|p|q|span|strong|style|table|tbody|td|th|tr|ul)$/i,j,o="_html5shiv",h=0,n={},g;(function(){try{var a=f.createElement("a");a.innerHTML="<xyz></xyz>";j="hidden"in a;var b;if(!(b=1==a.childNodes.length)){f.createElement("a");var c=f.createDocumentFragment();b="undefined"==typeof c.cloneNode||
|
|
||||||
"undefined"==typeof c.createDocumentFragment||"undefined"==typeof c.createElement}g=b}catch(d){g=j=!0}})();var e={elements:k.elements||"abbr article aside audio bdi canvas data datalist details dialog figcaption figure footer header hgroup main mark meter nav output progress section summary template time video",version:"3.7.0",shivCSS:!1!==k.shivCSS,supportsUnknownElements:g,shivMethods:!1!==k.shivMethods,type:"default",shivDocument:q,createElement:p,createDocumentFragment:function(a,b){a||(a=f);
|
|
||||||
if(g)return a.createDocumentFragment();for(var b=b||i(a),c=b.frag.cloneNode(),d=0,e=m(),h=e.length;d<h;d++)c.createElement(e[d]);return c}};l.html5=e;q(f)})(this,document);
|
|
||||||
|
@ -2,8 +2,8 @@
|
|||||||
layout: nil
|
layout: nil
|
||||||
---
|
---
|
||||||
|
|
||||||
{% include js/jquery-1.10.2.min.js %}
|
{% include js/vendor/jquery/jquery.min.js %}
|
||||||
{% include js/jquery.qtip.min.js %}
|
{% include js/vendor/qtip2/jquery.qtip.min.js %}
|
||||||
{% include js/ZeroClipboard.min.js %}
|
{% include js/vendor/zeroclipboard/ZeroClipboard.min.js %}
|
||||||
{% include js/annotations.js %}
|
{% include js/annotations.js %}
|
||||||
{% include js/app.js %}
|
{% include js/app.js %}
|
||||||
|
9
js/selectivizr-min.js
vendored
9
js/selectivizr-min.js
vendored
@ -1,5 +1,4 @@
|
|||||||
/*!
|
---
|
||||||
* selectivizr v1.0.2 - (c) Keith Clark, freely distributable under the terms of the MIT license.
|
---
|
||||||
* selectivizr.com
|
|
||||||
*/
|
{% include js/vendor/selectivizr/selectivizr.js %}
|
||||||
(function(j){function A(a){return a.replace(B,h).replace(C,function(a,d,b){for(var a=b.split(","),b=0,e=a.length;b<e;b++){var s=D(a[b].replace(E,h).replace(F,h))+o,l=[];a[b]=s.replace(G,function(a,b,c,d,e){if(b){if(l.length>0){var a=l,f,e=s.substring(0,e).replace(H,i);if(e==i||e.charAt(e.length-1)==o)e+="*";try{f=t(e)}catch(k){}if(f){e=0;for(c=f.length;e<c;e++){for(var d=f[e],h=d.className,j=0,m=a.length;j<m;j++){var g=a[j];if(!RegExp("(^|\\s)"+g.className+"(\\s|$)").test(d.className)&&g.b&&(g.b===!0||g.b(d)===!0))h=u(h,g.className,!0)}d.className=h}}l=[]}return b}else{if(b=c?I(c):!v||v.test(d)?{className:w(d),b:!0}:null)return l.push(b),"."+b.className;return a}})}return d+a.join(",")})}function I(a){var c=!0,d=w(a.slice(1)),b=a.substring(0,5)==":not(",e,f;b&&(a=a.slice(5,-1));var l=a.indexOf("(");l>-1&&(a=a.substring(0,l));if(a.charAt(0)==":")switch(a.slice(1)){case "root":c=function(a){return b?a!=p:a==p};break;case "target":if(m==8){c=function(a){function c(){var d=location.hash,e=d.slice(1);return b?d==i||a.id!=e:d!=i&&a.id==e}k(j,"hashchange",function(){g(a,d,c())});return c()};break}return!1;case "checked":c=function(a){J.test(a.type)&&k(a,"propertychange",function(){event.propertyName=="checked"&&g(a,d,a.checked!==b)});return a.checked!==b};break;case "disabled":b=!b;case "enabled":c=function(c){if(K.test(c.tagName))return k(c,"propertychange",function(){event.propertyName=="$disabled"&&g(c,d,c.a===b)}),q.push(c),c.a=c.disabled,c.disabled===b;return a==":enabled"?b:!b};break;case "focus":e="focus",f="blur";case "hover":e||(e="mouseenter",f="mouseleave");c=function(a){k(a,b?f:e,function(){g(a,d,!0)});k(a,b?e:f,function(){g(a,d,!1)});return b};break;default:if(!L.test(a))return!1}return{className:d,b:c}}function w(a){return M+"-"+(m==6&&N?O++:a.replace(P,function(a){return a.charCodeAt(0)}))}function D(a){return a.replace(x,h).replace(Q,o)}function g(a,c,d){var b=a.className,c=u(b,c,d);if(c!=b)a.className=c,a.parentNode.className+=i}function u(a,c,d){var b=RegExp("(^|\\s)"+c+"(\\s|$)"),e=b.test(a);return d?e?a:a+o+c:e?a.replace(b,h).replace(x,h):a}function k(a,c,d){a.attachEvent("on"+c,d)}function r(a,c){if(/^https?:\/\//i.test(a))return c.substring(0,c.indexOf("/",8))==a.substring(0,a.indexOf("/",8))?a:null;if(a.charAt(0)=="/")return c.substring(0,c.indexOf("/",8))+a;var d=c.split(/[?#]/)[0];a.charAt(0)!="?"&&d.charAt(d.length-1)!="/"&&(d=d.substring(0,d.lastIndexOf("/")+1));return d+a}function y(a){if(a)return n.open("GET",a,!1),n.send(),(n.status==200?n.responseText:i).replace(R,i).replace(S,function(c,d,b,e,f){return y(r(b||f,a))}).replace(T,function(c,d,b){d=d||i;return" url("+d+r(b,a)+d+") "});return i}function U(){var a,c;a=f.getElementsByTagName("BASE");for(var d=a.length>0?a[0].href:f.location.href,b=0;b<f.styleSheets.length;b++)if(c=f.styleSheets[b],c.href!=i&&(a=r(c.href,d)))c.cssText=A(y(a));q.length>0&&setInterval(function(){for(var a=0,c=q.length;a<c;a++){var b=q[a];if(b.disabled!==b.a)b.disabled?(b.disabled=!1,b.a=!0,b.disabled=!0):b.a=b.disabled}},250)}if(!/*@cc_on!@*/true){var f=document,p=f.documentElement,n=function(){if(j.XMLHttpRequest)return new XMLHttpRequest;try{return new ActiveXObject("Microsoft.XMLHTTP")}catch(a){return null}}(),m=/MSIE (\d+)/.exec(navigator.userAgent)[1];if(!(f.compatMode!="CSS1Compat"||m<6||m>8||!n)){var z={NW:"*.Dom.select",MooTools:"$$",DOMAssistant:"*.$",Prototype:"$$",YAHOO:"*.util.Selector.query",Sizzle:"*",jQuery:"*",dojo:"*.query"},t,q=[],O=0,N=!0,M="slvzr",R=/(\/\*[^*]*\*+([^\/][^*]*\*+)*\/)\s*/g,S=/@import\s*(?:(?:(?:url\(\s*(['"]?)(.*)\1)\s*\))|(?:(['"])(.*)\3))[^;]*;/g,T=/\burl\(\s*(["']?)(?!data:)([^"')]+)\1\s*\)/g,L=/^:(empty|(first|last|only|nth(-last)?)-(child|of-type))$/,B=/:(:first-(?:line|letter))/g,C=/(^|})\s*([^\{]*?[\[:][^{]+)/g,G=/([ +~>])|(:[a-z-]+(?:\(.*?\)+)?)|(\[.*?\])/g,H=/(:not\()?:(hover|enabled|disabled|focus|checked|target|active|visited|first-line|first-letter)\)?/g,P=/[^\w-]/g,K=/^(INPUT|SELECT|TEXTAREA|BUTTON)$/,J=/^(checkbox|radio)$/,v=m>6?/[\$\^*]=(['"])\1/:null,E=/([(\[+~])\s+/g,F=/\s+([)\]+~])/g,Q=/\s+/g,x=/^\s*((?:[\S\s]*\S)?)\s*$/,i="",o=" ",h="$1";(function(a,c){function d(){try{p.doScroll("left")}catch(a){setTimeout(d,50);return}b("poll")}function b(d){if(!(d.type=="readystatechange"&&f.readyState!="complete")&&((d.type=="load"?a:f).detachEvent("on"+d.type,b,!1),!e&&(e=!0)))c.call(a,d.type||d)}var e=!1,g=!0;if(f.readyState=="complete")c.call(a,i);else{if(f.createEventObject&&p.doScroll){try{g=!a.frameElement}catch(h){}g&&d()}k(f,"readystatechange",b);k(a,"load",b)}})(j,function(){for(var a in z){var c,d,b=j;if(j[a]){for(c=z[a].replace("*",a).split(".");(d=c.shift())&&(b=b[d]););if(typeof b=="function"){t=b;U();break}}}})}}})(this);
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user