va_common 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (285) hide show
  1. checksums.yaml +7 -0
  2. data/.gitignore +9 -0
  3. data/.travis.yml +4 -0
  4. data/CODE_OF_CONDUCT.md +13 -0
  5. data/Gemfile +4 -0
  6. data/README.md +66 -0
  7. data/Rakefile +1 -0
  8. data/app/assets/fonts/merriweather-bold-webfont.eot +0 -0
  9. data/app/assets/fonts/merriweather-bold-webfont.svg +294 -0
  10. data/app/assets/fonts/merriweather-bold-webfont.ttf +0 -0
  11. data/app/assets/fonts/merriweather-bold-webfont.woff +0 -0
  12. data/app/assets/fonts/merriweather-bold-webfont.woff2 +0 -0
  13. data/app/assets/fonts/merriweather-italic-webfont.eot +0 -0
  14. data/app/assets/fonts/merriweather-italic-webfont.svg +283 -0
  15. data/app/assets/fonts/merriweather-italic-webfont.ttf +0 -0
  16. data/app/assets/fonts/merriweather-italic-webfont.woff +0 -0
  17. data/app/assets/fonts/merriweather-italic-webfont.woff2 +0 -0
  18. data/app/assets/fonts/merriweather-light-webfont.eot +0 -0
  19. data/app/assets/fonts/merriweather-light-webfont.svg +299 -0
  20. data/app/assets/fonts/merriweather-light-webfont.ttf +0 -0
  21. data/app/assets/fonts/merriweather-light-webfont.woff +0 -0
  22. data/app/assets/fonts/merriweather-light-webfont.woff2 +0 -0
  23. data/app/assets/fonts/merriweather-regular-webfont.eot +0 -0
  24. data/app/assets/fonts/merriweather-regular-webfont.svg +294 -0
  25. data/app/assets/fonts/merriweather-regular-webfont.ttf +0 -0
  26. data/app/assets/fonts/merriweather-regular-webfont.woff +0 -0
  27. data/app/assets/fonts/merriweather-regular-webfont.woff2 +0 -0
  28. data/app/assets/fonts/sourcesanspro-bold-webfont.eot +0 -0
  29. data/app/assets/fonts/sourcesanspro-bold-webfont.svg +965 -0
  30. data/app/assets/fonts/sourcesanspro-bold-webfont.ttf +0 -0
  31. data/app/assets/fonts/sourcesanspro-bold-webfont.woff +0 -0
  32. data/app/assets/fonts/sourcesanspro-bold-webfont.woff2 +0 -0
  33. data/app/assets/fonts/sourcesanspro-italic-webfont.eot +0 -0
  34. data/app/assets/fonts/sourcesanspro-italic-webfont.svg +853 -0
  35. data/app/assets/fonts/sourcesanspro-italic-webfont.ttf +0 -0
  36. data/app/assets/fonts/sourcesanspro-italic-webfont.woff +0 -0
  37. data/app/assets/fonts/sourcesanspro-italic-webfont.woff2 +0 -0
  38. data/app/assets/fonts/sourcesanspro-light-webfont.eot +0 -0
  39. data/app/assets/fonts/sourcesanspro-light-webfont.svg +915 -0
  40. data/app/assets/fonts/sourcesanspro-light-webfont.ttf +0 -0
  41. data/app/assets/fonts/sourcesanspro-light-webfont.woff +0 -0
  42. data/app/assets/fonts/sourcesanspro-light-webfont.woff2 +0 -0
  43. data/app/assets/fonts/sourcesanspro-regular-webfont.eot +0 -0
  44. data/app/assets/fonts/sourcesanspro-regular-webfont.svg +989 -0
  45. data/app/assets/fonts/sourcesanspro-regular-webfont.ttf +0 -0
  46. data/app/assets/fonts/sourcesanspro-regular-webfont.woff +0 -0
  47. data/app/assets/fonts/sourcesanspro-regular-webfont.woff2 +0 -0
  48. data/app/assets/images/design/background/thread.png +0 -0
  49. data/app/assets/images/design/logo/logo-alt-hover.png +0 -0
  50. data/app/assets/images/design/logo/logo-alt.png +0 -0
  51. data/app/assets/images/design/logo/logo-hover.png +0 -0
  52. data/app/assets/images/design/logo/logo-small.png +0 -0
  53. data/app/assets/images/design/logo/logo.png +0 -0
  54. data/app/assets/images/design/logo/og-image.jpg +0 -0
  55. data/app/assets/images/design/seal/seal-footer.png +0 -0
  56. data/app/assets/images/design/seal/seal-footer.svg +1 -0
  57. data/app/assets/images/design/seal/seal.png +0 -0
  58. data/app/assets/images/design/seal/stars.png +0 -0
  59. data/app/assets/images/icons/apple-touch-icon-114x114.png +0 -0
  60. data/app/assets/images/icons/apple-touch-icon-152x152.png +0 -0
  61. data/app/assets/images/icons/apple-touch-icon-72x72.png +0 -0
  62. data/app/assets/images/icons/apple-touch-icon.png +0 -0
  63. data/app/assets/images/icons/favicon.ico +0 -0
  64. data/app/assets/images/icons/va.png +0 -0
  65. data/app/assets/images/icons/watermark.png +0 -0
  66. data/app/assets/images/icons/wrench.png +0 -0
  67. data/app/assets/images/social-icons/png/facebook25.png +0 -0
  68. data/app/assets/images/social-icons/png/rss25.png +0 -0
  69. data/app/assets/images/social-icons/png/twitter16.png +0 -0
  70. data/app/assets/images/social-icons/png/youtube15.png +0 -0
  71. data/app/assets/images/social-icons/svg/facebook25.svg +11 -0
  72. data/app/assets/images/social-icons/svg/rss25.svg +1 -0
  73. data/app/assets/images/social-icons/svg/twitter16.svg +15 -0
  74. data/app/assets/images/social-icons/svg/youtube15.svg +1 -0
  75. data/app/assets/js/components.js +376 -0
  76. data/app/assets/js/foundation/foundation.abide.js +408 -0
  77. data/app/assets/js/foundation/foundation.accordion.js +88 -0
  78. data/app/assets/js/foundation/foundation.alert.js +43 -0
  79. data/app/assets/js/foundation/foundation.clearing.js +586 -0
  80. data/app/assets/js/foundation/foundation.dropdown.js +463 -0
  81. data/app/assets/js/foundation/foundation.equalizer.js +104 -0
  82. data/app/assets/js/foundation/foundation.interchange.js +359 -0
  83. data/app/assets/js/foundation/foundation.joyride.js +932 -0
  84. data/app/assets/js/foundation/foundation.js +725 -0
  85. data/app/assets/js/foundation/foundation.magellan.js +215 -0
  86. data/app/assets/js/foundation/foundation.offcanvas.js +152 -0
  87. data/app/assets/js/foundation/foundation.orbit.js +476 -0
  88. data/app/assets/js/foundation/foundation.reveal.js +498 -0
  89. data/app/assets/js/foundation/foundation.slider.js +281 -0
  90. data/app/assets/js/foundation/foundation.tab.js +249 -0
  91. data/app/assets/js/foundation/foundation.tooltip.js +339 -0
  92. data/app/assets/js/foundation/foundation.topbar.js +458 -0
  93. data/app/assets/js/foundation.min.js +6376 -0
  94. data/app/assets/js/scripts-no-touch.js +33 -0
  95. data/app/assets/js/scripts-touch.js +33 -0
  96. data/app/assets/js/va_common_main.js +1 -0
  97. data/app/assets/js/vendor/classie.js +80 -0
  98. data/app/assets/js/vendor/html5shiv.js +8 -0
  99. data/app/assets/js/vendor/jquery-1.11.0.min.js +4 -0
  100. data/app/assets/js/vendor/jquery.js +9789 -0
  101. data/app/assets/js/vendor/jquery.smooth-scroll.js +255 -0
  102. data/app/assets/js/vendor/jquery.stellar.js +651 -0
  103. data/app/assets/js/vendor/jquery.tipsy.js +258 -0
  104. data/app/assets/js/vendor/menu.js +40 -0
  105. data/app/assets/js/vendor/modernizr.custom.js +4 -0
  106. data/app/assets/js/vendor/nwmatcher-1.2.5-min.js +7 -0
  107. data/app/assets/js/vendor/respond.min.js +6 -0
  108. data/app/assets/js/vendor/scroll-settings.js +3 -0
  109. data/app/assets/js/vendor/selectivizr-1.0.3b.js +560 -0
  110. data/app/assets/js/vendor/stellar-settings.js +8 -0
  111. data/app/assets/js/vendor/svg-injector.js +450 -0
  112. data/app/assets/js/vendor/tota11y.min.js +28 -0
  113. data/app/assets/js/vendor/wow.min.js +2 -0
  114. data/app/assets/stylesheets/_va.scss +2377 -0
  115. data/app/assets/stylesheets/components/_accordions.scss +98 -0
  116. data/app/assets/stylesheets/core/_base.scss +20 -0
  117. data/app/assets/stylesheets/core/_defaults.scss +92 -0
  118. data/app/assets/stylesheets/core/_grid-settings.scss +10 -0
  119. data/app/assets/stylesheets/core/_grid.scss +116 -0
  120. data/app/assets/stylesheets/core/_utilities.scss +105 -0
  121. data/app/assets/stylesheets/core/_variables.scss +88 -0
  122. data/app/assets/stylesheets/elements/_buttons.scss +189 -0
  123. data/app/assets/stylesheets/elements/_figure.scss +9 -0
  124. data/app/assets/stylesheets/elements/_inputs.scss +328 -0
  125. data/app/assets/stylesheets/elements/_labels.scss +39 -0
  126. data/app/assets/stylesheets/elements/_list.scss +82 -0
  127. data/app/assets/stylesheets/elements/_table.scss +39 -0
  128. data/app/assets/stylesheets/elements/_typography.scss +220 -0
  129. data/app/assets/stylesheets/foundation/_functions.scss +146 -0
  130. data/app/assets/stylesheets/foundation/_settings.scss +1467 -0
  131. data/app/assets/stylesheets/foundation/_variables.scss +1286 -0
  132. data/app/assets/stylesheets/foundation/components/_accordion.scss +157 -0
  133. data/app/assets/stylesheets/foundation/components/_alert-boxes.scss +128 -0
  134. data/app/assets/stylesheets/foundation/components/_block-grid.scss +132 -0
  135. data/app/assets/stylesheets/foundation/components/_breadcrumbs.scss +132 -0
  136. data/app/assets/stylesheets/foundation/components/_button-groups.scss +200 -0
  137. data/app/assets/stylesheets/foundation/components/_buttons.scss +259 -0
  138. data/app/assets/stylesheets/foundation/components/_clearing.scss +256 -0
  139. data/app/assets/stylesheets/foundation/components/_dropdown-buttons.scss +131 -0
  140. data/app/assets/stylesheets/foundation/components/_dropdown.scss +262 -0
  141. data/app/assets/stylesheets/foundation/components/_flex-video.scss +51 -0
  142. data/app/assets/stylesheets/foundation/components/_forms.scss +570 -0
  143. data/app/assets/stylesheets/foundation/components/_global.scss +481 -0
  144. data/app/assets/stylesheets/foundation/components/_grid.scss +289 -0
  145. data/app/assets/stylesheets/foundation/components/_icon-bar.scss +358 -0
  146. data/app/assets/stylesheets/foundation/components/_inline-lists.scss +57 -0
  147. data/app/assets/stylesheets/foundation/components/_joyride.scss +222 -0
  148. data/app/assets/stylesheets/foundation/components/_keystrokes.scss +61 -0
  149. data/app/assets/stylesheets/foundation/components/_labels.scss +106 -0
  150. data/app/assets/stylesheets/foundation/components/_magellan.scss +34 -0
  151. data/app/assets/stylesheets/foundation/components/_offcanvas.scss +515 -0
  152. data/app/assets/stylesheets/foundation/components/_orbit.scss +368 -0
  153. data/app/assets/stylesheets/foundation/components/_pagination.scss +162 -0
  154. data/app/assets/stylesheets/foundation/components/_panels.scss +101 -0
  155. data/app/assets/stylesheets/foundation/components/_pricing-tables.scss +150 -0
  156. data/app/assets/stylesheets/foundation/components/_progress-bars.scss +79 -0
  157. data/app/assets/stylesheets/foundation/components/_range-slider.scss +169 -0
  158. data/app/assets/stylesheets/foundation/components/_reveal.scss +202 -0
  159. data/app/assets/stylesheets/foundation/components/_side-nav.scss +116 -0
  160. data/app/assets/stylesheets/foundation/components/_split-buttons.scss +199 -0
  161. data/app/assets/stylesheets/foundation/components/_sub-nav.scss +123 -0
  162. data/app/assets/stylesheets/foundation/components/_switches.scss +238 -0
  163. data/app/assets/stylesheets/foundation/components/_tables.scss +135 -0
  164. data/app/assets/stylesheets/foundation/components/_tabs.scss +123 -0
  165. data/app/assets/stylesheets/foundation/components/_thumbs.scss +66 -0
  166. data/app/assets/stylesheets/foundation/components/_toolbar.scss +70 -0
  167. data/app/assets/stylesheets/foundation/components/_tooltips.scss +142 -0
  168. data/app/assets/stylesheets/foundation/components/_top-bar.scss +691 -0
  169. data/app/assets/stylesheets/foundation/components/_type.scss +525 -0
  170. data/app/assets/stylesheets/foundation/components/_visibility.scss +408 -0
  171. data/app/assets/stylesheets/functions/_new-breakpoint.scss +49 -0
  172. data/app/assets/stylesheets/functions/_private.scss +114 -0
  173. data/app/assets/stylesheets/lib/_normalize.scss +427 -0
  174. data/app/assets/stylesheets/lib/bourbon/_bourbon-deprecated-upcoming.scss +411 -0
  175. data/app/assets/stylesheets/lib/bourbon/_bourbon.scss +87 -0
  176. data/app/assets/stylesheets/lib/bourbon/addons/_border-color.scss +26 -0
  177. data/app/assets/stylesheets/lib/bourbon/addons/_border-radius.scss +48 -0
  178. data/app/assets/stylesheets/lib/bourbon/addons/_border-style.scss +25 -0
  179. data/app/assets/stylesheets/lib/bourbon/addons/_border-width.scss +25 -0
  180. data/app/assets/stylesheets/lib/bourbon/addons/_buttons.scss +64 -0
  181. data/app/assets/stylesheets/lib/bourbon/addons/_clearfix.scss +25 -0
  182. data/app/assets/stylesheets/lib/bourbon/addons/_ellipsis.scss +30 -0
  183. data/app/assets/stylesheets/lib/bourbon/addons/_font-stacks.scss +31 -0
  184. data/app/assets/stylesheets/lib/bourbon/addons/_hide-text.scss +27 -0
  185. data/app/assets/stylesheets/lib/bourbon/addons/_margin.scss +26 -0
  186. data/app/assets/stylesheets/lib/bourbon/addons/_padding.scss +26 -0
  187. data/app/assets/stylesheets/lib/bourbon/addons/_position.scss +48 -0
  188. data/app/assets/stylesheets/lib/bourbon/addons/_prefixer.scss +66 -0
  189. data/app/assets/stylesheets/lib/bourbon/addons/_retina-image.scss +25 -0
  190. data/app/assets/stylesheets/lib/bourbon/addons/_size.scss +51 -0
  191. data/app/assets/stylesheets/lib/bourbon/addons/_text-inputs.scss +112 -0
  192. data/app/assets/stylesheets/lib/bourbon/addons/_timing-functions.scss +34 -0
  193. data/app/assets/stylesheets/lib/bourbon/addons/_triangle.scss +63 -0
  194. data/app/assets/stylesheets/lib/bourbon/addons/_word-wrap.scss +29 -0
  195. data/app/assets/stylesheets/lib/bourbon/css3/_animation.scss +43 -0
  196. data/app/assets/stylesheets/lib/bourbon/css3/_appearance.scss +3 -0
  197. data/app/assets/stylesheets/lib/bourbon/css3/_backface-visibility.scss +3 -0
  198. data/app/assets/stylesheets/lib/bourbon/css3/_background-image.scss +42 -0
  199. data/app/assets/stylesheets/lib/bourbon/css3/_background.scss +55 -0
  200. data/app/assets/stylesheets/lib/bourbon/css3/_border-image.scss +59 -0
  201. data/app/assets/stylesheets/lib/bourbon/css3/_calc.scss +4 -0
  202. data/app/assets/stylesheets/lib/bourbon/css3/_columns.scss +47 -0
  203. data/app/assets/stylesheets/lib/bourbon/css3/_filter.scss +4 -0
  204. data/app/assets/stylesheets/lib/bourbon/css3/_flex-box.scss +287 -0
  205. data/app/assets/stylesheets/lib/bourbon/css3/_font-face.scss +24 -0
  206. data/app/assets/stylesheets/lib/bourbon/css3/_font-feature-settings.scss +4 -0
  207. data/app/assets/stylesheets/lib/bourbon/css3/_hidpi-media-query.scss +10 -0
  208. data/app/assets/stylesheets/lib/bourbon/css3/_hyphens.scss +4 -0
  209. data/app/assets/stylesheets/lib/bourbon/css3/_image-rendering.scss +14 -0
  210. data/app/assets/stylesheets/lib/bourbon/css3/_keyframes.scss +36 -0
  211. data/app/assets/stylesheets/lib/bourbon/css3/_linear-gradient.scss +38 -0
  212. data/app/assets/stylesheets/lib/bourbon/css3/_perspective.scss +8 -0
  213. data/app/assets/stylesheets/lib/bourbon/css3/_placeholder.scss +8 -0
  214. data/app/assets/stylesheets/lib/bourbon/css3/_radial-gradient.scss +39 -0
  215. data/app/assets/stylesheets/lib/bourbon/css3/_selection.scss +42 -0
  216. data/app/assets/stylesheets/lib/bourbon/css3/_text-decoration.scss +19 -0
  217. data/app/assets/stylesheets/lib/bourbon/css3/_transform.scss +15 -0
  218. data/app/assets/stylesheets/lib/bourbon/css3/_transition.scss +71 -0
  219. data/app/assets/stylesheets/lib/bourbon/css3/_user-select.scss +3 -0
  220. data/app/assets/stylesheets/lib/bourbon/functions/_assign-inputs.scss +11 -0
  221. data/app/assets/stylesheets/lib/bourbon/functions/_contains-falsy.scss +20 -0
  222. data/app/assets/stylesheets/lib/bourbon/functions/_contains.scss +26 -0
  223. data/app/assets/stylesheets/lib/bourbon/functions/_is-length.scss +11 -0
  224. data/app/assets/stylesheets/lib/bourbon/functions/_is-light.scss +21 -0
  225. data/app/assets/stylesheets/lib/bourbon/functions/_is-number.scss +11 -0
  226. data/app/assets/stylesheets/lib/bourbon/functions/_is-size.scss +13 -0
  227. data/app/assets/stylesheets/lib/bourbon/functions/_modular-scale.scss +69 -0
  228. data/app/assets/stylesheets/lib/bourbon/functions/_px-to-em.scss +13 -0
  229. data/app/assets/stylesheets/lib/bourbon/functions/_px-to-rem.scss +15 -0
  230. data/app/assets/stylesheets/lib/bourbon/functions/_shade.scss +24 -0
  231. data/app/assets/stylesheets/lib/bourbon/functions/_strip-units.scss +17 -0
  232. data/app/assets/stylesheets/lib/bourbon/functions/_tint.scss +24 -0
  233. data/app/assets/stylesheets/lib/bourbon/functions/_transition-property-name.scss +22 -0
  234. data/app/assets/stylesheets/lib/bourbon/functions/_unpack.scss +27 -0
  235. data/app/assets/stylesheets/lib/bourbon/helpers/_convert-units.scss +21 -0
  236. data/app/assets/stylesheets/lib/bourbon/helpers/_directional-values.scss +96 -0
  237. data/app/assets/stylesheets/lib/bourbon/helpers/_font-source-declaration.scss +43 -0
  238. data/app/assets/stylesheets/lib/bourbon/helpers/_gradient-positions-parser.scss +13 -0
  239. data/app/assets/stylesheets/lib/bourbon/helpers/_linear-angle-parser.scss +25 -0
  240. data/app/assets/stylesheets/lib/bourbon/helpers/_linear-gradient-parser.scss +41 -0
  241. data/app/assets/stylesheets/lib/bourbon/helpers/_linear-positions-parser.scss +61 -0
  242. data/app/assets/stylesheets/lib/bourbon/helpers/_linear-side-corner-parser.scss +31 -0
  243. data/app/assets/stylesheets/lib/bourbon/helpers/_radial-arg-parser.scss +69 -0
  244. data/app/assets/stylesheets/lib/bourbon/helpers/_radial-gradient-parser.scss +50 -0
  245. data/app/assets/stylesheets/lib/bourbon/helpers/_radial-positions-parser.scss +18 -0
  246. data/app/assets/stylesheets/lib/bourbon/helpers/_render-gradients.scss +26 -0
  247. data/app/assets/stylesheets/lib/bourbon/helpers/_shape-size-stripper.scss +10 -0
  248. data/app/assets/stylesheets/lib/bourbon/helpers/_str-to-num.scss +50 -0
  249. data/app/assets/stylesheets/lib/bourbon/settings/_asset-pipeline.scss +7 -0
  250. data/app/assets/stylesheets/lib/bourbon/settings/_prefixer.scss +9 -0
  251. data/app/assets/stylesheets/lib/bourbon/settings/_px-to-em.scss +1 -0
  252. data/app/assets/stylesheets/lib/neat/_neat-helpers.scss +8 -0
  253. data/app/assets/stylesheets/lib/neat/_neat.scss +23 -0
  254. data/app/assets/stylesheets/lib/neat/functions/_new-breakpoint.scss +49 -0
  255. data/app/assets/stylesheets/lib/neat/functions/_private.scss +114 -0
  256. data/app/assets/stylesheets/lib/neat/grid/_box-sizing.scss +15 -0
  257. data/app/assets/stylesheets/lib/neat/grid/_direction-context.scss +33 -0
  258. data/app/assets/stylesheets/lib/neat/grid/_display-context.scss +28 -0
  259. data/app/assets/stylesheets/lib/neat/grid/_fill-parent.scss +22 -0
  260. data/app/assets/stylesheets/lib/neat/grid/_media.scss +92 -0
  261. data/app/assets/stylesheets/lib/neat/grid/_omega.scss +87 -0
  262. data/app/assets/stylesheets/lib/neat/grid/_outer-container.scss +38 -0
  263. data/app/assets/stylesheets/lib/neat/grid/_pad.scss +25 -0
  264. data/app/assets/stylesheets/lib/neat/grid/_private.scss +35 -0
  265. data/app/assets/stylesheets/lib/neat/grid/_row.scss +52 -0
  266. data/app/assets/stylesheets/lib/neat/grid/_shift.scss +50 -0
  267. data/app/assets/stylesheets/lib/neat/grid/_span-columns.scss +94 -0
  268. data/app/assets/stylesheets/lib/neat/grid/_to-deprecate.scss +97 -0
  269. data/app/assets/stylesheets/lib/neat/grid/_visual-grid.scss +42 -0
  270. data/app/assets/stylesheets/lib/neat/settings/_disable-warnings.scss +13 -0
  271. data/app/assets/stylesheets/lib/neat/settings/_grid.scss +51 -0
  272. data/app/assets/stylesheets/lib/neat/settings/_visual-grid.scss +27 -0
  273. data/app/assets/stylesheets/va_common_main.css.scss +18 -0
  274. data/bin/console +14 -0
  275. data/bin/setup +7 -0
  276. data/lib/generators/files/_footer.html.erb +89 -0
  277. data/lib/generators/files/_header.html.erb +7 -0
  278. data/lib/generators/va_common_generator.rb +6 -0
  279. data/lib/generators/va_footer_generator.rb +7 -0
  280. data/lib/generators/va_header_generator.rb +7 -0
  281. data/lib/va_common/engine.rb +4 -0
  282. data/lib/va_common/version.rb +3 -0
  283. data/lib/va_common.rb +2 -0
  284. data/va_common.gemspec +22 -0
  285. metadata +354 -0
@@ -0,0 +1,586 @@
1
+ ;(function ($, window, document, undefined) {
2
+ 'use strict';
3
+
4
+ Foundation.libs.clearing = {
5
+ name : 'clearing',
6
+
7
+ version : '5.5.2',
8
+
9
+ settings : {
10
+ templates : {
11
+ viewing : '<a href="#" class="clearing-close">&times;</a>' +
12
+ '<div class="visible-img" style="display: none"><div class="clearing-touch-label"></div><img src="data:image/gif;base64,R0lGODlhAQABAAD/ACwAAAAAAQABAAACADs%3D" alt="" />' +
13
+ '<p class="clearing-caption"></p><a href="#" class="clearing-main-prev"><span></span></a>' +
14
+ '<a href="#" class="clearing-main-next"><span></span></a></div>' +
15
+ '<img class="clearing-preload-next" style="display: none" src="data:image/gif;base64,R0lGODlhAQABAAD/ACwAAAAAAQABAAACADs%3D" alt="" />' +
16
+ '<img class="clearing-preload-prev" style="display: none" src="data:image/gif;base64,R0lGODlhAQABAAD/ACwAAAAAAQABAAACADs%3D" alt="" />'
17
+ },
18
+
19
+ // comma delimited list of selectors that, on click, will close clearing,
20
+ // add 'div.clearing-blackout, div.visible-img' to close on background click
21
+ close_selectors : '.clearing-close, div.clearing-blackout',
22
+
23
+ // Default to the entire li element.
24
+ open_selectors : '',
25
+
26
+ // Image will be skipped in carousel.
27
+ skip_selector : '',
28
+
29
+ touch_label : '',
30
+
31
+ // event initializers and locks
32
+ init : false,
33
+ locked : false
34
+ },
35
+
36
+ init : function (scope, method, options) {
37
+ var self = this;
38
+ Foundation.inherit(this, 'throttle image_loaded');
39
+
40
+ this.bindings(method, options);
41
+
42
+ if (self.S(this.scope).is('[' + this.attr_name() + ']')) {
43
+ this.assemble(self.S('li', this.scope));
44
+ } else {
45
+ self.S('[' + this.attr_name() + ']', this.scope).each(function () {
46
+ self.assemble(self.S('li', this));
47
+ });
48
+ }
49
+ },
50
+
51
+ events : function (scope) {
52
+ var self = this,
53
+ S = self.S,
54
+ $scroll_container = $('.scroll-container');
55
+
56
+ if ($scroll_container.length > 0) {
57
+ this.scope = $scroll_container;
58
+ }
59
+
60
+ S(this.scope)
61
+ .off('.clearing')
62
+ .on('click.fndtn.clearing', 'ul[' + this.attr_name() + '] li ' + this.settings.open_selectors,
63
+ function (e, current, target) {
64
+ var current = current || S(this),
65
+ target = target || current,
66
+ next = current.next('li'),
67
+ settings = current.closest('[' + self.attr_name() + ']').data(self.attr_name(true) + '-init'),
68
+ image = S(e.target);
69
+
70
+ e.preventDefault();
71
+
72
+ if (!settings) {
73
+ self.init();
74
+ settings = current.closest('[' + self.attr_name() + ']').data(self.attr_name(true) + '-init');
75
+ }
76
+
77
+ // if clearing is open and the current image is
78
+ // clicked, go to the next image in sequence
79
+ if (target.hasClass('visible') &&
80
+ current[0] === target[0] &&
81
+ next.length > 0 && self.is_open(current)) {
82
+ target = next;
83
+ image = S('img', target);
84
+ }
85
+
86
+ // set current and target to the clicked li if not otherwise defined.
87
+ self.open(image, current, target);
88
+ self.update_paddles(target);
89
+ })
90
+
91
+ .on('click.fndtn.clearing', '.clearing-main-next',
92
+ function (e) { self.nav(e, 'next') })
93
+ .on('click.fndtn.clearing', '.clearing-main-prev',
94
+ function (e) { self.nav(e, 'prev') })
95
+ .on('click.fndtn.clearing', this.settings.close_selectors,
96
+ function (e) { Foundation.libs.clearing.close(e, this) });
97
+
98
+ $(document).on('keydown.fndtn.clearing',
99
+ function (e) { self.keydown(e) });
100
+
101
+ S(window).off('.clearing').on('resize.fndtn.clearing',
102
+ function () { self.resize() });
103
+
104
+ this.swipe_events(scope);
105
+ },
106
+
107
+ swipe_events : function (scope) {
108
+ var self = this,
109
+ S = self.S;
110
+
111
+ S(this.scope)
112
+ .on('touchstart.fndtn.clearing', '.visible-img', function (e) {
113
+ if (!e.touches) { e = e.originalEvent; }
114
+ var data = {
115
+ start_page_x : e.touches[0].pageX,
116
+ start_page_y : e.touches[0].pageY,
117
+ start_time : (new Date()).getTime(),
118
+ delta_x : 0,
119
+ is_scrolling : undefined
120
+ };
121
+
122
+ S(this).data('swipe-transition', data);
123
+ e.stopPropagation();
124
+ })
125
+ .on('touchmove.fndtn.clearing', '.visible-img', function (e) {
126
+ if (!e.touches) {
127
+ e = e.originalEvent;
128
+ }
129
+ // Ignore pinch/zoom events
130
+ if (e.touches.length > 1 || e.scale && e.scale !== 1) {
131
+ return;
132
+ }
133
+
134
+ var data = S(this).data('swipe-transition');
135
+
136
+ if (typeof data === 'undefined') {
137
+ data = {};
138
+ }
139
+
140
+ data.delta_x = e.touches[0].pageX - data.start_page_x;
141
+
142
+ if (Foundation.rtl) {
143
+ data.delta_x = -data.delta_x;
144
+ }
145
+
146
+ if (typeof data.is_scrolling === 'undefined') {
147
+ data.is_scrolling = !!( data.is_scrolling || Math.abs(data.delta_x) < Math.abs(e.touches[0].pageY - data.start_page_y) );
148
+ }
149
+
150
+ if (!data.is_scrolling && !data.active) {
151
+ e.preventDefault();
152
+ var direction = (data.delta_x < 0) ? 'next' : 'prev';
153
+ data.active = true;
154
+ self.nav(e, direction);
155
+ }
156
+ })
157
+ .on('touchend.fndtn.clearing', '.visible-img', function (e) {
158
+ S(this).data('swipe-transition', {});
159
+ e.stopPropagation();
160
+ });
161
+ },
162
+
163
+ assemble : function ($li) {
164
+ var $el = $li.parent();
165
+
166
+ if ($el.parent().hasClass('carousel')) {
167
+ return;
168
+ }
169
+
170
+ $el.after('<div id="foundationClearingHolder"></div>');
171
+
172
+ var grid = $el.detach(),
173
+ grid_outerHTML = '';
174
+
175
+ if (grid[0] == null) {
176
+ return;
177
+ } else {
178
+ grid_outerHTML = grid[0].outerHTML;
179
+ }
180
+
181
+ var holder = this.S('#foundationClearingHolder'),
182
+ settings = $el.data(this.attr_name(true) + '-init'),
183
+ data = {
184
+ grid : '<div class="carousel">' + grid_outerHTML + '</div>',
185
+ viewing : settings.templates.viewing
186
+ },
187
+ wrapper = '<div class="clearing-assembled"><div>' + data.viewing +
188
+ data.grid + '</div></div>',
189
+ touch_label = this.settings.touch_label;
190
+
191
+ if (Modernizr.touch) {
192
+ wrapper = $(wrapper).find('.clearing-touch-label').html(touch_label).end();
193
+ }
194
+
195
+ holder.after(wrapper).remove();
196
+ },
197
+
198
+ open : function ($image, current, target) {
199
+ var self = this,
200
+ body = $(document.body),
201
+ root = target.closest('.clearing-assembled'),
202
+ container = self.S('div', root).first(),
203
+ visible_image = self.S('.visible-img', container),
204
+ image = self.S('img', visible_image).not($image),
205
+ label = self.S('.clearing-touch-label', container),
206
+ error = false,
207
+ loaded = {};
208
+
209
+ // Event to disable scrolling on touch devices when Clearing is activated
210
+ $('body').on('touchmove', function (e) {
211
+ e.preventDefault();
212
+ });
213
+
214
+ image.error(function () {
215
+ error = true;
216
+ });
217
+
218
+ function startLoad() {
219
+ setTimeout(function () {
220
+ this.image_loaded(image, function () {
221
+ if (image.outerWidth() === 1 && !error) {
222
+ startLoad.call(this);
223
+ } else {
224
+ cb.call(this, image);
225
+ }
226
+ }.bind(this));
227
+ }.bind(this), 100);
228
+ }
229
+
230
+ function cb (image) {
231
+ var $image = $(image);
232
+ $image.css('visibility', 'visible');
233
+ $image.trigger('imageVisible');
234
+ // toggle the gallery
235
+ body.css('overflow', 'hidden');
236
+ root.addClass('clearing-blackout');
237
+ container.addClass('clearing-container');
238
+ visible_image.show();
239
+ this.fix_height(target)
240
+ .caption(self.S('.clearing-caption', visible_image), self.S('img', target))
241
+ .center_and_label(image, label)
242
+ .shift(current, target, function () {
243
+ target.closest('li').siblings().removeClass('visible');
244
+ target.closest('li').addClass('visible');
245
+ });
246
+ visible_image.trigger('opened.fndtn.clearing')
247
+ }
248
+
249
+ if (!this.locked()) {
250
+ visible_image.trigger('open.fndtn.clearing');
251
+ // set the image to the selected thumbnail
252
+ loaded = this.load($image);
253
+ if (loaded.interchange) {
254
+ image
255
+ .attr('data-interchange', loaded.interchange)
256
+ .foundation('interchange', 'reflow');
257
+ } else {
258
+ image
259
+ .attr('src', loaded.src)
260
+ .attr('data-interchange', '');
261
+ }
262
+ image.css('visibility', 'hidden');
263
+
264
+ startLoad.call(this);
265
+ }
266
+ },
267
+
268
+ close : function (e, el) {
269
+ e.preventDefault();
270
+
271
+ var root = (function (target) {
272
+ if (/blackout/.test(target.selector)) {
273
+ return target;
274
+ } else {
275
+ return target.closest('.clearing-blackout');
276
+ }
277
+ }($(el))),
278
+ body = $(document.body), container, visible_image;
279
+
280
+ if (el === e.target && root) {
281
+ body.css('overflow', '');
282
+ container = $('div', root).first();
283
+ visible_image = $('.visible-img', container);
284
+ visible_image.trigger('close.fndtn.clearing');
285
+ this.settings.prev_index = 0;
286
+ $('ul[' + this.attr_name() + ']', root)
287
+ .attr('style', '').closest('.clearing-blackout')
288
+ .removeClass('clearing-blackout');
289
+ container.removeClass('clearing-container');
290
+ visible_image.hide();
291
+ visible_image.trigger('closed.fndtn.clearing');
292
+ }
293
+
294
+ // Event to re-enable scrolling on touch devices
295
+ $('body').off('touchmove');
296
+
297
+ return false;
298
+ },
299
+
300
+ is_open : function (current) {
301
+ return current.parent().prop('style').length > 0;
302
+ },
303
+
304
+ keydown : function (e) {
305
+ var clearing = $('.clearing-blackout ul[' + this.attr_name() + ']'),
306
+ NEXT_KEY = this.rtl ? 37 : 39,
307
+ PREV_KEY = this.rtl ? 39 : 37,
308
+ ESC_KEY = 27;
309
+
310
+ if (e.which === NEXT_KEY) {
311
+ this.go(clearing, 'next');
312
+ }
313
+ if (e.which === PREV_KEY) {
314
+ this.go(clearing, 'prev');
315
+ }
316
+ if (e.which === ESC_KEY) {
317
+ this.S('a.clearing-close').trigger('click.fndtn.clearing');
318
+ }
319
+ },
320
+
321
+ nav : function (e, direction) {
322
+ var clearing = $('ul[' + this.attr_name() + ']', '.clearing-blackout');
323
+
324
+ e.preventDefault();
325
+ this.go(clearing, direction);
326
+ },
327
+
328
+ resize : function () {
329
+ var image = $('img', '.clearing-blackout .visible-img'),
330
+ label = $('.clearing-touch-label', '.clearing-blackout');
331
+
332
+ if (image.length) {
333
+ this.center_and_label(image, label);
334
+ image.trigger('resized.fndtn.clearing')
335
+ }
336
+ },
337
+
338
+ // visual adjustments
339
+ fix_height : function (target) {
340
+ var lis = target.parent().children(),
341
+ self = this;
342
+
343
+ lis.each(function () {
344
+ var li = self.S(this),
345
+ image = li.find('img');
346
+
347
+ if (li.height() > image.outerHeight()) {
348
+ li.addClass('fix-height');
349
+ }
350
+ })
351
+ .closest('ul')
352
+ .width(lis.length * 100 + '%');
353
+
354
+ return this;
355
+ },
356
+
357
+ update_paddles : function (target) {
358
+ target = target.closest('li');
359
+ var visible_image = target
360
+ .closest('.carousel')
361
+ .siblings('.visible-img');
362
+
363
+ if (target.next().length > 0) {
364
+ this.S('.clearing-main-next', visible_image).removeClass('disabled');
365
+ } else {
366
+ this.S('.clearing-main-next', visible_image).addClass('disabled');
367
+ }
368
+
369
+ if (target.prev().length > 0) {
370
+ this.S('.clearing-main-prev', visible_image).removeClass('disabled');
371
+ } else {
372
+ this.S('.clearing-main-prev', visible_image).addClass('disabled');
373
+ }
374
+ },
375
+
376
+ center_and_label : function (target, label) {
377
+ if (!this.rtl && label.length > 0) {
378
+ label.css({
379
+ marginLeft : -(label.outerWidth() / 2),
380
+ marginTop : -(target.outerHeight() / 2)-label.outerHeight()-10
381
+ });
382
+ } else {
383
+ label.css({
384
+ marginRight : -(label.outerWidth() / 2),
385
+ marginTop : -(target.outerHeight() / 2)-label.outerHeight()-10,
386
+ left: 'auto',
387
+ right: '50%'
388
+ });
389
+ }
390
+ return this;
391
+ },
392
+
393
+ // image loading and preloading
394
+
395
+ load : function ($image) {
396
+ var href,
397
+ interchange,
398
+ closest_a;
399
+
400
+ if ($image[0].nodeName === 'A') {
401
+ href = $image.attr('href');
402
+ interchange = $image.data('clearing-interchange');
403
+ } else {
404
+ closest_a = $image.closest('a');
405
+ href = closest_a.attr('href');
406
+ interchange = closest_a.data('clearing-interchange');
407
+ }
408
+
409
+ this.preload($image);
410
+
411
+ return {
412
+ 'src': href ? href : $image.attr('src'),
413
+ 'interchange': href ? interchange : $image.data('clearing-interchange')
414
+ }
415
+ },
416
+
417
+ preload : function ($image) {
418
+ this
419
+ .img($image.closest('li').next(), 'next')
420
+ .img($image.closest('li').prev(), 'prev');
421
+ },
422
+
423
+ img : function (img, sibling_type) {
424
+ if (img.length) {
425
+ var preload_img = $('.clearing-preload-' + sibling_type),
426
+ new_a = this.S('a', img),
427
+ src,
428
+ interchange,
429
+ image;
430
+
431
+ if (new_a.length) {
432
+ src = new_a.attr('href');
433
+ interchange = new_a.data('clearing-interchange');
434
+ } else {
435
+ image = this.S('img', img);
436
+ src = image.attr('src');
437
+ interchange = image.data('clearing-interchange');
438
+ }
439
+
440
+ if (interchange) {
441
+ preload_img.attr('data-interchange', interchange);
442
+ } else {
443
+ preload_img.attr('src', src);
444
+ preload_img.attr('data-interchange', '');
445
+ }
446
+ }
447
+ return this;
448
+ },
449
+
450
+ // image caption
451
+
452
+ caption : function (container, $image) {
453
+ var caption = $image.attr('data-caption');
454
+
455
+ if (caption) {
456
+ container
457
+ .html(caption)
458
+ .show();
459
+ } else {
460
+ container
461
+ .text('')
462
+ .hide();
463
+ }
464
+ return this;
465
+ },
466
+
467
+ // directional methods
468
+
469
+ go : function ($ul, direction) {
470
+ var current = this.S('.visible', $ul),
471
+ target = current[direction]();
472
+
473
+ // Check for skip selector.
474
+ if (this.settings.skip_selector && target.find(this.settings.skip_selector).length != 0) {
475
+ target = target[direction]();
476
+ }
477
+
478
+ if (target.length) {
479
+ this.S('img', target)
480
+ .trigger('click.fndtn.clearing', [current, target])
481
+ .trigger('change.fndtn.clearing');
482
+ }
483
+ },
484
+
485
+ shift : function (current, target, callback) {
486
+ var clearing = target.parent(),
487
+ old_index = this.settings.prev_index || target.index(),
488
+ direction = this.direction(clearing, current, target),
489
+ dir = this.rtl ? 'right' : 'left',
490
+ left = parseInt(clearing.css('left'), 10),
491
+ width = target.outerWidth(),
492
+ skip_shift;
493
+
494
+ var dir_obj = {};
495
+
496
+ // we use jQuery animate instead of CSS transitions because we
497
+ // need a callback to unlock the next animation
498
+ // needs support for RTL **
499
+ if (target.index() !== old_index && !/skip/.test(direction)) {
500
+ if (/left/.test(direction)) {
501
+ this.lock();
502
+ dir_obj[dir] = left + width;
503
+ clearing.animate(dir_obj, 300, this.unlock());
504
+ } else if (/right/.test(direction)) {
505
+ this.lock();
506
+ dir_obj[dir] = left - width;
507
+ clearing.animate(dir_obj, 300, this.unlock());
508
+ }
509
+ } else if (/skip/.test(direction)) {
510
+ // the target image is not adjacent to the current image, so
511
+ // do we scroll right or not
512
+ skip_shift = target.index() - this.settings.up_count;
513
+ this.lock();
514
+
515
+ if (skip_shift > 0) {
516
+ dir_obj[dir] = -(skip_shift * width);
517
+ clearing.animate(dir_obj, 300, this.unlock());
518
+ } else {
519
+ dir_obj[dir] = 0;
520
+ clearing.animate(dir_obj, 300, this.unlock());
521
+ }
522
+ }
523
+
524
+ callback();
525
+ },
526
+
527
+ direction : function ($el, current, target) {
528
+ var lis = this.S('li', $el),
529
+ li_width = lis.outerWidth() + (lis.outerWidth() / 4),
530
+ up_count = Math.floor(this.S('.clearing-container').outerWidth() / li_width) - 1,
531
+ target_index = lis.index(target),
532
+ response;
533
+
534
+ this.settings.up_count = up_count;
535
+
536
+ if (this.adjacent(this.settings.prev_index, target_index)) {
537
+ if ((target_index > up_count) && target_index > this.settings.prev_index) {
538
+ response = 'right';
539
+ } else if ((target_index > up_count - 1) && target_index <= this.settings.prev_index) {
540
+ response = 'left';
541
+ } else {
542
+ response = false;
543
+ }
544
+ } else {
545
+ response = 'skip';
546
+ }
547
+
548
+ this.settings.prev_index = target_index;
549
+
550
+ return response;
551
+ },
552
+
553
+ adjacent : function (current_index, target_index) {
554
+ for (var i = target_index + 1; i >= target_index - 1; i--) {
555
+ if (i === current_index) {
556
+ return true;
557
+ }
558
+ }
559
+ return false;
560
+ },
561
+
562
+ // lock management
563
+
564
+ lock : function () {
565
+ this.settings.locked = true;
566
+ },
567
+
568
+ unlock : function () {
569
+ this.settings.locked = false;
570
+ },
571
+
572
+ locked : function () {
573
+ return this.settings.locked;
574
+ },
575
+
576
+ off : function () {
577
+ this.S(this.scope).off('.fndtn.clearing');
578
+ this.S(window).off('.fndtn.clearing');
579
+ },
580
+
581
+ reflow : function () {
582
+ this.init();
583
+ }
584
+ };
585
+
586
+ }(jQuery, window, window.document));