jekyll-theme-chalk 0.1.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (405) hide show
  1. checksums.yaml +7 -0
  2. data/404.html +39 -0
  3. data/LICENSE +21 -0
  4. data/LICENSE.txt +21 -0
  5. data/README.md +91 -0
  6. data/_assets/fonts/cormorant-garamond/Cormorant-Garamond-700.eot +0 -0
  7. data/_assets/fonts/cormorant-garamond/Cormorant-Garamond-700.ttf +0 -0
  8. data/_assets/fonts/cormorant-garamond/Cormorant-Garamond-700.woff +0 -0
  9. data/_assets/fonts/cormorant-garamond/Cormorant-Garamond-700.woff2 +0 -0
  10. data/_assets/fonts/ionicons/ionicons.eot +0 -0
  11. data/_assets/fonts/ionicons/ionicons.ttf +0 -0
  12. data/_assets/fonts/ionicons/ionicons.woff +0 -0
  13. data/_assets/fonts/lato/Lato-300.eot +0 -0
  14. data/_assets/fonts/lato/Lato-300.ttf +0 -0
  15. data/_assets/fonts/lato/Lato-300.woff +0 -0
  16. data/_assets/fonts/lato/Lato-300.woff2 +0 -0
  17. data/_assets/fonts/lato/Lato-700.eot +0 -0
  18. data/_assets/fonts/lato/Lato-700.ttf +0 -0
  19. data/_assets/fonts/lato/Lato-700.woff +0 -0
  20. data/_assets/fonts/lato/Lato-700.woff2 +0 -0
  21. data/_assets/fonts/lato/Lato-regular.eot +0 -0
  22. data/_assets/fonts/lato/Lato-regular.ttf +0 -0
  23. data/_assets/fonts/lato/Lato-regular.woff +0 -0
  24. data/_assets/fonts/lato/Lato-regular.woff2 +0 -0
  25. data/_assets/images/about.jpg +0 -0
  26. data/_assets/images/about@2x.jpg +0 -0
  27. data/_assets/images/apple-touch-icon.png +0 -0
  28. data/_assets/images/documentation/chalk-intro.png +0 -0
  29. data/_assets/images/documentation/chalk-intro@2x.png +0 -0
  30. data/_assets/images/documentation/enlarge.gif +0 -0
  31. data/_assets/images/documentation/enlarge@2x.gif +0 -0
  32. data/_assets/images/documentation/sample-image.jpg +0 -0
  33. data/_assets/images/documentation/sample-image@2x.jpg +0 -0
  34. data/_assets/images/og-image.jpg +0 -0
  35. data/_assets/javascripts/application.js +17 -0
  36. data/_assets/javascripts/scrollappear.js +25 -0
  37. data/_assets/javascripts/vendor.js +4 -0
  38. data/_assets/javascripts/webfonts.js +7 -0
  39. data/_assets/stylesheets/.csscomb.json +196 -0
  40. data/_assets/stylesheets/.scss-lint.yml +33 -0
  41. data/_assets/stylesheets/_base.scss +151 -0
  42. data/_assets/stylesheets/_mixins.scss +28 -0
  43. data/_assets/stylesheets/_variables.scss +47 -0
  44. data/_assets/stylesheets/dark.scss +71 -0
  45. data/_assets/stylesheets/fonts.scss +63 -0
  46. data/_assets/stylesheets/layouts/_footer.scss +17 -0
  47. data/_assets/stylesheets/layouts/_grid.scss +102 -0
  48. data/_assets/stylesheets/light.scss +71 -0
  49. data/_assets/stylesheets/modules/_about.scss +10 -0
  50. data/_assets/stylesheets/modules/_articles.scss +213 -0
  51. data/_assets/stylesheets/modules/_embed.scss +31 -0
  52. data/_assets/stylesheets/modules/_header.scss +57 -0
  53. data/_assets/stylesheets/modules/_highlights-dark.scss +415 -0
  54. data/_assets/stylesheets/modules/_highlights-light.scss +409 -0
  55. data/_assets/stylesheets/modules/_icons.scss +83 -0
  56. data/_assets/stylesheets/modules/_scrollappear.scss +14 -0
  57. data/_assets/stylesheets/notfound-dark.scss +91 -0
  58. data/_assets/stylesheets/notfound-light.scss +91 -0
  59. data/_assets/stylesheets/vendor/_normalize.scss +461 -0
  60. data/_assets/yarn/.yarn-integrity +22 -0
  61. data/_assets/yarn/fluidbox/.gitattributes +22 -0
  62. data/_assets/yarn/fluidbox/.npmignore +220 -0
  63. data/_assets/yarn/fluidbox/.travis.yml +6 -0
  64. data/_assets/yarn/fluidbox/Gruntfile.js +8 -0
  65. data/_assets/yarn/fluidbox/LICENSE.md +23 -0
  66. data/_assets/yarn/fluidbox/README.html +750 -0
  67. data/_assets/yarn/fluidbox/README.md +396 -0
  68. data/_assets/yarn/fluidbox/bower.json +35 -0
  69. data/_assets/yarn/fluidbox/demo/css/styles.min.css +2 -0
  70. data/_assets/yarn/fluidbox/demo/css/styles.min.css.map +1 -0
  71. data/_assets/yarn/fluidbox/demo/fonts/BLOKKRegular.eot +0 -0
  72. data/_assets/yarn/fluidbox/demo/fonts/BLOKKRegular.svg +233 -0
  73. data/_assets/yarn/fluidbox/demo/fonts/BLOKKRegular.ttf +0 -0
  74. data/_assets/yarn/fluidbox/demo/fonts/BLOKKRegular.woff +0 -0
  75. data/_assets/yarn/fluidbox/demo/fonts/fontello.eot +0 -0
  76. data/_assets/yarn/fluidbox/demo/fonts/fontello.svg +13 -0
  77. data/_assets/yarn/fluidbox/demo/fonts/fontello.ttf +0 -0
  78. data/_assets/yarn/fluidbox/demo/fonts/fontello.woff +0 -0
  79. data/_assets/yarn/fluidbox/demo/index.html +758 -0
  80. data/_assets/yarn/fluidbox/demo/src/css/styles.scss +1131 -0
  81. data/_assets/yarn/fluidbox/dist/css/fluidbox.min.css +2 -0
  82. data/_assets/yarn/fluidbox/dist/css/fluidbox.min.css.map +1 -0
  83. data/_assets/yarn/fluidbox/dist/js/jquery.fluidbox.min.js +1 -0
  84. data/_assets/yarn/fluidbox/grunt/aliases.yaml +20 -0
  85. data/_assets/yarn/fluidbox/grunt/clean.js +5 -0
  86. data/_assets/yarn/fluidbox/grunt/concurrent.js +33 -0
  87. data/_assets/yarn/fluidbox/grunt/jshint.js +10 -0
  88. data/_assets/yarn/fluidbox/grunt/postcss.js +47 -0
  89. data/_assets/yarn/fluidbox/grunt/sass.js +42 -0
  90. data/_assets/yarn/fluidbox/grunt/uglify.js +7 -0
  91. data/_assets/yarn/fluidbox/grunt/watch.js +28 -0
  92. data/_assets/yarn/fluidbox/index.html +8 -0
  93. data/_assets/yarn/fluidbox/license.txt +21 -0
  94. data/_assets/yarn/fluidbox/package.json +61 -0
  95. data/_assets/yarn/fluidbox/src/css/_fluidbox.scss +95 -0
  96. data/_assets/yarn/fluidbox/src/css/fluidbox.scss +2 -0
  97. data/_assets/yarn/fluidbox/src/js/jquery.fluidbox.js +722 -0
  98. data/_assets/yarn/jquery/AUTHORS.txt +301 -0
  99. data/_assets/yarn/jquery/LICENSE.txt +36 -0
  100. data/_assets/yarn/jquery/README.md +67 -0
  101. data/_assets/yarn/jquery/bower.json +14 -0
  102. data/_assets/yarn/jquery/dist/core.js +476 -0
  103. data/_assets/yarn/jquery/dist/jquery.js +10253 -0
  104. data/_assets/yarn/jquery/dist/jquery.min.js +4 -0
  105. data/_assets/yarn/jquery/dist/jquery.min.map +1 -0
  106. data/_assets/yarn/jquery/dist/jquery.slim.js +8160 -0
  107. data/_assets/yarn/jquery/dist/jquery.slim.min.js +4 -0
  108. data/_assets/yarn/jquery/dist/jquery.slim.min.map +1 -0
  109. data/_assets/yarn/jquery/external/sizzle/LICENSE.txt +36 -0
  110. data/_assets/yarn/jquery/external/sizzle/dist/sizzle.js +2272 -0
  111. data/_assets/yarn/jquery/external/sizzle/dist/sizzle.min.js +3 -0
  112. data/_assets/yarn/jquery/external/sizzle/dist/sizzle.min.map +1 -0
  113. data/_assets/yarn/jquery/package.json +97 -0
  114. data/_assets/yarn/jquery/src/.eslintrc.json +5 -0
  115. data/_assets/yarn/jquery/src/ajax.js +855 -0
  116. data/_assets/yarn/jquery/src/ajax/jsonp.js +102 -0
  117. data/_assets/yarn/jquery/src/ajax/load.js +76 -0
  118. data/_assets/yarn/jquery/src/ajax/parseXML.js +30 -0
  119. data/_assets/yarn/jquery/src/ajax/script.js +77 -0
  120. data/_assets/yarn/jquery/src/ajax/var/location.js +5 -0
  121. data/_assets/yarn/jquery/src/ajax/var/nonce.js +7 -0
  122. data/_assets/yarn/jquery/src/ajax/var/rquery.js +5 -0
  123. data/_assets/yarn/jquery/src/ajax/xhr.js +169 -0
  124. data/_assets/yarn/jquery/src/attributes.js +13 -0
  125. data/_assets/yarn/jquery/src/attributes/attr.js +141 -0
  126. data/_assets/yarn/jquery/src/attributes/classes.js +174 -0
  127. data/_assets/yarn/jquery/src/attributes/prop.js +143 -0
  128. data/_assets/yarn/jquery/src/attributes/support.js +33 -0
  129. data/_assets/yarn/jquery/src/attributes/val.js +190 -0
  130. data/_assets/yarn/jquery/src/callbacks.js +234 -0
  131. data/_assets/yarn/jquery/src/core.js +476 -0
  132. data/_assets/yarn/jquery/src/core/DOMEval.js +16 -0
  133. data/_assets/yarn/jquery/src/core/access.js +70 -0
  134. data/_assets/yarn/jquery/src/core/init.js +128 -0
  135. data/_assets/yarn/jquery/src/core/nodeName.js +13 -0
  136. data/_assets/yarn/jquery/src/core/parseHTML.js +65 -0
  137. data/_assets/yarn/jquery/src/core/ready-no-deferred.js +96 -0
  138. data/_assets/yarn/jquery/src/core/ready.js +86 -0
  139. data/_assets/yarn/jquery/src/core/readyException.js +13 -0
  140. data/_assets/yarn/jquery/src/core/stripAndCollapse.js +14 -0
  141. data/_assets/yarn/jquery/src/core/support.js +20 -0
  142. data/_assets/yarn/jquery/src/core/var/rsingleTag.js +6 -0
  143. data/_assets/yarn/jquery/src/css.js +438 -0
  144. data/_assets/yarn/jquery/src/css/addGetHookIf.js +26 -0
  145. data/_assets/yarn/jquery/src/css/adjustCSS.js +71 -0
  146. data/_assets/yarn/jquery/src/css/curCSS.js +65 -0
  147. data/_assets/yarn/jquery/src/css/hiddenVisibleSelectors.js +15 -0
  148. data/_assets/yarn/jquery/src/css/showHide.js +105 -0
  149. data/_assets/yarn/jquery/src/css/support.js +89 -0
  150. data/_assets/yarn/jquery/src/css/var/cssExpand.js +5 -0
  151. data/_assets/yarn/jquery/src/css/var/getStyles.js +17 -0
  152. data/_assets/yarn/jquery/src/css/var/isHiddenWithinTree.js +34 -0
  153. data/_assets/yarn/jquery/src/css/var/rmargin.js +5 -0
  154. data/_assets/yarn/jquery/src/css/var/rnumnonpx.js +7 -0
  155. data/_assets/yarn/jquery/src/css/var/swap.js +26 -0
  156. data/_assets/yarn/jquery/src/data.js +179 -0
  157. data/_assets/yarn/jquery/src/data/Data.js +161 -0
  158. data/_assets/yarn/jquery/src/data/var/acceptData.js +19 -0
  159. data/_assets/yarn/jquery/src/data/var/dataPriv.js +7 -0
  160. data/_assets/yarn/jquery/src/data/var/dataUser.js +7 -0
  161. data/_assets/yarn/jquery/src/deferred.js +391 -0
  162. data/_assets/yarn/jquery/src/deferred/exceptionHook.js +21 -0
  163. data/_assets/yarn/jquery/src/deprecated.js +40 -0
  164. data/_assets/yarn/jquery/src/dimensions.js +56 -0
  165. data/_assets/yarn/jquery/src/effects.js +699 -0
  166. data/_assets/yarn/jquery/src/effects/Tween.js +123 -0
  167. data/_assets/yarn/jquery/src/effects/animatedSelector.js +15 -0
  168. data/_assets/yarn/jquery/src/event.js +746 -0
  169. data/_assets/yarn/jquery/src/event/ajax.js +22 -0
  170. data/_assets/yarn/jquery/src/event/alias.js +29 -0
  171. data/_assets/yarn/jquery/src/event/focusin.js +55 -0
  172. data/_assets/yarn/jquery/src/event/support.js +11 -0
  173. data/_assets/yarn/jquery/src/event/trigger.js +185 -0
  174. data/_assets/yarn/jquery/src/exports/amd.js +26 -0
  175. data/_assets/yarn/jquery/src/exports/global.js +34 -0
  176. data/_assets/yarn/jquery/src/jquery.js +41 -0
  177. data/_assets/yarn/jquery/src/manipulation.js +488 -0
  178. data/_assets/yarn/jquery/src/manipulation/_evalUrl.js +23 -0
  179. data/_assets/yarn/jquery/src/manipulation/buildFragment.js +104 -0
  180. data/_assets/yarn/jquery/src/manipulation/getAll.js +32 -0
  181. data/_assets/yarn/jquery/src/manipulation/setGlobalEval.js +22 -0
  182. data/_assets/yarn/jquery/src/manipulation/support.js +35 -0
  183. data/_assets/yarn/jquery/src/manipulation/var/rcheckableType.js +5 -0
  184. data/_assets/yarn/jquery/src/manipulation/var/rscriptType.js +5 -0
  185. data/_assets/yarn/jquery/src/manipulation/var/rtagName.js +5 -0
  186. data/_assets/yarn/jquery/src/manipulation/wrapMap.js +29 -0
  187. data/_assets/yarn/jquery/src/offset.js +229 -0
  188. data/_assets/yarn/jquery/src/queue.js +145 -0
  189. data/_assets/yarn/jquery/src/queue/delay.js +24 -0
  190. data/_assets/yarn/jquery/src/selector-native.js +237 -0
  191. data/_assets/yarn/jquery/src/selector-sizzle.js +19 -0
  192. data/_assets/yarn/jquery/src/selector.js +3 -0
  193. data/_assets/yarn/jquery/src/serialize.js +130 -0
  194. data/_assets/yarn/jquery/src/traversing.js +191 -0
  195. data/_assets/yarn/jquery/src/traversing/findFilter.js +106 -0
  196. data/_assets/yarn/jquery/src/traversing/var/dir.js +22 -0
  197. data/_assets/yarn/jquery/src/traversing/var/rneedsContext.js +8 -0
  198. data/_assets/yarn/jquery/src/traversing/var/siblings.js +17 -0
  199. data/_assets/yarn/jquery/src/var/ObjectFunctionString.js +7 -0
  200. data/_assets/yarn/jquery/src/var/arr.js +5 -0
  201. data/_assets/yarn/jquery/src/var/class2type.js +6 -0
  202. data/_assets/yarn/jquery/src/var/concat.js +7 -0
  203. data/_assets/yarn/jquery/src/var/document.js +5 -0
  204. data/_assets/yarn/jquery/src/var/documentElement.js +7 -0
  205. data/_assets/yarn/jquery/src/var/fnToString.js +7 -0
  206. data/_assets/yarn/jquery/src/var/getProto.js +5 -0
  207. data/_assets/yarn/jquery/src/var/hasOwn.js +7 -0
  208. data/_assets/yarn/jquery/src/var/indexOf.js +7 -0
  209. data/_assets/yarn/jquery/src/var/pnum.js +5 -0
  210. data/_assets/yarn/jquery/src/var/push.js +7 -0
  211. data/_assets/yarn/jquery/src/var/rcssNum.js +9 -0
  212. data/_assets/yarn/jquery/src/var/rnothtmlwhite.js +8 -0
  213. data/_assets/yarn/jquery/src/var/slice.js +7 -0
  214. data/_assets/yarn/jquery/src/var/support.js +6 -0
  215. data/_assets/yarn/jquery/src/var/toString.js +7 -0
  216. data/_assets/yarn/jquery/src/wrap.js +77 -0
  217. data/_assets/yarn/retinajs/.babelrc +4 -0
  218. data/_assets/yarn/retinajs/.editorconfig +15 -0
  219. data/_assets/yarn/retinajs/.eslintignore +2 -0
  220. data/_assets/yarn/retinajs/.eslintrc +9 -0
  221. data/_assets/yarn/retinajs/.npmignore +7 -0
  222. data/_assets/yarn/retinajs/.travis.yml +20 -0
  223. data/_assets/yarn/retinajs/LICENSE +20 -0
  224. data/_assets/yarn/retinajs/README.md +267 -0
  225. data/_assets/yarn/retinajs/bower.json +25 -0
  226. data/_assets/yarn/retinajs/dist/_retina.sass +68 -0
  227. data/_assets/yarn/retinajs/dist/_retina.scss +102 -0
  228. data/_assets/yarn/retinajs/dist/retina.js +100 -0
  229. data/_assets/yarn/retinajs/dist/retina.js.map +1 -0
  230. data/_assets/yarn/retinajs/dist/retina.less +56 -0
  231. data/_assets/yarn/retinajs/dist/retina.min.js +2 -0
  232. data/_assets/yarn/retinajs/dist/retina.min.js.map +1 -0
  233. data/_assets/yarn/retinajs/dist/retina.styl +56 -0
  234. data/_assets/yarn/retinajs/es/_retina.sass +68 -0
  235. data/_assets/yarn/retinajs/es/_retina.scss +102 -0
  236. data/_assets/yarn/retinajs/es/retina.js +91 -0
  237. data/_assets/yarn/retinajs/es/retina.js.map +1 -0
  238. data/_assets/yarn/retinajs/es/retina.less +56 -0
  239. data/_assets/yarn/retinajs/es/retina.styl +56 -0
  240. data/_assets/yarn/retinajs/gulpfile.babel.js +154 -0
  241. data/_assets/yarn/retinajs/package.json +57 -0
  242. data/_assets/yarn/retinajs/src/_retina.sass +68 -0
  243. data/_assets/yarn/retinajs/src/_retina.scss +102 -0
  244. data/_assets/yarn/retinajs/src/retina.js +246 -0
  245. data/_assets/yarn/retinajs/src/retina.less +56 -0
  246. data/_assets/yarn/retinajs/src/retina.styl +56 -0
  247. data/_assets/yarn/retinajs/test/DOM.js +44 -0
  248. data/_assets/yarn/retinajs/test/fixtures/image.js +19 -0
  249. data/_assets/yarn/retinajs/test/fixtures/less_expected_output.css +18 -0
  250. data/_assets/yarn/retinajs/test/fixtures/scss_expected_output.css +13 -0
  251. data/_assets/yarn/retinajs/test/fixtures/test.less +10 -0
  252. data/_assets/yarn/retinajs/test/fixtures/test.scss +11 -0
  253. data/_assets/yarn/retinajs/test/fixtures/xml_http_request.js +24 -0
  254. data/_assets/yarn/retinajs/test/functional/public/google-logo.png +0 -0
  255. data/_assets/yarn/retinajs/test/functional/public/google-logo@2x.png +0 -0
  256. data/_assets/yarn/retinajs/test/functional/public/google-logo@3x.png +0 -0
  257. data/_assets/yarn/retinajs/test/functional/public/index.html +190 -0
  258. data/_assets/yarn/retinajs/test/functional/public/ipad.png +0 -0
  259. data/_assets/yarn/retinajs/test/functional/public/ipad@2x.png +0 -0
  260. data/_assets/yarn/retinajs/test/functional/public/ipad@3x.png +0 -0
  261. data/_assets/yarn/retinajs/test/functional/public/styles/_retina.sass +68 -0
  262. data/_assets/yarn/retinajs/test/functional/public/styles/_retina.scss +102 -0
  263. data/_assets/yarn/retinajs/test/functional/public/styles/less-base.less +13 -0
  264. data/_assets/yarn/retinajs/test/functional/public/styles/retina.less +56 -0
  265. data/_assets/yarn/retinajs/test/functional/public/styles/retina.less.css +73 -0
  266. data/_assets/yarn/retinajs/test/functional/public/styles/retina.sass.css +42 -0
  267. data/_assets/yarn/retinajs/test/functional/public/styles/retina.scss.css +96 -0
  268. data/_assets/yarn/retinajs/test/functional/public/styles/retina.styl +56 -0
  269. data/_assets/yarn/retinajs/test/functional/public/styles/retina.styl.css +61 -0
  270. data/_assets/yarn/retinajs/test/functional/public/styles/sass-base.sass +10 -0
  271. data/_assets/yarn/retinajs/test/functional/public/styles/scss-base.scss +13 -0
  272. data/_assets/yarn/retinajs/test/functional/public/styles/styl-base.styl +10 -0
  273. data/_assets/yarn/retinajs/test/mocha-runner.js +7 -0
  274. data/_assets/yarn/retinajs/test/retina.spec.js +14 -0
  275. data/_assets/yarn/scrollreveal/.gitattributes +10 -0
  276. data/_assets/yarn/scrollreveal/.github/CONTRIBUTING.md +9 -0
  277. data/_assets/yarn/scrollreveal/.github/ISSUE_TEMPLATE.md +11 -0
  278. data/_assets/yarn/scrollreveal/.ignore/coverage/PhantomJS 2.1.1 (Mac OS X 0.0.0)/lcov-report/base.css +213 -0
  279. data/_assets/yarn/scrollreveal/.ignore/coverage/PhantomJS 2.1.1 (Mac OS X 0.0.0)/lcov-report/index.html +158 -0
  280. data/_assets/yarn/scrollreveal/.ignore/coverage/PhantomJS 2.1.1 (Mac OS X 0.0.0)/lcov-report/lib/index.html +93 -0
  281. data/_assets/yarn/scrollreveal/.ignore/coverage/PhantomJS 2.1.1 (Mac OS X 0.0.0)/lcov-report/lib/package.json.html +143 -0
  282. 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
  283. 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
  284. 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
  285. 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
  286. 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
  287. 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
  288. 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
  289. 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
  290. 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
  291. 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
  292. 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
  293. 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
  294. 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
  295. 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
  296. 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
  297. 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
  298. 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
  299. 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
  300. 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
  301. 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
  302. 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
  303. data/_assets/yarn/scrollreveal/.ignore/coverage/PhantomJS 2.1.1 (Mac OS X 0.0.0)/lcov-report/prettify.css +1 -0
  304. data/_assets/yarn/scrollreveal/.ignore/coverage/PhantomJS 2.1.1 (Mac OS X 0.0.0)/lcov-report/prettify.js +1 -0
  305. data/_assets/yarn/scrollreveal/.ignore/coverage/PhantomJS 2.1.1 (Mac OS X 0.0.0)/lcov-report/sort-arrow-sprite.png +0 -0
  306. data/_assets/yarn/scrollreveal/.ignore/coverage/PhantomJS 2.1.1 (Mac OS X 0.0.0)/lcov-report/sorter.js +158 -0
  307. data/_assets/yarn/scrollreveal/.ignore/coverage/PhantomJS 2.1.1 (Mac OS X 0.0.0)/lcov.info +1016 -0
  308. data/_assets/yarn/scrollreveal/.ignore/coverage/server.coverage.js +11 -0
  309. data/_assets/yarn/scrollreveal/.ignore/sandbox/css/styles.css +32 -0
  310. data/_assets/yarn/scrollreveal/.ignore/sandbox/index.html +68 -0
  311. data/_assets/yarn/scrollreveal/.ignore/sandbox/js/scrollreveal.js +1271 -0
  312. data/_assets/yarn/scrollreveal/.ignore/sandbox/rollup.conf.sandbox.js +15 -0
  313. data/_assets/yarn/scrollreveal/.ignore/sandbox/server.sandbox.js +11 -0
  314. data/_assets/yarn/scrollreveal/.npmignore +8 -0
  315. data/_assets/yarn/scrollreveal/CHANGELOG.md +268 -0
  316. data/_assets/yarn/scrollreveal/LICENSE.md +12 -0
  317. data/_assets/yarn/scrollreveal/README.md +413 -0
  318. data/_assets/yarn/scrollreveal/bower.json +24 -0
  319. data/_assets/yarn/scrollreveal/dist/scrollreveal.js +860 -0
  320. data/_assets/yarn/scrollreveal/dist/scrollreveal.min.js +1 -0
  321. data/_assets/yarn/scrollreveal/gulpfile.js +33 -0
  322. data/_assets/yarn/scrollreveal/lib/gulp/gulp-clean.js +7 -0
  323. data/_assets/yarn/scrollreveal/lib/gulp/gulp-dev.js +6 -0
  324. data/_assets/yarn/scrollreveal/lib/gulp/gulp-dist-min.js +19 -0
  325. data/_assets/yarn/scrollreveal/lib/gulp/gulp-dist.js +6 -0
  326. data/_assets/yarn/scrollreveal/lib/gulp/gulp-server.js +9 -0
  327. data/_assets/yarn/scrollreveal/lib/gulp/gulp-validate-bower.js +13 -0
  328. data/_assets/yarn/scrollreveal/lib/gulp/gulp-watch.js +6 -0
  329. data/_assets/yarn/scrollreveal/src/scrollreveal.js +860 -0
  330. data/_assets/yarn/throttle-debounce-fn/.jscsrc +5 -0
  331. data/_assets/yarn/throttle-debounce-fn/.jshintrc +13 -0
  332. data/_assets/yarn/throttle-debounce-fn/.npmignore +1 -0
  333. data/_assets/yarn/throttle-debounce-fn/Gruntfile.js +76 -0
  334. data/_assets/yarn/throttle-debounce-fn/LICENSE.md +22 -0
  335. data/_assets/yarn/throttle-debounce-fn/README.md +55 -0
  336. data/_assets/yarn/throttle-debounce-fn/dist/throttle-debounce-fn.js +164 -0
  337. data/_assets/yarn/throttle-debounce-fn/dist/throttle-debounce-fn.min.js +10 -0
  338. data/_assets/yarn/throttle-debounce-fn/package.json +36 -0
  339. data/_assets/yarn/throttle-debounce-fn/src/throttle-debounce-fn.js +156 -0
  340. data/_assets/yarn/turbolinks/LICENSE +20 -0
  341. data/_assets/yarn/turbolinks/README.md +473 -0
  342. data/_assets/yarn/turbolinks/dist/turbolinks.js +6 -0
  343. data/_assets/yarn/turbolinks/src/turbolinks/BANNER.js.erb +4 -0
  344. data/_assets/yarn/turbolinks/src/turbolinks/VERSION +1 -0
  345. data/_assets/yarn/turbolinks/src/turbolinks/browser_adapter.coffee +61 -0
  346. data/_assets/yarn/turbolinks/src/turbolinks/compatibility.coffee +30 -0
  347. data/_assets/yarn/turbolinks/src/turbolinks/controller.coffee +239 -0
  348. data/_assets/yarn/turbolinks/src/turbolinks/error_renderer.coffee +21 -0
  349. data/_assets/yarn/turbolinks/src/turbolinks/head_details.coffee +51 -0
  350. data/_assets/yarn/turbolinks/src/turbolinks/helpers.coffee +57 -0
  351. data/_assets/yarn/turbolinks/src/turbolinks/history.coffee +48 -0
  352. data/_assets/yarn/turbolinks/src/turbolinks/http_request.coffee +88 -0
  353. data/_assets/yarn/turbolinks/src/turbolinks/index.coffee +18 -0
  354. data/_assets/yarn/turbolinks/src/turbolinks/location.coffee +70 -0
  355. data/_assets/yarn/turbolinks/src/turbolinks/progress_bar.coffee +83 -0
  356. data/_assets/yarn/turbolinks/src/turbolinks/renderer.coffee +27 -0
  357. data/_assets/yarn/turbolinks/src/turbolinks/scroll_manager.coffee +28 -0
  358. data/_assets/yarn/turbolinks/src/turbolinks/snapshot.coffee +47 -0
  359. data/_assets/yarn/turbolinks/src/turbolinks/snapshot_cache.coffee +43 -0
  360. data/_assets/yarn/turbolinks/src/turbolinks/snapshot_renderer.coffee +88 -0
  361. data/_assets/yarn/turbolinks/src/turbolinks/start.coffee +18 -0
  362. data/_assets/yarn/turbolinks/src/turbolinks/view.coffee +34 -0
  363. data/_assets/yarn/turbolinks/src/turbolinks/visit.coffee +162 -0
  364. data/_assets/yarn/webfontloader/CHANGELOG +419 -0
  365. data/_assets/yarn/webfontloader/LICENSE +176 -0
  366. data/_assets/yarn/webfontloader/README.md +394 -0
  367. data/_assets/yarn/webfontloader/package.json +37 -0
  368. data/_assets/yarn/webfontloader/src/closure.js +2 -0
  369. data/_assets/yarn/webfontloader/src/core/cssclassname.js +46 -0
  370. data/_assets/yarn/webfontloader/src/core/domhelper.js +405 -0
  371. data/_assets/yarn/webfontloader/src/core/eventdispatcher.js +195 -0
  372. data/_assets/yarn/webfontloader/src/core/font.js +140 -0
  373. data/_assets/yarn/webfontloader/src/core/fontmodule.js +16 -0
  374. data/_assets/yarn/webfontloader/src/core/fontmoduleloader.js +47 -0
  375. data/_assets/yarn/webfontloader/src/core/fontruler.js +60 -0
  376. data/_assets/yarn/webfontloader/src/core/fontwatcher.js +171 -0
  377. data/_assets/yarn/webfontloader/src/core/fontwatchrunner.js +249 -0
  378. data/_assets/yarn/webfontloader/src/core/initialize.js +97 -0
  379. data/_assets/yarn/webfontloader/src/core/nativefontwatchrunner.js +69 -0
  380. data/_assets/yarn/webfontloader/src/core/stylesheetwaiter.js +48 -0
  381. data/_assets/yarn/webfontloader/src/core/webfont.js +97 -0
  382. data/_assets/yarn/webfontloader/src/modules/custom.js +63 -0
  383. data/_assets/yarn/webfontloader/src/modules/fontdeck.js +66 -0
  384. data/_assets/yarn/webfontloader/src/modules/google/fontapiparser.js +181 -0
  385. data/_assets/yarn/webfontloader/src/modules/google/fontapiurlbuilder.js +77 -0
  386. data/_assets/yarn/webfontloader/src/modules/google/googlefontapi.js +54 -0
  387. data/_assets/yarn/webfontloader/src/modules/monotype.js +110 -0
  388. data/_assets/yarn/webfontloader/src/modules/typekit.js +73 -0
  389. data/_assets/yarn/webfontloader/webfontloader.js +17 -0
  390. data/_includes/footer.html +7 -0
  391. data/_includes/head.html +41 -0
  392. data/_includes/image.html +5 -0
  393. data/_includes/javascript.html +1 -0
  394. data/_includes/javascripts.html +19 -0
  395. data/_includes/navigation.html +75 -0
  396. data/_includes/stylesheet.html +1 -0
  397. data/_layouts/articles_by_tag.html +38 -0
  398. data/_layouts/default.html +16 -0
  399. data/_layouts/post.html +65 -0
  400. data/about.html +18 -0
  401. data/favicon.ico +0 -0
  402. data/feed.xml +20 -0
  403. data/index.html +49 -0
  404. data/robots.txt +5 -0
  405. 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