jekyll-theme-chalk 0.1.1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/404.html +39 -0
- data/LICENSE +21 -0
- data/LICENSE.txt +21 -0
- data/README.md +91 -0
- data/_assets/fonts/cormorant-garamond/Cormorant-Garamond-700.eot +0 -0
- data/_assets/fonts/cormorant-garamond/Cormorant-Garamond-700.ttf +0 -0
- data/_assets/fonts/cormorant-garamond/Cormorant-Garamond-700.woff +0 -0
- data/_assets/fonts/cormorant-garamond/Cormorant-Garamond-700.woff2 +0 -0
- data/_assets/fonts/ionicons/ionicons.eot +0 -0
- data/_assets/fonts/ionicons/ionicons.ttf +0 -0
- data/_assets/fonts/ionicons/ionicons.woff +0 -0
- data/_assets/fonts/lato/Lato-300.eot +0 -0
- data/_assets/fonts/lato/Lato-300.ttf +0 -0
- data/_assets/fonts/lato/Lato-300.woff +0 -0
- data/_assets/fonts/lato/Lato-300.woff2 +0 -0
- data/_assets/fonts/lato/Lato-700.eot +0 -0
- data/_assets/fonts/lato/Lato-700.ttf +0 -0
- data/_assets/fonts/lato/Lato-700.woff +0 -0
- data/_assets/fonts/lato/Lato-700.woff2 +0 -0
- data/_assets/fonts/lato/Lato-regular.eot +0 -0
- data/_assets/fonts/lato/Lato-regular.ttf +0 -0
- data/_assets/fonts/lato/Lato-regular.woff +0 -0
- data/_assets/fonts/lato/Lato-regular.woff2 +0 -0
- data/_assets/images/about.jpg +0 -0
- data/_assets/images/about@2x.jpg +0 -0
- data/_assets/images/apple-touch-icon.png +0 -0
- data/_assets/images/documentation/chalk-intro.png +0 -0
- data/_assets/images/documentation/chalk-intro@2x.png +0 -0
- data/_assets/images/documentation/enlarge.gif +0 -0
- data/_assets/images/documentation/enlarge@2x.gif +0 -0
- data/_assets/images/documentation/sample-image.jpg +0 -0
- data/_assets/images/documentation/sample-image@2x.jpg +0 -0
- data/_assets/images/og-image.jpg +0 -0
- data/_assets/javascripts/application.js +17 -0
- data/_assets/javascripts/scrollappear.js +25 -0
- data/_assets/javascripts/vendor.js +4 -0
- data/_assets/javascripts/webfonts.js +7 -0
- data/_assets/stylesheets/.csscomb.json +196 -0
- data/_assets/stylesheets/.scss-lint.yml +33 -0
- data/_assets/stylesheets/_base.scss +151 -0
- data/_assets/stylesheets/_mixins.scss +28 -0
- data/_assets/stylesheets/_variables.scss +47 -0
- data/_assets/stylesheets/dark.scss +71 -0
- data/_assets/stylesheets/fonts.scss +63 -0
- data/_assets/stylesheets/layouts/_footer.scss +17 -0
- data/_assets/stylesheets/layouts/_grid.scss +102 -0
- data/_assets/stylesheets/light.scss +71 -0
- data/_assets/stylesheets/modules/_about.scss +10 -0
- data/_assets/stylesheets/modules/_articles.scss +213 -0
- data/_assets/stylesheets/modules/_embed.scss +31 -0
- data/_assets/stylesheets/modules/_header.scss +57 -0
- data/_assets/stylesheets/modules/_highlights-dark.scss +415 -0
- data/_assets/stylesheets/modules/_highlights-light.scss +409 -0
- data/_assets/stylesheets/modules/_icons.scss +83 -0
- data/_assets/stylesheets/modules/_scrollappear.scss +14 -0
- data/_assets/stylesheets/notfound-dark.scss +91 -0
- data/_assets/stylesheets/notfound-light.scss +91 -0
- data/_assets/stylesheets/vendor/_normalize.scss +461 -0
- data/_assets/yarn/.yarn-integrity +22 -0
- data/_assets/yarn/fluidbox/.gitattributes +22 -0
- data/_assets/yarn/fluidbox/.npmignore +220 -0
- data/_assets/yarn/fluidbox/.travis.yml +6 -0
- data/_assets/yarn/fluidbox/Gruntfile.js +8 -0
- data/_assets/yarn/fluidbox/LICENSE.md +23 -0
- data/_assets/yarn/fluidbox/README.html +750 -0
- data/_assets/yarn/fluidbox/README.md +396 -0
- data/_assets/yarn/fluidbox/bower.json +35 -0
- data/_assets/yarn/fluidbox/demo/css/styles.min.css +2 -0
- data/_assets/yarn/fluidbox/demo/css/styles.min.css.map +1 -0
- data/_assets/yarn/fluidbox/demo/fonts/BLOKKRegular.eot +0 -0
- data/_assets/yarn/fluidbox/demo/fonts/BLOKKRegular.svg +233 -0
- data/_assets/yarn/fluidbox/demo/fonts/BLOKKRegular.ttf +0 -0
- data/_assets/yarn/fluidbox/demo/fonts/BLOKKRegular.woff +0 -0
- data/_assets/yarn/fluidbox/demo/fonts/fontello.eot +0 -0
- data/_assets/yarn/fluidbox/demo/fonts/fontello.svg +13 -0
- data/_assets/yarn/fluidbox/demo/fonts/fontello.ttf +0 -0
- data/_assets/yarn/fluidbox/demo/fonts/fontello.woff +0 -0
- data/_assets/yarn/fluidbox/demo/index.html +758 -0
- data/_assets/yarn/fluidbox/demo/src/css/styles.scss +1131 -0
- data/_assets/yarn/fluidbox/dist/css/fluidbox.min.css +2 -0
- data/_assets/yarn/fluidbox/dist/css/fluidbox.min.css.map +1 -0
- data/_assets/yarn/fluidbox/dist/js/jquery.fluidbox.min.js +1 -0
- data/_assets/yarn/fluidbox/grunt/aliases.yaml +20 -0
- data/_assets/yarn/fluidbox/grunt/clean.js +5 -0
- data/_assets/yarn/fluidbox/grunt/concurrent.js +33 -0
- data/_assets/yarn/fluidbox/grunt/jshint.js +10 -0
- data/_assets/yarn/fluidbox/grunt/postcss.js +47 -0
- data/_assets/yarn/fluidbox/grunt/sass.js +42 -0
- data/_assets/yarn/fluidbox/grunt/uglify.js +7 -0
- data/_assets/yarn/fluidbox/grunt/watch.js +28 -0
- data/_assets/yarn/fluidbox/index.html +8 -0
- data/_assets/yarn/fluidbox/license.txt +21 -0
- data/_assets/yarn/fluidbox/package.json +61 -0
- data/_assets/yarn/fluidbox/src/css/_fluidbox.scss +95 -0
- data/_assets/yarn/fluidbox/src/css/fluidbox.scss +2 -0
- data/_assets/yarn/fluidbox/src/js/jquery.fluidbox.js +722 -0
- data/_assets/yarn/jquery/AUTHORS.txt +301 -0
- data/_assets/yarn/jquery/LICENSE.txt +36 -0
- data/_assets/yarn/jquery/README.md +67 -0
- data/_assets/yarn/jquery/bower.json +14 -0
- data/_assets/yarn/jquery/dist/core.js +476 -0
- data/_assets/yarn/jquery/dist/jquery.js +10253 -0
- data/_assets/yarn/jquery/dist/jquery.min.js +4 -0
- data/_assets/yarn/jquery/dist/jquery.min.map +1 -0
- data/_assets/yarn/jquery/dist/jquery.slim.js +8160 -0
- data/_assets/yarn/jquery/dist/jquery.slim.min.js +4 -0
- data/_assets/yarn/jquery/dist/jquery.slim.min.map +1 -0
- data/_assets/yarn/jquery/external/sizzle/LICENSE.txt +36 -0
- data/_assets/yarn/jquery/external/sizzle/dist/sizzle.js +2272 -0
- data/_assets/yarn/jquery/external/sizzle/dist/sizzle.min.js +3 -0
- data/_assets/yarn/jquery/external/sizzle/dist/sizzle.min.map +1 -0
- data/_assets/yarn/jquery/package.json +97 -0
- data/_assets/yarn/jquery/src/.eslintrc.json +5 -0
- data/_assets/yarn/jquery/src/ajax.js +855 -0
- data/_assets/yarn/jquery/src/ajax/jsonp.js +102 -0
- data/_assets/yarn/jquery/src/ajax/load.js +76 -0
- data/_assets/yarn/jquery/src/ajax/parseXML.js +30 -0
- data/_assets/yarn/jquery/src/ajax/script.js +77 -0
- data/_assets/yarn/jquery/src/ajax/var/location.js +5 -0
- data/_assets/yarn/jquery/src/ajax/var/nonce.js +7 -0
- data/_assets/yarn/jquery/src/ajax/var/rquery.js +5 -0
- data/_assets/yarn/jquery/src/ajax/xhr.js +169 -0
- data/_assets/yarn/jquery/src/attributes.js +13 -0
- data/_assets/yarn/jquery/src/attributes/attr.js +141 -0
- data/_assets/yarn/jquery/src/attributes/classes.js +174 -0
- data/_assets/yarn/jquery/src/attributes/prop.js +143 -0
- data/_assets/yarn/jquery/src/attributes/support.js +33 -0
- data/_assets/yarn/jquery/src/attributes/val.js +190 -0
- data/_assets/yarn/jquery/src/callbacks.js +234 -0
- data/_assets/yarn/jquery/src/core.js +476 -0
- data/_assets/yarn/jquery/src/core/DOMEval.js +16 -0
- data/_assets/yarn/jquery/src/core/access.js +70 -0
- data/_assets/yarn/jquery/src/core/init.js +128 -0
- data/_assets/yarn/jquery/src/core/nodeName.js +13 -0
- data/_assets/yarn/jquery/src/core/parseHTML.js +65 -0
- data/_assets/yarn/jquery/src/core/ready-no-deferred.js +96 -0
- data/_assets/yarn/jquery/src/core/ready.js +86 -0
- data/_assets/yarn/jquery/src/core/readyException.js +13 -0
- data/_assets/yarn/jquery/src/core/stripAndCollapse.js +14 -0
- data/_assets/yarn/jquery/src/core/support.js +20 -0
- data/_assets/yarn/jquery/src/core/var/rsingleTag.js +6 -0
- data/_assets/yarn/jquery/src/css.js +438 -0
- data/_assets/yarn/jquery/src/css/addGetHookIf.js +26 -0
- data/_assets/yarn/jquery/src/css/adjustCSS.js +71 -0
- data/_assets/yarn/jquery/src/css/curCSS.js +65 -0
- data/_assets/yarn/jquery/src/css/hiddenVisibleSelectors.js +15 -0
- data/_assets/yarn/jquery/src/css/showHide.js +105 -0
- data/_assets/yarn/jquery/src/css/support.js +89 -0
- data/_assets/yarn/jquery/src/css/var/cssExpand.js +5 -0
- data/_assets/yarn/jquery/src/css/var/getStyles.js +17 -0
- data/_assets/yarn/jquery/src/css/var/isHiddenWithinTree.js +34 -0
- data/_assets/yarn/jquery/src/css/var/rmargin.js +5 -0
- data/_assets/yarn/jquery/src/css/var/rnumnonpx.js +7 -0
- data/_assets/yarn/jquery/src/css/var/swap.js +26 -0
- data/_assets/yarn/jquery/src/data.js +179 -0
- data/_assets/yarn/jquery/src/data/Data.js +161 -0
- data/_assets/yarn/jquery/src/data/var/acceptData.js +19 -0
- data/_assets/yarn/jquery/src/data/var/dataPriv.js +7 -0
- data/_assets/yarn/jquery/src/data/var/dataUser.js +7 -0
- data/_assets/yarn/jquery/src/deferred.js +391 -0
- data/_assets/yarn/jquery/src/deferred/exceptionHook.js +21 -0
- data/_assets/yarn/jquery/src/deprecated.js +40 -0
- data/_assets/yarn/jquery/src/dimensions.js +56 -0
- data/_assets/yarn/jquery/src/effects.js +699 -0
- data/_assets/yarn/jquery/src/effects/Tween.js +123 -0
- data/_assets/yarn/jquery/src/effects/animatedSelector.js +15 -0
- data/_assets/yarn/jquery/src/event.js +746 -0
- data/_assets/yarn/jquery/src/event/ajax.js +22 -0
- data/_assets/yarn/jquery/src/event/alias.js +29 -0
- data/_assets/yarn/jquery/src/event/focusin.js +55 -0
- data/_assets/yarn/jquery/src/event/support.js +11 -0
- data/_assets/yarn/jquery/src/event/trigger.js +185 -0
- data/_assets/yarn/jquery/src/exports/amd.js +26 -0
- data/_assets/yarn/jquery/src/exports/global.js +34 -0
- data/_assets/yarn/jquery/src/jquery.js +41 -0
- data/_assets/yarn/jquery/src/manipulation.js +488 -0
- data/_assets/yarn/jquery/src/manipulation/_evalUrl.js +23 -0
- data/_assets/yarn/jquery/src/manipulation/buildFragment.js +104 -0
- data/_assets/yarn/jquery/src/manipulation/getAll.js +32 -0
- data/_assets/yarn/jquery/src/manipulation/setGlobalEval.js +22 -0
- data/_assets/yarn/jquery/src/manipulation/support.js +35 -0
- data/_assets/yarn/jquery/src/manipulation/var/rcheckableType.js +5 -0
- data/_assets/yarn/jquery/src/manipulation/var/rscriptType.js +5 -0
- data/_assets/yarn/jquery/src/manipulation/var/rtagName.js +5 -0
- data/_assets/yarn/jquery/src/manipulation/wrapMap.js +29 -0
- data/_assets/yarn/jquery/src/offset.js +229 -0
- data/_assets/yarn/jquery/src/queue.js +145 -0
- data/_assets/yarn/jquery/src/queue/delay.js +24 -0
- data/_assets/yarn/jquery/src/selector-native.js +237 -0
- data/_assets/yarn/jquery/src/selector-sizzle.js +19 -0
- data/_assets/yarn/jquery/src/selector.js +3 -0
- data/_assets/yarn/jquery/src/serialize.js +130 -0
- data/_assets/yarn/jquery/src/traversing.js +191 -0
- data/_assets/yarn/jquery/src/traversing/findFilter.js +106 -0
- data/_assets/yarn/jquery/src/traversing/var/dir.js +22 -0
- data/_assets/yarn/jquery/src/traversing/var/rneedsContext.js +8 -0
- data/_assets/yarn/jquery/src/traversing/var/siblings.js +17 -0
- data/_assets/yarn/jquery/src/var/ObjectFunctionString.js +7 -0
- data/_assets/yarn/jquery/src/var/arr.js +5 -0
- data/_assets/yarn/jquery/src/var/class2type.js +6 -0
- data/_assets/yarn/jquery/src/var/concat.js +7 -0
- data/_assets/yarn/jquery/src/var/document.js +5 -0
- data/_assets/yarn/jquery/src/var/documentElement.js +7 -0
- data/_assets/yarn/jquery/src/var/fnToString.js +7 -0
- data/_assets/yarn/jquery/src/var/getProto.js +5 -0
- data/_assets/yarn/jquery/src/var/hasOwn.js +7 -0
- data/_assets/yarn/jquery/src/var/indexOf.js +7 -0
- data/_assets/yarn/jquery/src/var/pnum.js +5 -0
- data/_assets/yarn/jquery/src/var/push.js +7 -0
- data/_assets/yarn/jquery/src/var/rcssNum.js +9 -0
- data/_assets/yarn/jquery/src/var/rnothtmlwhite.js +8 -0
- data/_assets/yarn/jquery/src/var/slice.js +7 -0
- data/_assets/yarn/jquery/src/var/support.js +6 -0
- data/_assets/yarn/jquery/src/var/toString.js +7 -0
- data/_assets/yarn/jquery/src/wrap.js +77 -0
- data/_assets/yarn/retinajs/.babelrc +4 -0
- data/_assets/yarn/retinajs/.editorconfig +15 -0
- data/_assets/yarn/retinajs/.eslintignore +2 -0
- data/_assets/yarn/retinajs/.eslintrc +9 -0
- data/_assets/yarn/retinajs/.npmignore +7 -0
- data/_assets/yarn/retinajs/.travis.yml +20 -0
- data/_assets/yarn/retinajs/LICENSE +20 -0
- data/_assets/yarn/retinajs/README.md +267 -0
- data/_assets/yarn/retinajs/bower.json +25 -0
- data/_assets/yarn/retinajs/dist/_retina.sass +68 -0
- data/_assets/yarn/retinajs/dist/_retina.scss +102 -0
- data/_assets/yarn/retinajs/dist/retina.js +100 -0
- data/_assets/yarn/retinajs/dist/retina.js.map +1 -0
- data/_assets/yarn/retinajs/dist/retina.less +56 -0
- data/_assets/yarn/retinajs/dist/retina.min.js +2 -0
- data/_assets/yarn/retinajs/dist/retina.min.js.map +1 -0
- data/_assets/yarn/retinajs/dist/retina.styl +56 -0
- data/_assets/yarn/retinajs/es/_retina.sass +68 -0
- data/_assets/yarn/retinajs/es/_retina.scss +102 -0
- data/_assets/yarn/retinajs/es/retina.js +91 -0
- data/_assets/yarn/retinajs/es/retina.js.map +1 -0
- data/_assets/yarn/retinajs/es/retina.less +56 -0
- data/_assets/yarn/retinajs/es/retina.styl +56 -0
- data/_assets/yarn/retinajs/gulpfile.babel.js +154 -0
- data/_assets/yarn/retinajs/package.json +57 -0
- data/_assets/yarn/retinajs/src/_retina.sass +68 -0
- data/_assets/yarn/retinajs/src/_retina.scss +102 -0
- data/_assets/yarn/retinajs/src/retina.js +246 -0
- data/_assets/yarn/retinajs/src/retina.less +56 -0
- data/_assets/yarn/retinajs/src/retina.styl +56 -0
- data/_assets/yarn/retinajs/test/DOM.js +44 -0
- data/_assets/yarn/retinajs/test/fixtures/image.js +19 -0
- data/_assets/yarn/retinajs/test/fixtures/less_expected_output.css +18 -0
- data/_assets/yarn/retinajs/test/fixtures/scss_expected_output.css +13 -0
- data/_assets/yarn/retinajs/test/fixtures/test.less +10 -0
- data/_assets/yarn/retinajs/test/fixtures/test.scss +11 -0
- data/_assets/yarn/retinajs/test/fixtures/xml_http_request.js +24 -0
- data/_assets/yarn/retinajs/test/functional/public/google-logo.png +0 -0
- data/_assets/yarn/retinajs/test/functional/public/google-logo@2x.png +0 -0
- data/_assets/yarn/retinajs/test/functional/public/google-logo@3x.png +0 -0
- data/_assets/yarn/retinajs/test/functional/public/index.html +190 -0
- data/_assets/yarn/retinajs/test/functional/public/ipad.png +0 -0
- data/_assets/yarn/retinajs/test/functional/public/ipad@2x.png +0 -0
- data/_assets/yarn/retinajs/test/functional/public/ipad@3x.png +0 -0
- data/_assets/yarn/retinajs/test/functional/public/styles/_retina.sass +68 -0
- data/_assets/yarn/retinajs/test/functional/public/styles/_retina.scss +102 -0
- data/_assets/yarn/retinajs/test/functional/public/styles/less-base.less +13 -0
- data/_assets/yarn/retinajs/test/functional/public/styles/retina.less +56 -0
- data/_assets/yarn/retinajs/test/functional/public/styles/retina.less.css +73 -0
- data/_assets/yarn/retinajs/test/functional/public/styles/retina.sass.css +42 -0
- data/_assets/yarn/retinajs/test/functional/public/styles/retina.scss.css +96 -0
- data/_assets/yarn/retinajs/test/functional/public/styles/retina.styl +56 -0
- data/_assets/yarn/retinajs/test/functional/public/styles/retina.styl.css +61 -0
- data/_assets/yarn/retinajs/test/functional/public/styles/sass-base.sass +10 -0
- data/_assets/yarn/retinajs/test/functional/public/styles/scss-base.scss +13 -0
- data/_assets/yarn/retinajs/test/functional/public/styles/styl-base.styl +10 -0
- data/_assets/yarn/retinajs/test/mocha-runner.js +7 -0
- data/_assets/yarn/retinajs/test/retina.spec.js +14 -0
- data/_assets/yarn/scrollreveal/.gitattributes +10 -0
- data/_assets/yarn/scrollreveal/.github/CONTRIBUTING.md +9 -0
- data/_assets/yarn/scrollreveal/.github/ISSUE_TEMPLATE.md +11 -0
- data/_assets/yarn/scrollreveal/.ignore/coverage/PhantomJS 2.1.1 (Mac OS X 0.0.0)/lcov-report/base.css +213 -0
- data/_assets/yarn/scrollreveal/.ignore/coverage/PhantomJS 2.1.1 (Mac OS X 0.0.0)/lcov-report/index.html +158 -0
- data/_assets/yarn/scrollreveal/.ignore/coverage/PhantomJS 2.1.1 (Mac OS X 0.0.0)/lcov-report/lib/index.html +93 -0
- data/_assets/yarn/scrollreveal/.ignore/coverage/PhantomJS 2.1.1 (Mac OS X 0.0.0)/lcov-report/lib/package.json.html +143 -0
- data/_assets/yarn/scrollreveal/.ignore/coverage/PhantomJS 2.1.1 (Mac OS X 0.0.0)/lcov-report/lib/src/instance/constructor.js.html +311 -0
- data/_assets/yarn/scrollreveal/.ignore/coverage/PhantomJS 2.1.1 (Mac OS X 0.0.0)/lcov-report/lib/src/instance/defaults.js.html +158 -0
- data/_assets/yarn/scrollreveal/.ignore/coverage/PhantomJS 2.1.1 (Mac OS X 0.0.0)/lcov-report/lib/src/instance/functions/animate.js.html +395 -0
- data/_assets/yarn/scrollreveal/.ignore/coverage/PhantomJS 2.1.1 (Mac OS X 0.0.0)/lcov-report/lib/src/instance/functions/delegate.js.html +179 -0
- data/_assets/yarn/scrollreveal/.ignore/coverage/PhantomJS 2.1.1 (Mac OS X 0.0.0)/lcov-report/lib/src/instance/functions/index.html +145 -0
- data/_assets/yarn/scrollreveal/.ignore/coverage/PhantomJS 2.1.1 (Mac OS X 0.0.0)/lcov-report/lib/src/instance/functions/initialize.js.html +197 -0
- data/_assets/yarn/scrollreveal/.ignore/coverage/PhantomJS 2.1.1 (Mac OS X 0.0.0)/lcov-report/lib/src/instance/functions/rinse.js.html +311 -0
- data/_assets/yarn/scrollreveal/.ignore/coverage/PhantomJS 2.1.1 (Mac OS X 0.0.0)/lcov-report/lib/src/instance/functions/style.js.html +617 -0
- data/_assets/yarn/scrollreveal/.ignore/coverage/PhantomJS 2.1.1 (Mac OS X 0.0.0)/lcov-report/lib/src/instance/index.html +119 -0
- data/_assets/yarn/scrollreveal/.ignore/coverage/PhantomJS 2.1.1 (Mac OS X 0.0.0)/lcov-report/lib/src/instance/methods/clean.js.html +137 -0
- data/_assets/yarn/scrollreveal/.ignore/coverage/PhantomJS 2.1.1 (Mac OS X 0.0.0)/lcov-report/lib/src/instance/methods/destroy.js.html +182 -0
- data/_assets/yarn/scrollreveal/.ignore/coverage/PhantomJS 2.1.1 (Mac OS X 0.0.0)/lcov-report/lib/src/instance/methods/index.html +132 -0
- data/_assets/yarn/scrollreveal/.ignore/coverage/PhantomJS 2.1.1 (Mac OS X 0.0.0)/lcov-report/lib/src/instance/methods/reveal.js.html +524 -0
- data/_assets/yarn/scrollreveal/.ignore/coverage/PhantomJS 2.1.1 (Mac OS X 0.0.0)/lcov-report/lib/src/instance/methods/sync.js.html +125 -0
- data/_assets/yarn/scrollreveal/.ignore/coverage/PhantomJS 2.1.1 (Mac OS X 0.0.0)/lcov-report/lib/src/instance/noop.js.html +89 -0
- data/_assets/yarn/scrollreveal/.ignore/coverage/PhantomJS 2.1.1 (Mac OS X 0.0.0)/lcov-report/lib/src/polyfills/index.html +93 -0
- data/_assets/yarn/scrollreveal/.ignore/coverage/PhantomJS 2.1.1 (Mac OS X 0.0.0)/lcov-report/lib/src/polyfills/requestAnimationFrame.js.html +125 -0
- data/_assets/yarn/scrollreveal/.ignore/coverage/PhantomJS 2.1.1 (Mac OS X 0.0.0)/lcov-report/lib/src/utils/browser.js.html +272 -0
- data/_assets/yarn/scrollreveal/.ignore/coverage/PhantomJS 2.1.1 (Mac OS X 0.0.0)/lcov-report/lib/src/utils/core.js.html +434 -0
- data/_assets/yarn/scrollreveal/.ignore/coverage/PhantomJS 2.1.1 (Mac OS X 0.0.0)/lcov-report/lib/src/utils/generic.js.html +218 -0
- data/_assets/yarn/scrollreveal/.ignore/coverage/PhantomJS 2.1.1 (Mac OS X 0.0.0)/lcov-report/lib/src/utils/index.html +119 -0
- data/_assets/yarn/scrollreveal/.ignore/coverage/PhantomJS 2.1.1 (Mac OS X 0.0.0)/lcov-report/prettify.css +1 -0
- data/_assets/yarn/scrollreveal/.ignore/coverage/PhantomJS 2.1.1 (Mac OS X 0.0.0)/lcov-report/prettify.js +1 -0
- data/_assets/yarn/scrollreveal/.ignore/coverage/PhantomJS 2.1.1 (Mac OS X 0.0.0)/lcov-report/sort-arrow-sprite.png +0 -0
- data/_assets/yarn/scrollreveal/.ignore/coverage/PhantomJS 2.1.1 (Mac OS X 0.0.0)/lcov-report/sorter.js +158 -0
- data/_assets/yarn/scrollreveal/.ignore/coverage/PhantomJS 2.1.1 (Mac OS X 0.0.0)/lcov.info +1016 -0
- data/_assets/yarn/scrollreveal/.ignore/coverage/server.coverage.js +11 -0
- data/_assets/yarn/scrollreveal/.ignore/sandbox/css/styles.css +32 -0
- data/_assets/yarn/scrollreveal/.ignore/sandbox/index.html +68 -0
- data/_assets/yarn/scrollreveal/.ignore/sandbox/js/scrollreveal.js +1271 -0
- data/_assets/yarn/scrollreveal/.ignore/sandbox/rollup.conf.sandbox.js +15 -0
- data/_assets/yarn/scrollreveal/.ignore/sandbox/server.sandbox.js +11 -0
- data/_assets/yarn/scrollreveal/.npmignore +8 -0
- data/_assets/yarn/scrollreveal/CHANGELOG.md +268 -0
- data/_assets/yarn/scrollreveal/LICENSE.md +12 -0
- data/_assets/yarn/scrollreveal/README.md +413 -0
- data/_assets/yarn/scrollreveal/bower.json +24 -0
- data/_assets/yarn/scrollreveal/dist/scrollreveal.js +860 -0
- data/_assets/yarn/scrollreveal/dist/scrollreveal.min.js +1 -0
- data/_assets/yarn/scrollreveal/gulpfile.js +33 -0
- data/_assets/yarn/scrollreveal/lib/gulp/gulp-clean.js +7 -0
- data/_assets/yarn/scrollreveal/lib/gulp/gulp-dev.js +6 -0
- data/_assets/yarn/scrollreveal/lib/gulp/gulp-dist-min.js +19 -0
- data/_assets/yarn/scrollreveal/lib/gulp/gulp-dist.js +6 -0
- data/_assets/yarn/scrollreveal/lib/gulp/gulp-server.js +9 -0
- data/_assets/yarn/scrollreveal/lib/gulp/gulp-validate-bower.js +13 -0
- data/_assets/yarn/scrollreveal/lib/gulp/gulp-watch.js +6 -0
- data/_assets/yarn/scrollreveal/src/scrollreveal.js +860 -0
- data/_assets/yarn/throttle-debounce-fn/.jscsrc +5 -0
- data/_assets/yarn/throttle-debounce-fn/.jshintrc +13 -0
- data/_assets/yarn/throttle-debounce-fn/.npmignore +1 -0
- data/_assets/yarn/throttle-debounce-fn/Gruntfile.js +76 -0
- data/_assets/yarn/throttle-debounce-fn/LICENSE.md +22 -0
- data/_assets/yarn/throttle-debounce-fn/README.md +55 -0
- data/_assets/yarn/throttle-debounce-fn/dist/throttle-debounce-fn.js +164 -0
- data/_assets/yarn/throttle-debounce-fn/dist/throttle-debounce-fn.min.js +10 -0
- data/_assets/yarn/throttle-debounce-fn/package.json +36 -0
- data/_assets/yarn/throttle-debounce-fn/src/throttle-debounce-fn.js +156 -0
- data/_assets/yarn/turbolinks/LICENSE +20 -0
- data/_assets/yarn/turbolinks/README.md +473 -0
- data/_assets/yarn/turbolinks/dist/turbolinks.js +6 -0
- data/_assets/yarn/turbolinks/src/turbolinks/BANNER.js.erb +4 -0
- data/_assets/yarn/turbolinks/src/turbolinks/VERSION +1 -0
- data/_assets/yarn/turbolinks/src/turbolinks/browser_adapter.coffee +61 -0
- data/_assets/yarn/turbolinks/src/turbolinks/compatibility.coffee +30 -0
- data/_assets/yarn/turbolinks/src/turbolinks/controller.coffee +239 -0
- data/_assets/yarn/turbolinks/src/turbolinks/error_renderer.coffee +21 -0
- data/_assets/yarn/turbolinks/src/turbolinks/head_details.coffee +51 -0
- data/_assets/yarn/turbolinks/src/turbolinks/helpers.coffee +57 -0
- data/_assets/yarn/turbolinks/src/turbolinks/history.coffee +48 -0
- data/_assets/yarn/turbolinks/src/turbolinks/http_request.coffee +88 -0
- data/_assets/yarn/turbolinks/src/turbolinks/index.coffee +18 -0
- data/_assets/yarn/turbolinks/src/turbolinks/location.coffee +70 -0
- data/_assets/yarn/turbolinks/src/turbolinks/progress_bar.coffee +83 -0
- data/_assets/yarn/turbolinks/src/turbolinks/renderer.coffee +27 -0
- data/_assets/yarn/turbolinks/src/turbolinks/scroll_manager.coffee +28 -0
- data/_assets/yarn/turbolinks/src/turbolinks/snapshot.coffee +47 -0
- data/_assets/yarn/turbolinks/src/turbolinks/snapshot_cache.coffee +43 -0
- data/_assets/yarn/turbolinks/src/turbolinks/snapshot_renderer.coffee +88 -0
- data/_assets/yarn/turbolinks/src/turbolinks/start.coffee +18 -0
- data/_assets/yarn/turbolinks/src/turbolinks/view.coffee +34 -0
- data/_assets/yarn/turbolinks/src/turbolinks/visit.coffee +162 -0
- data/_assets/yarn/webfontloader/CHANGELOG +419 -0
- data/_assets/yarn/webfontloader/LICENSE +176 -0
- data/_assets/yarn/webfontloader/README.md +394 -0
- data/_assets/yarn/webfontloader/package.json +37 -0
- data/_assets/yarn/webfontloader/src/closure.js +2 -0
- data/_assets/yarn/webfontloader/src/core/cssclassname.js +46 -0
- data/_assets/yarn/webfontloader/src/core/domhelper.js +405 -0
- data/_assets/yarn/webfontloader/src/core/eventdispatcher.js +195 -0
- data/_assets/yarn/webfontloader/src/core/font.js +140 -0
- data/_assets/yarn/webfontloader/src/core/fontmodule.js +16 -0
- data/_assets/yarn/webfontloader/src/core/fontmoduleloader.js +47 -0
- data/_assets/yarn/webfontloader/src/core/fontruler.js +60 -0
- data/_assets/yarn/webfontloader/src/core/fontwatcher.js +171 -0
- data/_assets/yarn/webfontloader/src/core/fontwatchrunner.js +249 -0
- data/_assets/yarn/webfontloader/src/core/initialize.js +97 -0
- data/_assets/yarn/webfontloader/src/core/nativefontwatchrunner.js +69 -0
- data/_assets/yarn/webfontloader/src/core/stylesheetwaiter.js +48 -0
- data/_assets/yarn/webfontloader/src/core/webfont.js +97 -0
- data/_assets/yarn/webfontloader/src/modules/custom.js +63 -0
- data/_assets/yarn/webfontloader/src/modules/fontdeck.js +66 -0
- data/_assets/yarn/webfontloader/src/modules/google/fontapiparser.js +181 -0
- data/_assets/yarn/webfontloader/src/modules/google/fontapiurlbuilder.js +77 -0
- data/_assets/yarn/webfontloader/src/modules/google/googlefontapi.js +54 -0
- data/_assets/yarn/webfontloader/src/modules/monotype.js +110 -0
- data/_assets/yarn/webfontloader/src/modules/typekit.js +73 -0
- data/_assets/yarn/webfontloader/webfontloader.js +17 -0
- data/_includes/footer.html +7 -0
- data/_includes/head.html +41 -0
- data/_includes/image.html +5 -0
- data/_includes/javascript.html +1 -0
- data/_includes/javascripts.html +19 -0
- data/_includes/navigation.html +75 -0
- data/_includes/stylesheet.html +1 -0
- data/_layouts/articles_by_tag.html +38 -0
- data/_layouts/default.html +16 -0
- data/_layouts/post.html +65 -0
- data/about.html +18 -0
- data/favicon.ico +0 -0
- data/feed.xml +20 -0
- data/index.html +49 -0
- data/robots.txt +5 -0
- metadata +596 -0
@@ -0,0 +1,25 @@
|
|
1
|
+
{
|
2
|
+
"name": "retinajs",
|
3
|
+
"version": "2.0.0",
|
4
|
+
"homepage": "http://retinajs.com",
|
5
|
+
"authors": [
|
6
|
+
"Axial <developer@axial.agency>"
|
7
|
+
],
|
8
|
+
"description": "JavaScript, Less and Sass helpers for rendering high-resolution image variants",
|
9
|
+
"main": "dist/retina.js",
|
10
|
+
"license": "MIT",
|
11
|
+
"ignore": [
|
12
|
+
"**/.*",
|
13
|
+
"node_modules",
|
14
|
+
"bower_components",
|
15
|
+
"test",
|
16
|
+
"tests"
|
17
|
+
],
|
18
|
+
"moduleType": [
|
19
|
+
"amd",
|
20
|
+
"es6",
|
21
|
+
"globals",
|
22
|
+
"node",
|
23
|
+
"yui"
|
24
|
+
]
|
25
|
+
}
|
@@ -0,0 +1,68 @@
|
|
1
|
+
// retina.sass
|
2
|
+
// A helper mixin for applying high-resolution background images (http://www.retinajs.com)
|
3
|
+
|
4
|
+
// Submitted by Nathan Crank
|
5
|
+
// nathancrank.com
|
6
|
+
|
7
|
+
// Updated by John Newman
|
8
|
+
// github.com/jgnewman
|
9
|
+
// http://axial.agency
|
10
|
+
|
11
|
+
/**
|
12
|
+
* Allows you to use retina images at various pixel densities.
|
13
|
+
* Examples:
|
14
|
+
*
|
15
|
+
* +retina(/images/mypic.jpg, 2);
|
16
|
+
* +retina(/images/mypic.jpg, 3, 100px 100px, left top no-repeat transparent);
|
17
|
+
*
|
18
|
+
* @param {Value} $path The path to the file name minus extension.
|
19
|
+
* @param {Number} $cap: 2 The highest pixel density level images exist for.
|
20
|
+
* @param {Value} $size: auto auto The intended width of the rendered image.
|
21
|
+
* @param {Value} $extras: null Any other `background` values to be added.
|
22
|
+
*/
|
23
|
+
=retina($path, $cap: 2, $size: auto auto, $extras: null)
|
24
|
+
|
25
|
+
// Set a counter and get the length of the image path.
|
26
|
+
$position: -1
|
27
|
+
$strpath: '#{$path}'
|
28
|
+
$length: str-length($strpath)
|
29
|
+
|
30
|
+
// Loop ver the image path and figure out the
|
31
|
+
// position of the dot where the extension begins.
|
32
|
+
@for $i from $length through $length - 10
|
33
|
+
@if $position == -1
|
34
|
+
$char: str-slice($strpath, $i,$i)
|
35
|
+
@if str-index($char, ".") == 1
|
36
|
+
$position: $i
|
37
|
+
|
38
|
+
// If we were able to figure out where the extension is,
|
39
|
+
// slice the path into a base and an extension. Use that to
|
40
|
+
// calculate urls for different density environments. Set
|
41
|
+
// values for different environments.
|
42
|
+
@if $position != -1
|
43
|
+
$ext: str-slice($strpath, $position + 1, $length)
|
44
|
+
$base: str-slice($strpath, 1 ,$position - 1)
|
45
|
+
$at1x_path: "#{$base}.#{$ext}"
|
46
|
+
$at2x_path: "#{$base}@2x.#{$ext}"
|
47
|
+
|
48
|
+
// Set a base background for 1x environments.
|
49
|
+
background: url("#{$at1x_path}") $extras
|
50
|
+
background-size: $size
|
51
|
+
|
52
|
+
// Create an @2x-ish media query.
|
53
|
+
@media all and (-webkit-min-device-pixel-ratio: 1.5), all and (-o-min-device-pixel-ratio: 3/2), all and (min--moz-device-pixel-ratio: 1.5), all and (min-device-pixel-ratio: 1.5)
|
54
|
+
background: url("#{$at2x_path}") $extras
|
55
|
+
background-size: $size
|
56
|
+
|
57
|
+
// Create media queries for all environments that the user has
|
58
|
+
// provided images for.
|
59
|
+
@if $cap >= 2
|
60
|
+
@for $env from 2 through $cap
|
61
|
+
$suffix: "@#{$env}x"
|
62
|
+
@media (-webkit-min-device-pixel-ratio: $env), (min-resolution: $env * 96dpi)
|
63
|
+
background: url("#{$base}#{$suffix}.#{$ext}") $extras
|
64
|
+
background-size: $size
|
65
|
+
|
66
|
+
@else
|
67
|
+
background: url("#{$path}") $extras
|
68
|
+
background-size: $size
|
@@ -0,0 +1,102 @@
|
|
1
|
+
// retina.scss
|
2
|
+
// A helper mixin for applying high-resolution background images (http://www.retinajs.com)
|
3
|
+
|
4
|
+
// Submitted by Nathan Crank
|
5
|
+
// nathancrank.com
|
6
|
+
|
7
|
+
// Updated by Gabriel R. Sezefredo
|
8
|
+
// gabriel.sezefredo.com.br
|
9
|
+
|
10
|
+
// Updated by John Newman
|
11
|
+
// github.com/jgnewman
|
12
|
+
// http://axial.agency
|
13
|
+
|
14
|
+
|
15
|
+
/**
|
16
|
+
* Allows you to use retina images at various pixel densities.
|
17
|
+
* Examples:
|
18
|
+
*
|
19
|
+
* @include retina(/images/mypic.jpg, 2);
|
20
|
+
* @include retina(/images/mypic.jpg, 3, 100px 100px, left top no-repeat transparent);
|
21
|
+
*
|
22
|
+
* @param {Value} $path The path to the file name minus extension.
|
23
|
+
* @param {Number} $cap: 2 The highest pixel density level images exist for.
|
24
|
+
* @param {Value} $size: auto auto The intended width of the rendered image.
|
25
|
+
* @param {Value} $extras: null Any other `background` values to be added.
|
26
|
+
*/
|
27
|
+
@mixin retina($path, $cap: 2, $size: auto auto, $extras: null) {
|
28
|
+
|
29
|
+
/*
|
30
|
+
* Set a counter and get the length of the image path.
|
31
|
+
*/
|
32
|
+
$position: -1;
|
33
|
+
$strpath: '#{$path}';
|
34
|
+
$length: str-length($strpath);
|
35
|
+
|
36
|
+
/*
|
37
|
+
* Loop ver the image path and figure out the
|
38
|
+
* position of the dot where the extension begins.
|
39
|
+
*/
|
40
|
+
@for $i from $length through $length - 10{
|
41
|
+
@if $position == -1 {
|
42
|
+
$char : str-slice($strpath, $i, $i);
|
43
|
+
@if str-index($char, ".") == 1 {
|
44
|
+
$position: $i;
|
45
|
+
}
|
46
|
+
}
|
47
|
+
}
|
48
|
+
|
49
|
+
/*
|
50
|
+
* If we were able to figure out where the extension is,
|
51
|
+
* slice the path into a base and an extension. Use that to
|
52
|
+
* calculate urls for different density environments. Set
|
53
|
+
* values for different environments.
|
54
|
+
*/
|
55
|
+
@if $position != -1 {
|
56
|
+
$ext: str-slice($strpath, $position + 1, $length);
|
57
|
+
$base: str-slice($strpath, 1, $position - 1);
|
58
|
+
$at1x_path: "#{$base}.#{$ext}";
|
59
|
+
$at2x_path: "#{$base}@2x.#{$ext}";
|
60
|
+
|
61
|
+
/*
|
62
|
+
* Set a base background for 1x environments.
|
63
|
+
*/
|
64
|
+
background: url("#{$at1x_path}") $extras;
|
65
|
+
background-size: $size;
|
66
|
+
|
67
|
+
/*
|
68
|
+
* Create an @2x-ish media query.
|
69
|
+
*/
|
70
|
+
@media all and (-webkit-min-device-pixel-ratio : 1.5),
|
71
|
+
all and (-o-min-device-pixel-ratio: 3/2),
|
72
|
+
all and (min--moz-device-pixel-ratio: 1.5),
|
73
|
+
all and (min-device-pixel-ratio: 1.5) {
|
74
|
+
background : url("#{$at2x_path}") $extras;
|
75
|
+
background-size : $size;
|
76
|
+
}
|
77
|
+
|
78
|
+
/*
|
79
|
+
* Create media queries for all environments that the user has
|
80
|
+
* provided images for.
|
81
|
+
*/
|
82
|
+
@if $cap >= 2 {
|
83
|
+
@for $env from 2 through $cap {
|
84
|
+
$suffix: "@#{$env}x";
|
85
|
+
@media (-webkit-min-device-pixel-ratio: $env),
|
86
|
+
(min-resolution: $env * 96dpi) {
|
87
|
+
background : url("#{$base}#{$suffix}.#{$ext}") $extras;
|
88
|
+
background-size : $size;
|
89
|
+
}
|
90
|
+
}
|
91
|
+
}
|
92
|
+
|
93
|
+
/*
|
94
|
+
* If anything went wrong trying to separate the file from its
|
95
|
+
* extension, set a background value without doing anything to it.
|
96
|
+
*/
|
97
|
+
} @else {
|
98
|
+
background: url("#{$path}") $extras;
|
99
|
+
background-size: $size;
|
100
|
+
}
|
101
|
+
|
102
|
+
}
|
@@ -0,0 +1,100 @@
|
|
1
|
+
(function (global, factory) {
|
2
|
+
typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :
|
3
|
+
typeof define === 'function' && define.amd ? define(factory) :
|
4
|
+
(global.retinajs = factory());
|
5
|
+
}(this, (function () { 'use strict';
|
6
|
+
|
7
|
+
var hasWindow = typeof window !== 'undefined';
|
8
|
+
var environment = Math.round(hasWindow ? window.devicePixelRatio || 1 : 1);
|
9
|
+
var srcReplace = /(\.[A-z]{3,4}\/?(\?.*)?)$/;
|
10
|
+
var inlineReplace = /url\(('|")?([^)'"]+)('|")?\)/i;
|
11
|
+
var selector = '[data-rjs]';
|
12
|
+
var processedAttr = 'data-rjs-processed';
|
13
|
+
function arrayify(object) {
|
14
|
+
return Array.prototype.slice.call(object);
|
15
|
+
}
|
16
|
+
function chooseCap(cap) {
|
17
|
+
var numericCap = parseInt(cap, 10);
|
18
|
+
if (environment < numericCap) {
|
19
|
+
return environment;
|
20
|
+
} else {
|
21
|
+
return numericCap;
|
22
|
+
}
|
23
|
+
}
|
24
|
+
function forceOriginalDimensions(image) {
|
25
|
+
if (!image.hasAttribute('data-no-resize')) {
|
26
|
+
if (image.offsetWidth === 0 && image.offsetHeight === 0) {
|
27
|
+
image.setAttribute('width', image.naturalWidth);
|
28
|
+
image.setAttribute('height', image.naturalHeight);
|
29
|
+
} else {
|
30
|
+
image.setAttribute('width', image.offsetWidth);
|
31
|
+
image.setAttribute('height', image.offsetHeight);
|
32
|
+
}
|
33
|
+
}
|
34
|
+
return image;
|
35
|
+
}
|
36
|
+
function setSourceIfAvailable(image, retinaURL) {
|
37
|
+
var imgType = image.nodeName.toLowerCase();
|
38
|
+
var testImage = document.createElement('img');
|
39
|
+
testImage.addEventListener('load', function () {
|
40
|
+
if (imgType === 'img') {
|
41
|
+
forceOriginalDimensions(image).setAttribute('src', retinaURL);
|
42
|
+
} else {
|
43
|
+
image.style.backgroundImage = 'url(' + retinaURL + ')';
|
44
|
+
}
|
45
|
+
});
|
46
|
+
testImage.setAttribute('src', retinaURL);
|
47
|
+
image.setAttribute(processedAttr, true);
|
48
|
+
}
|
49
|
+
function dynamicSwapImage(image, src) {
|
50
|
+
var rjs = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 1;
|
51
|
+
var cap = chooseCap(rjs);
|
52
|
+
if (src && cap > 1) {
|
53
|
+
var newSrc = src.replace(srcReplace, '@' + cap + 'x$1');
|
54
|
+
setSourceIfAvailable(image, newSrc);
|
55
|
+
}
|
56
|
+
}
|
57
|
+
function manualSwapImage(image, src, hdsrc) {
|
58
|
+
if (environment > 1) {
|
59
|
+
setSourceIfAvailable(image, hdsrc);
|
60
|
+
}
|
61
|
+
}
|
62
|
+
function getImages(images) {
|
63
|
+
if (!images) {
|
64
|
+
return typeof document !== 'undefined' ? arrayify(document.querySelectorAll(selector)) : [];
|
65
|
+
} else {
|
66
|
+
return typeof images.forEach === 'function' ? images : arrayify(images);
|
67
|
+
}
|
68
|
+
}
|
69
|
+
function cleanBgImg(img) {
|
70
|
+
return img.style.backgroundImage.replace(inlineReplace, '$2');
|
71
|
+
}
|
72
|
+
function retina(images) {
|
73
|
+
getImages(images).forEach(function (img) {
|
74
|
+
if (!img.getAttribute(processedAttr)) {
|
75
|
+
var isImg = img.nodeName.toLowerCase() === 'img';
|
76
|
+
var src = isImg ? img.getAttribute('src') : cleanBgImg(img);
|
77
|
+
var rjs = img.getAttribute('data-rjs');
|
78
|
+
var rjsIsNumber = !isNaN(parseInt(rjs, 10));
|
79
|
+
if (rjs === null) {
|
80
|
+
return;
|
81
|
+
}
|
82
|
+
if (rjsIsNumber) {
|
83
|
+
dynamicSwapImage(img, src, rjs);
|
84
|
+
} else {
|
85
|
+
manualSwapImage(img, src, rjs);
|
86
|
+
}
|
87
|
+
}
|
88
|
+
});
|
89
|
+
}
|
90
|
+
if (hasWindow) {
|
91
|
+
window.addEventListener('load', function () {
|
92
|
+
retina();
|
93
|
+
});
|
94
|
+
window.retinajs = retina;
|
95
|
+
}
|
96
|
+
|
97
|
+
return retina;
|
98
|
+
|
99
|
+
})));
|
100
|
+
//# sourceMappingURL=retina.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"retina.js","sources":["../src/retina.js"],"sourcesContent":["/* @flow */\n\n/**\n * --------------------------------------------------------------------------\n * Retina.js\n * Licensed under MIT (https://github.com/strues/retinajs/blob/master/LICENSE)\n *\n * Retina.js is an open source script that makes it easy to serve high-resolution\n * images to devices with retina displays.\n * --------------------------------------------------------------------------\n */\n\n/*\n * Determine whether or not `window` is available.\n */\nconst hasWindow = typeof window !== 'undefined';\n\n/*\n * Get the device pixel ratio per our environment.\n * Default to 1.\n */\nconst environment = Math.round(hasWindow ? window.devicePixelRatio || 1 : 1);\n\n/*\n * Define a pattern for capturing src url suffixes.\n */\nconst srcReplace = /(\\.[A-z]{3,4}\\/?(\\?.*)?)$/;\nconst inlineReplace = /url\\(('|\")?([^)'\"]+)('|\")?\\)/i;\n\n/*\n * Define our selectors for elements to target.\n */\nconst selector = '[data-rjs]';\n\n/*\n * Define the attribute we'll use to mark an image as having been processed.\n */\nconst processedAttr = 'data-rjs-processed';\n\n/**\n * Shortcut for turning some iterable object into an array.\n *\n * @param {Iterable} object Any iterable object.\n *\n * @return {Array}\n */\nfunction arrayify(object) {\n return Array.prototype.slice.call(object);\n}\n\n/**\n * Chooses the actual image size to fetch, (for example 2 or 3) that\n * will be used to create a suffix like \"@2x\" or \"@3x\".\n *\n * @param {String|Number} cap The number the user provided indicating that\n * they have prepared images up to this size.\n *\n * @return {Number} The number we'll be using to create a suffix.\n */\nfunction chooseCap(cap) {\n const numericCap = parseInt(cap, 10);\n\n /*\n * If the environment's device pixel ratio is less than what the user\n * provided, we'll only grab images at that size.\n */\n if (environment < numericCap) {\n return environment;\n\n /*\n * If the device pixel ratio is greater than or equal to what the\n * user provided, we'll use what the user provided.\n */\n } else {\n return numericCap;\n }\n}\n\n/**\n * Makes sure that, since we are going to swap out the source of an image,\n * the image does not change size on the page.\n *\n * @param {Element} image An image element in the DOM.\n *\n * @return {Element} The same element that was passed in.\n */\nfunction forceOriginalDimensions(image) {\n if (!image.hasAttribute('data-no-resize')) {\n if (image.offsetWidth === 0 && image.offsetHeight === 0) {\n image.setAttribute('width', image.naturalWidth);\n image.setAttribute('height', image.naturalHeight);\n } else {\n image.setAttribute('width', image.offsetWidth);\n image.setAttribute('height', image.offsetHeight);\n }\n }\n return image;\n}\n\n/**\n * Determines whether the retina image actually exists on the server.\n * If so, swaps out the retina image for the standard one. If not,\n * leaves the original image alone.\n *\n * @param {Element} image An image element in the DOM.\n * @param {String} newSrc The url to the retina image.\n *\n * @return {undefined}\n */\nfunction setSourceIfAvailable(image, retinaURL) {\n const imgType = image.nodeName.toLowerCase();\n\n /*\n * Create a new image element and give it a load listener. When the\n * load listener fires, it means the URL is correct and we will then\n * attach it to the user's image.\n */\n const testImage = document.createElement('img');\n testImage.addEventListener('load', () => {\n /*\n * If we're dealing with an image tag, force it's dimensions\n * and set the source attribute. If not, go after the background-image\n * inline style.\n */\n if (imgType === 'img') {\n forceOriginalDimensions(image).setAttribute('src', retinaURL);\n } else {\n image.style.backgroundImage = `url(${retinaURL})`;\n }\n });\n\n /*\n * Attach the retina URL to our proxy image to load in the new\n * image resource.\n */\n testImage.setAttribute('src', retinaURL);\n\n /*\n * Mark our image as processed so that it won't be processed again.\n */\n image.setAttribute(processedAttr, true);\n}\n\n/**\n * Attempts to do an image url swap on a given image.\n *\n * @param {Element} image An image in the DOM.\n * @param {String} src The original image source attribute.\n * @param {String|Number} rjs The pixel density cap for images provided.\n *\n * @return {undefined}\n */\nfunction dynamicSwapImage(image, src, rjs = 1) {\n const cap = chooseCap(rjs);\n\n /*\n * Don't do anything if the cap is less than 2 or there is no src.\n */\n if (src && cap > 1) {\n const newSrc = src.replace(srcReplace, `@${cap}x$1`);\n setSourceIfAvailable(image, newSrc);\n }\n}\n\n/**\n * Performs an image url swap on a given image with a provided url.\n *\n * @param {Element} image An image in the DOM.\n * @param {String} src The original image source attribute.\n * @param {String} hdsrc The path for a 2x image.\n *\n * @return {undefined}\n */\nfunction manualSwapImage(image, src, hdsrc) {\n if (environment > 1) {\n setSourceIfAvailable(image, hdsrc);\n }\n}\n\n/**\n * Collects all images matching our selector, and converts our\n * NodeList into an Array so that Array methods will be available to it.\n *\n * @param {Iterable} images Optional. An Array, jQuery selection, or NodeList\n * of elements to affect with retina.js.\n *\n * @return {Iterable} Contains all elements matching our selector.\n */\nfunction getImages(images) {\n if (!images) {\n return typeof document !== 'undefined' ? arrayify(document.querySelectorAll(selector)) : [];\n } else {\n return typeof images.forEach === 'function' ? images : arrayify(images);\n }\n}\n\n/**\n * Converts a string like \"url(hello.png)\" into \"hello.png\".\n *\n * @param {Element} img An HTML element with a background image.\n *\n * @return {String}\n */\nfunction cleanBgImg(img) {\n return img.style.backgroundImage.replace(inlineReplace, '$2');\n}\n\n/**\n * Gets all participating images and dynamically swaps out each one for its\n * retina equivalent taking into account the environment capabilities and\n * the densities for which the user has provided images.\n *\n * @param {Iterable} images Optional. An Array, jQuery selection, or NodeList\n * of elements to affect with retina.js. If not\n * provided, retina.js will grab all images on the\n * page.\n *\n * @return {undefined}\n */\nfunction retina(images) {\n getImages(images).forEach(img => {\n if (!img.getAttribute(processedAttr)) {\n const isImg = img.nodeName.toLowerCase() === 'img';\n const src = isImg ? img.getAttribute('src') : cleanBgImg(img);\n const rjs = img.getAttribute('data-rjs');\n const rjsIsNumber = !isNaN(parseInt(rjs, 10));\n\n // do not try to load /null image!\n if (rjs === null) {\n return;\n }\n\n /*\n * If the user provided a number, dynamically swap out the image.\n * If the user provided a url, do it manually.\n */\n if (rjsIsNumber) {\n dynamicSwapImage(img, src, rjs);\n } else {\n manualSwapImage(img, src, rjs);\n }\n }\n });\n}\n\n/*\n * If this environment has `window`, activate the plugin.\n */\nif (hasWindow) {\n window.addEventListener('load', () => {\n retina();\n });\n window.retinajs = retina;\n}\n\nexport default retina;\n"],"names":["hasWindow","window","environment","Math","round","devicePixelRatio","srcReplace","inlineReplace","selector","processedAttr","arrayify","object","Array","prototype","slice","call","chooseCap","cap","numericCap","parseInt","forceOriginalDimensions","image","hasAttribute","offsetWidth","offsetHeight","setAttribute","naturalWidth","naturalHeight","setSourceIfAvailable","retinaURL","imgType","nodeName","toLowerCase","testImage","document","createElement","addEventListener","style","backgroundImage","dynamicSwapImage","src","rjs","newSrc","replace","manualSwapImage","hdsrc","getImages","images","querySelectorAll","forEach","cleanBgImg","img","retina","getAttribute","isImg","rjsIsNumber","isNaN","retinajs"],"mappings":";;;;;;AAeA,IAAMA,YAAY,OAAOC,MAAP,KAAkB,WAApC;AAMA,IAAMC,cAAcC,KAAKC,KAAL,CAAWJ,YAAYC,OAAOI,gBAAP,IAA2B,CAAvC,GAA2C,CAAtD,CAApB;AAKA,IAAMC,aAAa,2BAAnB;AACA,IAAMC,gBAAgB,+BAAtB;AAKA,IAAMC,WAAW,YAAjB;AAKA,IAAMC,gBAAgB,oBAAtB;AASA,SAASC,QAAT,CAAkBC,MAAlB,EAA0B;SACjBC,MAAMC,SAAN,CAAgBC,KAAhB,CAAsBC,IAAtB,CAA2BJ,MAA3B,CAAP;;AAYF,SAASK,SAAT,CAAmBC,GAAnB,EAAwB;MAChBC,aAAaC,SAASF,GAAT,EAAc,EAAd,CAAnB;MAMIf,cAAcgB,UAAlB,EAA8B;WACrBhB,WAAP;GADF,MAOO;WACEgB,UAAP;;;AAYJ,SAASE,uBAAT,CAAiCC,KAAjC,EAAwC;MAClC,CAACA,MAAMC,YAAN,CAAmB,gBAAnB,CAAL,EAA2C;QACrCD,MAAME,WAAN,KAAsB,CAAtB,IAA2BF,MAAMG,YAAN,KAAuB,CAAtD,EAAyD;YACjDC,YAAN,CAAmB,OAAnB,EAA4BJ,MAAMK,YAAlC;YACMD,YAAN,CAAmB,QAAnB,EAA6BJ,MAAMM,aAAnC;KAFF,MAGO;YACCF,YAAN,CAAmB,OAAnB,EAA4BJ,MAAME,WAAlC;YACME,YAAN,CAAmB,QAAnB,EAA6BJ,MAAMG,YAAnC;;;SAGGH,KAAP;;AAaF,SAASO,oBAAT,CAA8BP,KAA9B,EAAqCQ,SAArC,EAAgD;MACxCC,UAAUT,MAAMU,QAAN,CAAeC,WAAf,EAAhB;MAOMC,YAAYC,SAASC,aAAT,CAAuB,KAAvB,CAAlB;YACUC,gBAAV,CAA2B,MAA3B,EAAmC,YAAM;QAMnCN,YAAY,KAAhB,EAAuB;8BACGT,KAAxB,EAA+BI,YAA/B,CAA4C,KAA5C,EAAmDI,SAAnD;KADF,MAEO;YACCQ,KAAN,CAAYC,eAAZ,YAAqCT,SAArC;;GATJ;YAiBUJ,YAAV,CAAuB,KAAvB,EAA8BI,SAA9B;QAKMJ,YAAN,CAAmBhB,aAAnB,EAAkC,IAAlC;;AAYF,SAAS8B,gBAAT,CAA0BlB,KAA1B,EAAiCmB,GAAjC,EAA+C;MAATC,GAAS,uEAAH,CAAG;MACvCxB,MAAMD,UAAUyB,GAAV,CAAZ;MAKID,OAAOvB,MAAM,CAAjB,EAAoB;QACZyB,SAASF,IAAIG,OAAJ,CAAYrC,UAAZ,QAA4BW,GAA5B,SAAf;yBACqBI,KAArB,EAA4BqB,MAA5B;;;AAaJ,SAASE,eAAT,CAAyBvB,KAAzB,EAAgCmB,GAAhC,EAAqCK,KAArC,EAA4C;MACtC3C,cAAc,CAAlB,EAAqB;yBACEmB,KAArB,EAA4BwB,KAA5B;;;AAaJ,SAASC,SAAT,CAAmBC,MAAnB,EAA2B;MACrB,CAACA,MAAL,EAAa;WACJ,OAAOb,QAAP,KAAoB,WAApB,GAAkCxB,SAASwB,SAASc,gBAAT,CAA0BxC,QAA1B,CAAT,CAAlC,GAAkF,EAAzF;GADF,MAEO;WACE,OAAOuC,OAAOE,OAAd,KAA0B,UAA1B,GAAuCF,MAAvC,GAAgDrC,SAASqC,MAAT,CAAvD;;;AAWJ,SAASG,UAAT,CAAoBC,GAApB,EAAyB;SAChBA,IAAId,KAAJ,CAAUC,eAAV,CAA0BK,OAA1B,CAAkCpC,aAAlC,EAAiD,IAAjD,CAAP;;AAeF,SAAS6C,MAAT,CAAgBL,MAAhB,EAAwB;YACZA,MAAV,EAAkBE,OAAlB,CAA0B,eAAO;QAC3B,CAACE,IAAIE,YAAJ,CAAiB5C,aAAjB,CAAL,EAAsC;UAC9B6C,QAAQH,IAAIpB,QAAJ,CAAaC,WAAb,OAA+B,KAA7C;UACMQ,MAAMc,QAAQH,IAAIE,YAAJ,CAAiB,KAAjB,CAAR,GAAkCH,WAAWC,GAAX,CAA9C;UACMV,MAAMU,IAAIE,YAAJ,CAAiB,UAAjB,CAAZ;UACME,cAAc,CAACC,MAAMrC,SAASsB,GAAT,EAAc,EAAd,CAAN,CAArB;UAGIA,QAAQ,IAAZ,EAAkB;;;UAQdc,WAAJ,EAAiB;yBACEJ,GAAjB,EAAsBX,GAAtB,EAA2BC,GAA3B;OADF,MAEO;wBACWU,GAAhB,EAAqBX,GAArB,EAA0BC,GAA1B;;;GAnBN;;AA4BF,IAAIzC,SAAJ,EAAe;SACNoC,gBAAP,CAAwB,MAAxB,EAAgC,YAAM;;GAAtC;SAGOqB,QAAP,GAAkBL,MAAlB;CAGF;;;;"}
|
@@ -0,0 +1,56 @@
|
|
1
|
+
// retina.less
|
2
|
+
// A helper mixin for applying high-resolution background images (http://www.retinajs.com)
|
3
|
+
|
4
|
+
// Updated by John Newman
|
5
|
+
// github.com/jgnewman
|
6
|
+
// http://axial.agency
|
7
|
+
|
8
|
+
/**
|
9
|
+
* Allows you to use retina images at various pixel densities.
|
10
|
+
* Examples:
|
11
|
+
*
|
12
|
+
* .retina(/images/mypic.jpg, 2);
|
13
|
+
* .retina(/images/mypic.jpg, 3, 100px 100px, left top no-repeat transparent);
|
14
|
+
*
|
15
|
+
* @param {String} $path The path to the file name minus extension.
|
16
|
+
* @param {Number} $cap: 2 The highest pixel density level images exist for.
|
17
|
+
* @param {Value} $size: auto auto The intended width of the rendered image.
|
18
|
+
* @param {Value} $extras: null Any other `background` values to be added.
|
19
|
+
*/
|
20
|
+
.retina(@path, @cap: 2, @size: auto auto, @extras: ~'') {
|
21
|
+
@lowretina: ~"(-webkit-min-device-pixel-ratio: 1.5), (min--moz-device-pixel-ratio: 1.5), (-o-min-device-pixel-ratio: 3/2), (min-resolution: 1.5dppx)";
|
22
|
+
@2xpath: ~`@{path}.replace(/\.\w+$/, function(match) { return "@2x" + match; })`;
|
23
|
+
|
24
|
+
/*
|
25
|
+
* Set a base background for 1x environments.
|
26
|
+
*/
|
27
|
+
background: url(@path) @extras;
|
28
|
+
background-size: @size;
|
29
|
+
|
30
|
+
/*
|
31
|
+
* Create an @2x-ish media query.
|
32
|
+
*/
|
33
|
+
@media @lowretina {
|
34
|
+
background : url(@2xpath) @extras;
|
35
|
+
background-size : @size;
|
36
|
+
}
|
37
|
+
|
38
|
+
/*
|
39
|
+
* Create media queries for all environments that the user has
|
40
|
+
* provided images for.
|
41
|
+
*/
|
42
|
+
.create-queries() when (@cap >= 2) {
|
43
|
+
.loop(@env) when (@env <= @cap) {
|
44
|
+
@retinapath: ~`@{path}.replace(/\.\w+$/, function(match) { return "@@{env}x" + match; })`;
|
45
|
+
@media (-webkit-min-device-pixel-ratio: @env),
|
46
|
+
(min-resolution: @env * 96dpi) {
|
47
|
+
background : url(@retinapath) @extras;
|
48
|
+
background-size : @size;
|
49
|
+
}
|
50
|
+
.loop((@env + 1)); // next iteration
|
51
|
+
}
|
52
|
+
.loop(2);
|
53
|
+
}
|
54
|
+
.create-queries();
|
55
|
+
|
56
|
+
}
|
@@ -0,0 +1,2 @@
|
|
1
|
+
(function(a,b){'object'==typeof exports&&'undefined'!=typeof module?module.exports=b():'function'==typeof define&&define.amd?define(b):a.retinajs=b()})(this,function(){'use strict';function a(a){return Array.prototype.slice.call(a)}function b(a){var b=parseInt(a,10);return k<b?k:b}function c(a){return a.hasAttribute('data-no-resize')||(0===a.offsetWidth&&0===a.offsetHeight?(a.setAttribute('width',a.naturalWidth),a.setAttribute('height',a.naturalHeight)):(a.setAttribute('width',a.offsetWidth),a.setAttribute('height',a.offsetHeight))),a}function d(a,b){var d=a.nodeName.toLowerCase(),e=document.createElement('img');e.addEventListener('load',function(){'img'===d?c(a).setAttribute('src',b):a.style.backgroundImage='url('+b+')'}),e.setAttribute('src',b),a.setAttribute(o,!0)}function e(a,c){var e=2<arguments.length&&void 0!==arguments[2]?arguments[2]:1,f=b(e);if(c&&1<f){var g=c.replace(l,'@'+f+'x$1');d(a,g)}}function f(a,b,c){1<k&&d(a,c)}function g(b){return b?'function'==typeof b.forEach?b:a(b):'undefined'==typeof document?[]:a(document.querySelectorAll(n))}function h(a){return a.style.backgroundImage.replace(m,'$2')}function i(a){g(a).forEach(function(a){if(!a.getAttribute(o)){var b='img'===a.nodeName.toLowerCase(),c=b?a.getAttribute('src'):h(a),d=a.getAttribute('data-rjs'),g=!isNaN(parseInt(d,10));if(null===d)return;g?e(a,c,d):f(a,c,d)}})}var j='undefined'!=typeof window,k=Math.round(j?window.devicePixelRatio||1:1),l=/(\.[A-z]{3,4}\/?(\?.*)?)$/,m=/url\(('|")?([^)'"]+)('|")?\)/i,n='[data-rjs]',o='data-rjs-processed';return j&&(window.addEventListener('load',function(){i()}),window.retinajs=i),i});
|
2
|
+
//# sourceMappingURL=retina.min.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"retina.min.js","sources":["../src/retina.js"],"sourcesContent":["/* @flow */\n\n/**\n * --------------------------------------------------------------------------\n * Retina.js\n * Licensed under MIT (https://github.com/strues/retinajs/blob/master/LICENSE)\n *\n * Retina.js is an open source script that makes it easy to serve high-resolution\n * images to devices with retina displays.\n * --------------------------------------------------------------------------\n */\n\n/*\n * Determine whether or not `window` is available.\n */\nconst hasWindow = typeof window !== 'undefined';\n\n/*\n * Get the device pixel ratio per our environment.\n * Default to 1.\n */\nconst environment = Math.round(hasWindow ? window.devicePixelRatio || 1 : 1);\n\n/*\n * Define a pattern for capturing src url suffixes.\n */\nconst srcReplace = /(\\.[A-z]{3,4}\\/?(\\?.*)?)$/;\nconst inlineReplace = /url\\(('|\")?([^)'\"]+)('|\")?\\)/i;\n\n/*\n * Define our selectors for elements to target.\n */\nconst selector = '[data-rjs]';\n\n/*\n * Define the attribute we'll use to mark an image as having been processed.\n */\nconst processedAttr = 'data-rjs-processed';\n\n/**\n * Shortcut for turning some iterable object into an array.\n *\n * @param {Iterable} object Any iterable object.\n *\n * @return {Array}\n */\nfunction arrayify(object) {\n return Array.prototype.slice.call(object);\n}\n\n/**\n * Chooses the actual image size to fetch, (for example 2 or 3) that\n * will be used to create a suffix like \"@2x\" or \"@3x\".\n *\n * @param {String|Number} cap The number the user provided indicating that\n * they have prepared images up to this size.\n *\n * @return {Number} The number we'll be using to create a suffix.\n */\nfunction chooseCap(cap) {\n const numericCap = parseInt(cap, 10);\n\n /*\n * If the environment's device pixel ratio is less than what the user\n * provided, we'll only grab images at that size.\n */\n if (environment < numericCap) {\n return environment;\n\n /*\n * If the device pixel ratio is greater than or equal to what the\n * user provided, we'll use what the user provided.\n */\n } else {\n return numericCap;\n }\n}\n\n/**\n * Makes sure that, since we are going to swap out the source of an image,\n * the image does not change size on the page.\n *\n * @param {Element} image An image element in the DOM.\n *\n * @return {Element} The same element that was passed in.\n */\nfunction forceOriginalDimensions(image) {\n if (!image.hasAttribute('data-no-resize')) {\n if (image.offsetWidth === 0 && image.offsetHeight === 0) {\n image.setAttribute('width', image.naturalWidth);\n image.setAttribute('height', image.naturalHeight);\n } else {\n image.setAttribute('width', image.offsetWidth);\n image.setAttribute('height', image.offsetHeight);\n }\n }\n return image;\n}\n\n/**\n * Determines whether the retina image actually exists on the server.\n * If so, swaps out the retina image for the standard one. If not,\n * leaves the original image alone.\n *\n * @param {Element} image An image element in the DOM.\n * @param {String} newSrc The url to the retina image.\n *\n * @return {undefined}\n */\nfunction setSourceIfAvailable(image, retinaURL) {\n const imgType = image.nodeName.toLowerCase();\n\n /*\n * Create a new image element and give it a load listener. When the\n * load listener fires, it means the URL is correct and we will then\n * attach it to the user's image.\n */\n const testImage = document.createElement('img');\n testImage.addEventListener('load', () => {\n /*\n * If we're dealing with an image tag, force it's dimensions\n * and set the source attribute. If not, go after the background-image\n * inline style.\n */\n if (imgType === 'img') {\n forceOriginalDimensions(image).setAttribute('src', retinaURL);\n } else {\n image.style.backgroundImage = `url(${retinaURL})`;\n }\n });\n\n /*\n * Attach the retina URL to our proxy image to load in the new\n * image resource.\n */\n testImage.setAttribute('src', retinaURL);\n\n /*\n * Mark our image as processed so that it won't be processed again.\n */\n image.setAttribute(processedAttr, true);\n}\n\n/**\n * Attempts to do an image url swap on a given image.\n *\n * @param {Element} image An image in the DOM.\n * @param {String} src The original image source attribute.\n * @param {String|Number} rjs The pixel density cap for images provided.\n *\n * @return {undefined}\n */\nfunction dynamicSwapImage(image, src, rjs = 1) {\n const cap = chooseCap(rjs);\n\n /*\n * Don't do anything if the cap is less than 2 or there is no src.\n */\n if (src && cap > 1) {\n const newSrc = src.replace(srcReplace, `@${cap}x$1`);\n setSourceIfAvailable(image, newSrc);\n }\n}\n\n/**\n * Performs an image url swap on a given image with a provided url.\n *\n * @param {Element} image An image in the DOM.\n * @param {String} src The original image source attribute.\n * @param {String} hdsrc The path for a 2x image.\n *\n * @return {undefined}\n */\nfunction manualSwapImage(image, src, hdsrc) {\n if (environment > 1) {\n setSourceIfAvailable(image, hdsrc);\n }\n}\n\n/**\n * Collects all images matching our selector, and converts our\n * NodeList into an Array so that Array methods will be available to it.\n *\n * @param {Iterable} images Optional. An Array, jQuery selection, or NodeList\n * of elements to affect with retina.js.\n *\n * @return {Iterable} Contains all elements matching our selector.\n */\nfunction getImages(images) {\n if (!images) {\n return typeof document !== 'undefined' ? arrayify(document.querySelectorAll(selector)) : [];\n } else {\n return typeof images.forEach === 'function' ? images : arrayify(images);\n }\n}\n\n/**\n * Converts a string like \"url(hello.png)\" into \"hello.png\".\n *\n * @param {Element} img An HTML element with a background image.\n *\n * @return {String}\n */\nfunction cleanBgImg(img) {\n return img.style.backgroundImage.replace(inlineReplace, '$2');\n}\n\n/**\n * Gets all participating images and dynamically swaps out each one for its\n * retina equivalent taking into account the environment capabilities and\n * the densities for which the user has provided images.\n *\n * @param {Iterable} images Optional. An Array, jQuery selection, or NodeList\n * of elements to affect with retina.js. If not\n * provided, retina.js will grab all images on the\n * page.\n *\n * @return {undefined}\n */\nfunction retina(images) {\n getImages(images).forEach(img => {\n if (!img.getAttribute(processedAttr)) {\n const isImg = img.nodeName.toLowerCase() === 'img';\n const src = isImg ? img.getAttribute('src') : cleanBgImg(img);\n const rjs = img.getAttribute('data-rjs');\n const rjsIsNumber = !isNaN(parseInt(rjs, 10));\n\n // do not try to load /null image!\n if (rjs === null) {\n return;\n }\n\n /*\n * If the user provided a number, dynamically swap out the image.\n * If the user provided a url, do it manually.\n */\n if (rjsIsNumber) {\n dynamicSwapImage(img, src, rjs);\n } else {\n manualSwapImage(img, src, rjs);\n }\n }\n });\n}\n\n/*\n * If this environment has `window`, activate the plugin.\n */\nif (hasWindow) {\n window.addEventListener('load', () => {\n retina();\n });\n window.retinajs = retina;\n}\n\nexport default retina;\n"],"names":["Array","prototype","slice","call","numericCap","parseInt","environment","image","hasAttribute","offsetWidth","offsetHeight","setAttribute","naturalWidth","naturalHeight","imgType","nodeName","toLowerCase","testImage","document","createElement","addEventListener","style","backgroundImage","rjs","cap","chooseCap","src","newSrc","replace","images","forEach","arrayify","querySelectorAll","img","getAttribute","isImg","cleanBgImg","rjsIsNumber","isNaN","hasWindow","window","Math","round","devicePixelRatio","srcReplace","inlineReplace","selector","processedAttr","retinajs"],"mappings":"qLA8CA,aAA0B,OACjBA,OAAMC,SAAND,CAAgBE,KAAhBF,CAAsBG,IAAtBH,IAYT,aAAwB,IAChBI,GAAaC,WAAc,EAAdA,EADG,MAOlBC,IAPkB,KA2BxB,aAAwC,OACjCC,GAAMC,YAAND,CAAmB,gBAAnBA,IACuB,CAAtBA,KAAME,WAANF,EAAkD,CAAvBA,KAAMG,gBAC7BC,aAAa,QAASJ,EAAMK,gBAC5BD,aAAa,SAAUJ,EAAMM,mBAE7BF,aAAa,QAASJ,EAAME,eAC5BE,aAAa,SAAUJ,EAAMG,kBAgBzC,eAAgD,IACxCI,GAAUP,EAAMQ,QAANR,CAAeS,WAAfT,GAOVU,EAAYC,SAASC,aAATD,CAAuB,KAAvBA,IACRE,iBAAiB,OAAQ,UAAM,CAMvB,KAAZN,IANmC,MAONH,aAAa,QAPP,GAS/BU,MAAMC,4BAThB,EAT8C,GA0BpCX,aAAa,QA1BuB,GA+BxCA,mBAYR,eAA+C,IAATY,0DAAM,EACpCC,EAAMC,QAKRC,GAAa,CAANF,GAAS,IACZG,GAASD,EAAIE,OAAJF,cAAAA,UAcnB,iBAA4C,CACxB,CAAdpB,EADsC,SAe5C,aAA2B,UAIU,UAA1B,QAAOuB,GAAOC,OAAd,GAAgDC,IAJhC,CAEI,WAApB,QAAOb,SAAP,IAAkCa,EAASb,SAASc,gBAATd,GAATa,EAa7C,aAAyB,OAChBE,GAAIZ,KAAJY,CAAUX,eAAVW,CAA0BL,OAA1BK,GAAiD,IAAjDA,EAeT,aAAwB,MACJH,QAAQ,WAAO,IAC3B,CAACG,EAAIC,YAAJD,IAAiC,IAC9BE,GAAuC,KAA/BF,KAAIlB,QAAJkB,CAAajB,WAAbiB,GACRP,EAAMS,EAAQF,EAAIC,YAAJD,CAAiB,KAAjBA,CAARE,CAAkCC,KACxCb,EAAMU,EAAIC,YAAJD,CAAiB,UAAjBA,EACNI,EAAc,CAACC,MAAMjC,WAAc,EAAdA,CAANiC,KAGT,IAARf,YAPgC,UAAA,UADxC,GA7MF,GAAMgB,GAA8B,WAAlB,QAAOC,OAAzB,CAMMlC,EAAcmC,KAAKC,KAALD,CAAWF,EAAYC,OAAOG,gBAAPH,EAA2B,CAAvCD,CAA2C,CAAtDE,CANpB,CAWMG,EAAa,2BAXnB,CAYMC,EAAgB,+BAZtB,CAiBMC,EAAW,YAjBjB,CAsBMC,EAAgB,oBAtBtB,mBA0OS3B,iBAAiB,OAAQ,UAAM,IAAtC,UAGO4B"}
|
@@ -0,0 +1,56 @@
|
|
1
|
+
// retina.styl
|
2
|
+
// A helper mixin for applying high-resolution background images (http://www.retinajs.com)
|
3
|
+
|
4
|
+
// Created by John Newman
|
5
|
+
// github.com/jgnewman
|
6
|
+
// http://axial.agency
|
7
|
+
|
8
|
+
|
9
|
+
/**
|
10
|
+
* Allows you to use retina images at various pixel densities.
|
11
|
+
* Examples:
|
12
|
+
*
|
13
|
+
* retina(/images/mypic.jpg, 2)
|
14
|
+
* retina(/images/mypic.jpg, 3, 100px 100px, left top no-repeat transparent)
|
15
|
+
*
|
16
|
+
* @param {Value} $path The path to the file name minus extension.
|
17
|
+
* @param {Number} $cap: 2 The highest pixel density level images exist for.
|
18
|
+
* @param {Value} $size: auto auto The intended width of the rendered image.
|
19
|
+
* @param {Value} $extras: null Any other `background` values to be added.
|
20
|
+
*/
|
21
|
+
retina($path, $cap = 2, $size = auto auto, $extras = null)
|
22
|
+
$dirname = dirname($path)
|
23
|
+
$filename = basename($path)
|
24
|
+
$at2xpath = pathjoin($dirname, replace('\.', '@2x.', $filename))
|
25
|
+
|
26
|
+
/*
|
27
|
+
* Set a base background for 1x environments.
|
28
|
+
*/
|
29
|
+
background: url($path) $extras
|
30
|
+
background-size: $size
|
31
|
+
|
32
|
+
/*
|
33
|
+
* Create an @2x-ish media query.
|
34
|
+
*/
|
35
|
+
@media all and (-webkit-min-device-pixel-ratio : 1.5), all and (-o-min-device-pixel-ratio: 3/2), all and (min--moz-device-pixel-ratio: 1.5), all and (min-device-pixel-ratio: 1.5)
|
36
|
+
background: url($at2xpath) $extras
|
37
|
+
background-size: $size
|
38
|
+
|
39
|
+
/*
|
40
|
+
* Create media queries for all environments that the user has
|
41
|
+
* provided images for.
|
42
|
+
*/
|
43
|
+
if $cap >= 2
|
44
|
+
for $env in (2..$cap)
|
45
|
+
$newpath = pathjoin($dirname, replace('\.', '@' + $env + 'x.', $filename))
|
46
|
+
@media (-webkit-min-device-pixel-ratio: $env), (min-resolution: $env * 96dpi)
|
47
|
+
background: url($newpath) $extras
|
48
|
+
background-size: $size
|
49
|
+
|
50
|
+
/*
|
51
|
+
* If anything went wrong trying to separate the file from its
|
52
|
+
* extension, set a background value without doing anything to it.
|
53
|
+
*/
|
54
|
+
else
|
55
|
+
background: url($path) $extras
|
56
|
+
background-size: $size
|
@@ -0,0 +1,68 @@
|
|
1
|
+
// retina.sass
|
2
|
+
// A helper mixin for applying high-resolution background images (http://www.retinajs.com)
|
3
|
+
|
4
|
+
// Submitted by Nathan Crank
|
5
|
+
// nathancrank.com
|
6
|
+
|
7
|
+
// Updated by John Newman
|
8
|
+
// github.com/jgnewman
|
9
|
+
// http://axial.agency
|
10
|
+
|
11
|
+
/**
|
12
|
+
* Allows you to use retina images at various pixel densities.
|
13
|
+
* Examples:
|
14
|
+
*
|
15
|
+
* +retina(/images/mypic.jpg, 2);
|
16
|
+
* +retina(/images/mypic.jpg, 3, 100px 100px, left top no-repeat transparent);
|
17
|
+
*
|
18
|
+
* @param {Value} $path The path to the file name minus extension.
|
19
|
+
* @param {Number} $cap: 2 The highest pixel density level images exist for.
|
20
|
+
* @param {Value} $size: auto auto The intended width of the rendered image.
|
21
|
+
* @param {Value} $extras: null Any other `background` values to be added.
|
22
|
+
*/
|
23
|
+
=retina($path, $cap: 2, $size: auto auto, $extras: null)
|
24
|
+
|
25
|
+
// Set a counter and get the length of the image path.
|
26
|
+
$position: -1
|
27
|
+
$strpath: '#{$path}'
|
28
|
+
$length: str-length($strpath)
|
29
|
+
|
30
|
+
// Loop ver the image path and figure out the
|
31
|
+
// position of the dot where the extension begins.
|
32
|
+
@for $i from $length through $length - 10
|
33
|
+
@if $position == -1
|
34
|
+
$char: str-slice($strpath, $i,$i)
|
35
|
+
@if str-index($char, ".") == 1
|
36
|
+
$position: $i
|
37
|
+
|
38
|
+
// If we were able to figure out where the extension is,
|
39
|
+
// slice the path into a base and an extension. Use that to
|
40
|
+
// calculate urls for different density environments. Set
|
41
|
+
// values for different environments.
|
42
|
+
@if $position != -1
|
43
|
+
$ext: str-slice($strpath, $position + 1, $length)
|
44
|
+
$base: str-slice($strpath, 1 ,$position - 1)
|
45
|
+
$at1x_path: "#{$base}.#{$ext}"
|
46
|
+
$at2x_path: "#{$base}@2x.#{$ext}"
|
47
|
+
|
48
|
+
// Set a base background for 1x environments.
|
49
|
+
background: url("#{$at1x_path}") $extras
|
50
|
+
background-size: $size
|
51
|
+
|
52
|
+
// Create an @2x-ish media query.
|
53
|
+
@media all and (-webkit-min-device-pixel-ratio: 1.5), all and (-o-min-device-pixel-ratio: 3/2), all and (min--moz-device-pixel-ratio: 1.5), all and (min-device-pixel-ratio: 1.5)
|
54
|
+
background: url("#{$at2x_path}") $extras
|
55
|
+
background-size: $size
|
56
|
+
|
57
|
+
// Create media queries for all environments that the user has
|
58
|
+
// provided images for.
|
59
|
+
@if $cap >= 2
|
60
|
+
@for $env from 2 through $cap
|
61
|
+
$suffix: "@#{$env}x"
|
62
|
+
@media (-webkit-min-device-pixel-ratio: $env), (min-resolution: $env * 96dpi)
|
63
|
+
background: url("#{$base}#{$suffix}.#{$ext}") $extras
|
64
|
+
background-size: $size
|
65
|
+
|
66
|
+
@else
|
67
|
+
background: url("#{$path}") $extras
|
68
|
+
background-size: $size
|