726 lines
		
	
	
		
			22 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
		
		
			
		
	
	
			726 lines
		
	
	
		
			22 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
| 
								 | 
							
								/*
							 | 
						||
| 
								 | 
							
								 * Foundation Responsive Library
							 | 
						||
| 
								 | 
							
								 * http://foundation.zurb.com
							 | 
						||
| 
								 | 
							
								 * Copyright 2014, ZURB
							 | 
						||
| 
								 | 
							
								 * Free to use under the MIT license.
							 | 
						||
| 
								 | 
							
								 * http://www.opensource.org/licenses/mit-license.php
							 | 
						||
| 
								 | 
							
								*/
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								(function ($, window, document, undefined) {
							 | 
						||
| 
								 | 
							
								  'use strict';
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  var header_helpers = function (class_array) {
							 | 
						||
| 
								 | 
							
								    var i = class_array.length;
							 | 
						||
| 
								 | 
							
								    var head = $('head');
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    while (i--) {
							 | 
						||
| 
								 | 
							
								      if (head.has('.' + class_array[i]).length === 0) {
							 | 
						||
| 
								 | 
							
								        head.append('<meta class="' + class_array[i] + '" />');
							 | 
						||
| 
								 | 
							
								      }
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								  };
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  header_helpers([
							 | 
						||
| 
								 | 
							
								    'foundation-mq-small',
							 | 
						||
| 
								 | 
							
								    'foundation-mq-small-only',
							 | 
						||
| 
								 | 
							
								    'foundation-mq-medium',
							 | 
						||
| 
								 | 
							
								    'foundation-mq-medium-only',
							 | 
						||
| 
								 | 
							
								    'foundation-mq-large',
							 | 
						||
| 
								 | 
							
								    'foundation-mq-large-only',
							 | 
						||
| 
								 | 
							
								    'foundation-mq-xlarge',
							 | 
						||
| 
								 | 
							
								    'foundation-mq-xlarge-only',
							 | 
						||
| 
								 | 
							
								    'foundation-mq-xxlarge',
							 | 
						||
| 
								 | 
							
								    'foundation-data-attribute-namespace']);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  // Enable FastClick if present
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  $(function () {
							 | 
						||
| 
								 | 
							
								    if (typeof FastClick !== 'undefined') {
							 | 
						||
| 
								 | 
							
								      // Don't attach to body if undefined
							 | 
						||
| 
								 | 
							
								      if (typeof document.body !== 'undefined') {
							 | 
						||
| 
								 | 
							
								        FastClick.attach(document.body);
							 | 
						||
| 
								 | 
							
								      }
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								  });
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  // private Fast Selector wrapper,
							 | 
						||
| 
								 | 
							
								  // returns jQuery object. Only use where
							 | 
						||
| 
								 | 
							
								  // getElementById is not available.
							 | 
						||
| 
								 | 
							
								  var S = function (selector, context) {
							 | 
						||
| 
								 | 
							
								    if (typeof selector === 'string') {
							 | 
						||
| 
								 | 
							
								      if (context) {
							 | 
						||
| 
								 | 
							
								        var cont;
							 | 
						||
| 
								 | 
							
								        if (context.jquery) {
							 | 
						||
| 
								 | 
							
								          cont = context[0];
							 | 
						||
| 
								 | 
							
								          if (!cont) {
							 | 
						||
| 
								 | 
							
								            return context;
							 | 
						||
| 
								 | 
							
								          }
							 | 
						||
| 
								 | 
							
								        } else {
							 | 
						||
| 
								 | 
							
								          cont = context;
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								        return $(cont.querySelectorAll(selector));
							 | 
						||
| 
								 | 
							
								      }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								      return $(document.querySelectorAll(selector));
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    return $(selector, context);
							 | 
						||
| 
								 | 
							
								  };
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  // Namespace functions.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  var attr_name = function (init) {
							 | 
						||
| 
								 | 
							
								    var arr = [];
							 | 
						||
| 
								 | 
							
								    if (!init) {
							 | 
						||
| 
								 | 
							
								      arr.push('data');
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								    if (this.namespace.length > 0) {
							 | 
						||
| 
								 | 
							
								      arr.push(this.namespace);
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								    arr.push(this.name);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    return arr.join('-');
							 | 
						||
| 
								 | 
							
								  };
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  var add_namespace = function (str) {
							 | 
						||
| 
								 | 
							
								    var parts = str.split('-'),
							 | 
						||
| 
								 | 
							
								        i = parts.length,
							 | 
						||
| 
								 | 
							
								        arr = [];
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    while (i--) {
							 | 
						||
| 
								 | 
							
								      if (i !== 0) {
							 | 
						||
| 
								 | 
							
								        arr.push(parts[i]);
							 | 
						||
| 
								 | 
							
								      } else {
							 | 
						||
| 
								 | 
							
								        if (this.namespace.length > 0) {
							 | 
						||
| 
								 | 
							
								          arr.push(this.namespace, parts[i]);
							 | 
						||
| 
								 | 
							
								        } else {
							 | 
						||
| 
								 | 
							
								          arr.push(parts[i]);
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								      }
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    return arr.reverse().join('-');
							 | 
						||
| 
								 | 
							
								  };
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  // Event binding and data-options updating.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  var bindings = function (method, options) {
							 | 
						||
| 
								 | 
							
								    var self = this,
							 | 
						||
| 
								 | 
							
								        bind = function(){
							 | 
						||
| 
								 | 
							
								          var $this = S(this),
							 | 
						||
| 
								 | 
							
								              should_bind_events = !$this.data(self.attr_name(true) + '-init');
							 | 
						||
| 
								 | 
							
								          $this.data(self.attr_name(true) + '-init', $.extend({}, self.settings, (options || method), self.data_options($this)));
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								          if (should_bind_events) {
							 | 
						||
| 
								 | 
							
								            self.events(this);
							 | 
						||
| 
								 | 
							
								          }
							 | 
						||
| 
								 | 
							
								        };
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    if (S(this.scope).is('[' + this.attr_name() +']')) {
							 | 
						||
| 
								 | 
							
								      bind.call(this.scope);
							 | 
						||
| 
								 | 
							
								    } else {
							 | 
						||
| 
								 | 
							
								      S('[' + this.attr_name() +']', this.scope).each(bind);
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								    // # Patch to fix #5043 to move this *after* the if/else clause in order for Backbone and similar frameworks to have improved control over event binding and data-options updating.
							 | 
						||
| 
								 | 
							
								    if (typeof method === 'string') {
							 | 
						||
| 
								 | 
							
								      return this[method].call(this, options);
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  };
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  var single_image_loaded = function (image, callback) {
							 | 
						||
| 
								 | 
							
								    function loaded () {
							 | 
						||
| 
								 | 
							
								      callback(image[0]);
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    function bindLoad () {
							 | 
						||
| 
								 | 
							
								      this.one('load', loaded);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								      if (/MSIE (\d+\.\d+);/.test(navigator.userAgent)) {
							 | 
						||
| 
								 | 
							
								        var src = this.attr( 'src' ),
							 | 
						||
| 
								 | 
							
								            param = src.match( /\?/ ) ? '&' : '?';
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        param += 'random=' + (new Date()).getTime();
							 | 
						||
| 
								 | 
							
								        this.attr('src', src + param);
							 | 
						||
| 
								 | 
							
								      }
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    if (!image.attr('src')) {
							 | 
						||
| 
								 | 
							
								      loaded();
							 | 
						||
| 
								 | 
							
								      return;
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    if (image[0].complete || image[0].readyState === 4) {
							 | 
						||
| 
								 | 
							
								      loaded();
							 | 
						||
| 
								 | 
							
								    } else {
							 | 
						||
| 
								 | 
							
								      bindLoad.call(image);
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								  };
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  /*! matchMedia() polyfill - Test a CSS media type/query in JS. Authors & copyright (c) 2012: Scott Jehl, Paul Irish, Nicholas Zakas, David Knight. Dual MIT/BSD license */
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  window.matchMedia || (window.matchMedia = function() {
							 | 
						||
| 
								 | 
							
								      "use strict";
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								      // For browsers that support matchMedium api such as IE 9 and webkit
							 | 
						||
| 
								 | 
							
								      var styleMedia = (window.styleMedia || window.media);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								      // For those that don't support matchMedium
							 | 
						||
| 
								 | 
							
								      if (!styleMedia) {
							 | 
						||
| 
								 | 
							
								          var style       = document.createElement('style'),
							 | 
						||
| 
								 | 
							
								              script      = document.getElementsByTagName('script')[0],
							 | 
						||
| 
								 | 
							
								              info        = null;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								          style.type  = 'text/css';
							 | 
						||
| 
								 | 
							
								          style.id    = 'matchmediajs-test';
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								          script.parentNode.insertBefore(style, script);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								          // 'style.currentStyle' is used by IE <= 8 and 'window.getComputedStyle' for all other browsers
							 | 
						||
| 
								 | 
							
								          info = ('getComputedStyle' in window) && window.getComputedStyle(style, null) || style.currentStyle;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								          styleMedia = {
							 | 
						||
| 
								 | 
							
								              matchMedium: function(media) {
							 | 
						||
| 
								 | 
							
								                  var text = '@media ' + media + '{ #matchmediajs-test { width: 1px; } }';
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								                  // 'style.styleSheet' is used by IE <= 8 and 'style.textContent' for all other browsers
							 | 
						||
| 
								 | 
							
								                  if (style.styleSheet) {
							 | 
						||
| 
								 | 
							
								                      style.styleSheet.cssText = text;
							 | 
						||
| 
								 | 
							
								                  } else {
							 | 
						||
| 
								 | 
							
								                      style.textContent = text;
							 | 
						||
| 
								 | 
							
								                  }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								                  // Test if media query is true or false
							 | 
						||
| 
								 | 
							
								                  return info.width === '1px';
							 | 
						||
| 
								 | 
							
								              }
							 | 
						||
| 
								 | 
							
								          };
							 | 
						||
| 
								 | 
							
								      }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								      return function(media) {
							 | 
						||
| 
								 | 
							
								          return {
							 | 
						||
| 
								 | 
							
								              matches: styleMedia.matchMedium(media || 'all'),
							 | 
						||
| 
								 | 
							
								              media: media || 'all'
							 | 
						||
| 
								 | 
							
								          };
							 | 
						||
| 
								 | 
							
								      };
							 | 
						||
| 
								 | 
							
								  }());
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  /*
							 | 
						||
| 
								 | 
							
								   * jquery.requestAnimationFrame
							 | 
						||
| 
								 | 
							
								   * https://github.com/gnarf37/jquery-requestAnimationFrame
							 | 
						||
| 
								 | 
							
								   * Requires jQuery 1.8+
							 | 
						||
| 
								 | 
							
								   *
							 | 
						||
| 
								 | 
							
								   * Copyright (c) 2012 Corey Frang
							 | 
						||
| 
								 | 
							
								   * Licensed under the MIT license.
							 | 
						||
| 
								 | 
							
								   */
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  (function(jQuery) {
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  // requestAnimationFrame polyfill adapted from Erik Möller
							 | 
						||
| 
								 | 
							
								  // fixes from Paul Irish and Tino Zijdel
							 | 
						||
| 
								 | 
							
								  // http://paulirish.com/2011/requestanimationframe-for-smart-animating/
							 | 
						||
| 
								 | 
							
								  // http://my.opera.com/emoller/blog/2011/12/20/requestanimationframe-for-smart-er-animating
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  var animating,
							 | 
						||
| 
								 | 
							
								      lastTime = 0,
							 | 
						||
| 
								 | 
							
								      vendors = ['webkit', 'moz'],
							 | 
						||
| 
								 | 
							
								      requestAnimationFrame = window.requestAnimationFrame,
							 | 
						||
| 
								 | 
							
								      cancelAnimationFrame = window.cancelAnimationFrame,
							 | 
						||
| 
								 | 
							
								      jqueryFxAvailable = 'undefined' !== typeof jQuery.fx;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  for (; lastTime < vendors.length && !requestAnimationFrame; lastTime++) {
							 | 
						||
| 
								 | 
							
								    requestAnimationFrame = window[ vendors[lastTime] + 'RequestAnimationFrame' ];
							 | 
						||
| 
								 | 
							
								    cancelAnimationFrame = cancelAnimationFrame ||
							 | 
						||
| 
								 | 
							
								      window[ vendors[lastTime] + 'CancelAnimationFrame' ] ||
							 | 
						||
| 
								 | 
							
								      window[ vendors[lastTime] + 'CancelRequestAnimationFrame' ];
							 | 
						||
| 
								 | 
							
								  }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  function raf() {
							 | 
						||
| 
								 | 
							
								    if (animating) {
							 | 
						||
| 
								 | 
							
								      requestAnimationFrame(raf);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								      if (jqueryFxAvailable) {
							 | 
						||
| 
								 | 
							
								        jQuery.fx.tick();
							 | 
						||
| 
								 | 
							
								      }
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								  }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  if (requestAnimationFrame) {
							 | 
						||
| 
								 | 
							
								    // use rAF
							 | 
						||
| 
								 | 
							
								    window.requestAnimationFrame = requestAnimationFrame;
							 | 
						||
| 
								 | 
							
								    window.cancelAnimationFrame = cancelAnimationFrame;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    if (jqueryFxAvailable) {
							 | 
						||
| 
								 | 
							
								      jQuery.fx.timer = function (timer) {
							 | 
						||
| 
								 | 
							
								        if (timer() && jQuery.timers.push(timer) && !animating) {
							 | 
						||
| 
								 | 
							
								          animating = true;
							 | 
						||
| 
								 | 
							
								          raf();
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								      };
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								      jQuery.fx.stop = function () {
							 | 
						||
| 
								 | 
							
								        animating = false;
							 | 
						||
| 
								 | 
							
								      };
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								  } else {
							 | 
						||
| 
								 | 
							
								    // polyfill
							 | 
						||
| 
								 | 
							
								    window.requestAnimationFrame = function (callback) {
							 | 
						||
| 
								 | 
							
								      var currTime = new Date().getTime(),
							 | 
						||
| 
								 | 
							
								        timeToCall = Math.max(0, 16 - (currTime - lastTime)),
							 | 
						||
| 
								 | 
							
								        id = window.setTimeout(function () {
							 | 
						||
| 
								 | 
							
								          callback(currTime + timeToCall);
							 | 
						||
| 
								 | 
							
								        }, timeToCall);
							 | 
						||
| 
								 | 
							
								      lastTime = currTime + timeToCall;
							 | 
						||
| 
								 | 
							
								      return id;
							 | 
						||
| 
								 | 
							
								    };
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    window.cancelAnimationFrame = function (id) {
							 | 
						||
| 
								 | 
							
								      clearTimeout(id);
							 | 
						||
| 
								 | 
							
								    };
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  }( $ ));
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  function removeQuotes (string) {
							 | 
						||
| 
								 | 
							
								    if (typeof string === 'string' || string instanceof String) {
							 | 
						||
| 
								 | 
							
								      string = string.replace(/^['\\/"]+|(;\s?})+|['\\/"]+$/g, '');
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    return string;
							 | 
						||
| 
								 | 
							
								  }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  window.Foundation = {
							 | 
						||
| 
								 | 
							
								    name : 'Foundation',
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    version : '5.5.2',
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    media_queries : {
							 | 
						||
| 
								 | 
							
								      'small'       : S('.foundation-mq-small').css('font-family').replace(/^[\/\\'"]+|(;\s?})+|[\/\\'"]+$/g, ''),
							 | 
						||
| 
								 | 
							
								      'small-only'  : S('.foundation-mq-small-only').css('font-family').replace(/^[\/\\'"]+|(;\s?})+|[\/\\'"]+$/g, ''),
							 | 
						||
| 
								 | 
							
								      'medium'      : S('.foundation-mq-medium').css('font-family').replace(/^[\/\\'"]+|(;\s?})+|[\/\\'"]+$/g, ''),
							 | 
						||
| 
								 | 
							
								      'medium-only' : S('.foundation-mq-medium-only').css('font-family').replace(/^[\/\\'"]+|(;\s?})+|[\/\\'"]+$/g, ''),
							 | 
						||
| 
								 | 
							
								      'large'       : S('.foundation-mq-large').css('font-family').replace(/^[\/\\'"]+|(;\s?})+|[\/\\'"]+$/g, ''),
							 | 
						||
| 
								 | 
							
								      'large-only'  : S('.foundation-mq-large-only').css('font-family').replace(/^[\/\\'"]+|(;\s?})+|[\/\\'"]+$/g, ''),
							 | 
						||
| 
								 | 
							
								      'xlarge'      : S('.foundation-mq-xlarge').css('font-family').replace(/^[\/\\'"]+|(;\s?})+|[\/\\'"]+$/g, ''),
							 | 
						||
| 
								 | 
							
								      'xlarge-only' : S('.foundation-mq-xlarge-only').css('font-family').replace(/^[\/\\'"]+|(;\s?})+|[\/\\'"]+$/g, ''),
							 | 
						||
| 
								 | 
							
								      'xxlarge'     : S('.foundation-mq-xxlarge').css('font-family').replace(/^[\/\\'"]+|(;\s?})+|[\/\\'"]+$/g, '')
							 | 
						||
| 
								 | 
							
								    },
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    stylesheet : $('<style></style>').appendTo('head')[0].sheet,
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    global : {
							 | 
						||
| 
								 | 
							
								      namespace : undefined
							 | 
						||
| 
								 | 
							
								    },
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    init : function (scope, libraries, method, options, response) {
							 | 
						||
| 
								 | 
							
								      var args = [scope, method, options, response],
							 | 
						||
| 
								 | 
							
								          responses = [];
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								      // check RTL
							 | 
						||
| 
								 | 
							
								      this.rtl = /rtl/i.test(S('html').attr('dir'));
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								      // set foundation global scope
							 | 
						||
| 
								 | 
							
								      this.scope = scope || this.scope;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								      this.set_namespace();
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								      if (libraries && typeof libraries === 'string' && !/reflow/i.test(libraries)) {
							 | 
						||
| 
								 | 
							
								        if (this.libs.hasOwnProperty(libraries)) {
							 | 
						||
| 
								 | 
							
								          responses.push(this.init_lib(libraries, args));
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								      } else {
							 | 
						||
| 
								 | 
							
								        for (var lib in this.libs) {
							 | 
						||
| 
								 | 
							
								          responses.push(this.init_lib(lib, libraries));
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								      }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								      S(window).load(function () {
							 | 
						||
| 
								 | 
							
								        S(window)
							 | 
						||
| 
								 | 
							
								          .trigger('resize.fndtn.clearing')
							 | 
						||
| 
								 | 
							
								          .trigger('resize.fndtn.dropdown')
							 | 
						||
| 
								 | 
							
								          .trigger('resize.fndtn.equalizer')
							 | 
						||
| 
								 | 
							
								          .trigger('resize.fndtn.interchange')
							 | 
						||
| 
								 | 
							
								          .trigger('resize.fndtn.joyride')
							 | 
						||
| 
								 | 
							
								          .trigger('resize.fndtn.magellan')
							 | 
						||
| 
								 | 
							
								          .trigger('resize.fndtn.topbar')
							 | 
						||
| 
								 | 
							
								          .trigger('resize.fndtn.slider');
							 | 
						||
| 
								 | 
							
								      });
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								      return scope;
							 | 
						||
| 
								 | 
							
								    },
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    init_lib : function (lib, args) {
							 | 
						||
| 
								 | 
							
								      if (this.libs.hasOwnProperty(lib)) {
							 | 
						||
| 
								 | 
							
								        this.patch(this.libs[lib]);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        if (args && args.hasOwnProperty(lib)) {
							 | 
						||
| 
								 | 
							
								            if (typeof this.libs[lib].settings !== 'undefined') {
							 | 
						||
| 
								 | 
							
								              $.extend(true, this.libs[lib].settings, args[lib]);
							 | 
						||
| 
								 | 
							
								            } else if (typeof this.libs[lib].defaults !== 'undefined') {
							 | 
						||
| 
								 | 
							
								              $.extend(true, this.libs[lib].defaults, args[lib]);
							 | 
						||
| 
								 | 
							
								            }
							 | 
						||
| 
								 | 
							
								          return this.libs[lib].init.apply(this.libs[lib], [this.scope, args[lib]]);
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        args = args instanceof Array ? args : new Array(args);
							 | 
						||
| 
								 | 
							
								        return this.libs[lib].init.apply(this.libs[lib], args);
							 | 
						||
| 
								 | 
							
								      }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								      return function () {};
							 | 
						||
| 
								 | 
							
								    },
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    patch : function (lib) {
							 | 
						||
| 
								 | 
							
								      lib.scope = this.scope;
							 | 
						||
| 
								 | 
							
								      lib.namespace = this.global.namespace;
							 | 
						||
| 
								 | 
							
								      lib.rtl = this.rtl;
							 | 
						||
| 
								 | 
							
								      lib['data_options'] = this.utils.data_options;
							 | 
						||
| 
								 | 
							
								      lib['attr_name'] = attr_name;
							 | 
						||
| 
								 | 
							
								      lib['add_namespace'] = add_namespace;
							 | 
						||
| 
								 | 
							
								      lib['bindings'] = bindings;
							 | 
						||
| 
								 | 
							
								      lib['S'] = this.utils.S;
							 | 
						||
| 
								 | 
							
								    },
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    inherit : function (scope, methods) {
							 | 
						||
| 
								 | 
							
								      var methods_arr = methods.split(' '),
							 | 
						||
| 
								 | 
							
								          i = methods_arr.length;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								      while (i--) {
							 | 
						||
| 
								 | 
							
								        if (this.utils.hasOwnProperty(methods_arr[i])) {
							 | 
						||
| 
								 | 
							
								          scope[methods_arr[i]] = this.utils[methods_arr[i]];
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								      }
							 | 
						||
| 
								 | 
							
								    },
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    set_namespace : function () {
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								      // Description:
							 | 
						||
| 
								 | 
							
								      //    Don't bother reading the namespace out of the meta tag
							 | 
						||
| 
								 | 
							
								      //    if the namespace has been set globally in javascript
							 | 
						||
| 
								 | 
							
								      //
							 | 
						||
| 
								 | 
							
								      // Example:
							 | 
						||
| 
								 | 
							
								      //    Foundation.global.namespace = 'my-namespace';
							 | 
						||
| 
								 | 
							
								      // or make it an empty string:
							 | 
						||
| 
								 | 
							
								      //    Foundation.global.namespace = '';
							 | 
						||
| 
								 | 
							
								      //
							 | 
						||
| 
								 | 
							
								      //
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								      // If the namespace has not been set (is undefined), try to read it out of the meta element.
							 | 
						||
| 
								 | 
							
								      // Otherwise use the globally defined namespace, even if it's empty ('')
							 | 
						||
| 
								 | 
							
								      var namespace = ( this.global.namespace === undefined ) ? $('.foundation-data-attribute-namespace').css('font-family') : this.global.namespace;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								      // Finally, if the namsepace is either undefined or false, set it to an empty string.
							 | 
						||
| 
								 | 
							
								      // Otherwise use the namespace value.
							 | 
						||
| 
								 | 
							
								      this.global.namespace = ( namespace === undefined || /false/i.test(namespace) ) ? '' : namespace;
							 | 
						||
| 
								 | 
							
								    },
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    libs : {},
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    // methods that can be inherited in libraries
							 | 
						||
| 
								 | 
							
								    utils : {
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								      // Description:
							 | 
						||
| 
								 | 
							
								      //    Fast Selector wrapper returns jQuery object. Only use where getElementById
							 | 
						||
| 
								 | 
							
								      //    is not available.
							 | 
						||
| 
								 | 
							
								      //
							 | 
						||
| 
								 | 
							
								      // Arguments:
							 | 
						||
| 
								 | 
							
								      //    Selector (String): CSS selector describing the element(s) to be
							 | 
						||
| 
								 | 
							
								      //    returned as a jQuery object.
							 | 
						||
| 
								 | 
							
								      //
							 | 
						||
| 
								 | 
							
								      //    Scope (String): CSS selector describing the area to be searched. Default
							 | 
						||
| 
								 | 
							
								      //    is document.
							 | 
						||
| 
								 | 
							
								      //
							 | 
						||
| 
								 | 
							
								      // Returns:
							 | 
						||
| 
								 | 
							
								      //    Element (jQuery Object): jQuery object containing elements matching the
							 | 
						||
| 
								 | 
							
								      //    selector within the scope.
							 | 
						||
| 
								 | 
							
								      S : S,
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								      // Description:
							 | 
						||
| 
								 | 
							
								      //    Executes a function a max of once every n milliseconds
							 | 
						||
| 
								 | 
							
								      //
							 | 
						||
| 
								 | 
							
								      // Arguments:
							 | 
						||
| 
								 | 
							
								      //    Func (Function): Function to be throttled.
							 | 
						||
| 
								 | 
							
								      //
							 | 
						||
| 
								 | 
							
								      //    Delay (Integer): Function execution threshold in milliseconds.
							 | 
						||
| 
								 | 
							
								      //
							 | 
						||
| 
								 | 
							
								      // Returns:
							 | 
						||
| 
								 | 
							
								      //    Lazy_function (Function): Function with throttling applied.
							 | 
						||
| 
								 | 
							
								      throttle : function (func, delay) {
							 | 
						||
| 
								 | 
							
								        var timer = null;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        return function () {
							 | 
						||
| 
								 | 
							
								          var context = this, args = arguments;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								          if (timer == null) {
							 | 
						||
| 
								 | 
							
								            timer = setTimeout(function () {
							 | 
						||
| 
								 | 
							
								              func.apply(context, args);
							 | 
						||
| 
								 | 
							
								              timer = null;
							 | 
						||
| 
								 | 
							
								            }, delay);
							 | 
						||
| 
								 | 
							
								          }
							 | 
						||
| 
								 | 
							
								        };
							 | 
						||
| 
								 | 
							
								      },
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								      // Description:
							 | 
						||
| 
								 | 
							
								      //    Executes a function when it stops being invoked for n seconds
							 | 
						||
| 
								 | 
							
								      //    Modified version of _.debounce() http://underscorejs.org
							 | 
						||
| 
								 | 
							
								      //
							 | 
						||
| 
								 | 
							
								      // Arguments:
							 | 
						||
| 
								 | 
							
								      //    Func (Function): Function to be debounced.
							 | 
						||
| 
								 | 
							
								      //
							 | 
						||
| 
								 | 
							
								      //    Delay (Integer): Function execution threshold in milliseconds.
							 | 
						||
| 
								 | 
							
								      //
							 | 
						||
| 
								 | 
							
								      //    Immediate (Bool): Whether the function should be called at the beginning
							 | 
						||
| 
								 | 
							
								      //    of the delay instead of the end. Default is false.
							 | 
						||
| 
								 | 
							
								      //
							 | 
						||
| 
								 | 
							
								      // Returns:
							 | 
						||
| 
								 | 
							
								      //    Lazy_function (Function): Function with debouncing applied.
							 | 
						||
| 
								 | 
							
								      debounce : function (func, delay, immediate) {
							 | 
						||
| 
								 | 
							
								        var timeout, result;
							 | 
						||
| 
								 | 
							
								        return function () {
							 | 
						||
| 
								 | 
							
								          var context = this, args = arguments;
							 | 
						||
| 
								 | 
							
								          var later = function () {
							 | 
						||
| 
								 | 
							
								            timeout = null;
							 | 
						||
| 
								 | 
							
								            if (!immediate) {
							 | 
						||
| 
								 | 
							
								              result = func.apply(context, args);
							 | 
						||
| 
								 | 
							
								            }
							 | 
						||
| 
								 | 
							
								          };
							 | 
						||
| 
								 | 
							
								          var callNow = immediate && !timeout;
							 | 
						||
| 
								 | 
							
								          clearTimeout(timeout);
							 | 
						||
| 
								 | 
							
								          timeout = setTimeout(later, delay);
							 | 
						||
| 
								 | 
							
								          if (callNow) {
							 | 
						||
| 
								 | 
							
								            result = func.apply(context, args);
							 | 
						||
| 
								 | 
							
								          }
							 | 
						||
| 
								 | 
							
								          return result;
							 | 
						||
| 
								 | 
							
								        };
							 | 
						||
| 
								 | 
							
								      },
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								      // Description:
							 | 
						||
| 
								 | 
							
								      //    Parses data-options attribute
							 | 
						||
| 
								 | 
							
								      //
							 | 
						||
| 
								 | 
							
								      // Arguments:
							 | 
						||
| 
								 | 
							
								      //    El (jQuery Object): Element to be parsed.
							 | 
						||
| 
								 | 
							
								      //
							 | 
						||
| 
								 | 
							
								      // Returns:
							 | 
						||
| 
								 | 
							
								      //    Options (Javascript Object): Contents of the element's data-options
							 | 
						||
| 
								 | 
							
								      //    attribute.
							 | 
						||
| 
								 | 
							
								      data_options : function (el, data_attr_name) {
							 | 
						||
| 
								 | 
							
								        data_attr_name = data_attr_name || 'options';
							 | 
						||
| 
								 | 
							
								        var opts = {}, ii, p, opts_arr,
							 | 
						||
| 
								 | 
							
								            data_options = function (el) {
							 | 
						||
| 
								 | 
							
								              var namespace = Foundation.global.namespace;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								              if (namespace.length > 0) {
							 | 
						||
| 
								 | 
							
								                return el.data(namespace + '-' + data_attr_name);
							 | 
						||
| 
								 | 
							
								              }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								              return el.data(data_attr_name);
							 | 
						||
| 
								 | 
							
								            };
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        var cached_options = data_options(el);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        if (typeof cached_options === 'object') {
							 | 
						||
| 
								 | 
							
								          return cached_options;
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        opts_arr = (cached_options || ':').split(';');
							 | 
						||
| 
								 | 
							
								        ii = opts_arr.length;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        function isNumber (o) {
							 | 
						||
| 
								 | 
							
								          return !isNaN (o - 0) && o !== null && o !== '' && o !== false && o !== true;
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        function trim (str) {
							 | 
						||
| 
								 | 
							
								          if (typeof str === 'string') {
							 | 
						||
| 
								 | 
							
								            return $.trim(str);
							 | 
						||
| 
								 | 
							
								          }
							 | 
						||
| 
								 | 
							
								          return str;
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        while (ii--) {
							 | 
						||
| 
								 | 
							
								          p = opts_arr[ii].split(':');
							 | 
						||
| 
								 | 
							
								          p = [p[0], p.slice(1).join(':')];
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								          if (/true/i.test(p[1])) {
							 | 
						||
| 
								 | 
							
								            p[1] = true;
							 | 
						||
| 
								 | 
							
								          }
							 | 
						||
| 
								 | 
							
								          if (/false/i.test(p[1])) {
							 | 
						||
| 
								 | 
							
								            p[1] = false;
							 | 
						||
| 
								 | 
							
								          }
							 | 
						||
| 
								 | 
							
								          if (isNumber(p[1])) {
							 | 
						||
| 
								 | 
							
								            if (p[1].indexOf('.') === -1) {
							 | 
						||
| 
								 | 
							
								              p[1] = parseInt(p[1], 10);
							 | 
						||
| 
								 | 
							
								            } else {
							 | 
						||
| 
								 | 
							
								              p[1] = parseFloat(p[1]);
							 | 
						||
| 
								 | 
							
								            }
							 | 
						||
| 
								 | 
							
								          }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								          if (p.length === 2 && p[0].length > 0) {
							 | 
						||
| 
								 | 
							
								            opts[trim(p[0])] = trim(p[1]);
							 | 
						||
| 
								 | 
							
								          }
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        return opts;
							 | 
						||
| 
								 | 
							
								      },
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								      // Description:
							 | 
						||
| 
								 | 
							
								      //    Adds JS-recognizable media queries
							 | 
						||
| 
								 | 
							
								      //
							 | 
						||
| 
								 | 
							
								      // Arguments:
							 | 
						||
| 
								 | 
							
								      //    Media (String): Key string for the media query to be stored as in
							 | 
						||
| 
								 | 
							
								      //    Foundation.media_queries
							 | 
						||
| 
								 | 
							
								      //
							 | 
						||
| 
								 | 
							
								      //    Class (String): Class name for the generated <meta> tag
							 | 
						||
| 
								 | 
							
								      register_media : function (media, media_class) {
							 | 
						||
| 
								 | 
							
								        if (Foundation.media_queries[media] === undefined) {
							 | 
						||
| 
								 | 
							
								          $('head').append('<meta class="' + media_class + '"/>');
							 | 
						||
| 
								 | 
							
								          Foundation.media_queries[media] = removeQuotes($('.' + media_class).css('font-family'));
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								      },
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								      // Description:
							 | 
						||
| 
								 | 
							
								      //    Add custom CSS within a JS-defined media query
							 | 
						||
| 
								 | 
							
								      //
							 | 
						||
| 
								 | 
							
								      // Arguments:
							 | 
						||
| 
								 | 
							
								      //    Rule (String): CSS rule to be appended to the document.
							 | 
						||
| 
								 | 
							
								      //
							 | 
						||
| 
								 | 
							
								      //    Media (String): Optional media query string for the CSS rule to be
							 | 
						||
| 
								 | 
							
								      //    nested under.
							 | 
						||
| 
								 | 
							
								      add_custom_rule : function (rule, media) {
							 | 
						||
| 
								 | 
							
								        if (media === undefined && Foundation.stylesheet) {
							 | 
						||
| 
								 | 
							
								          Foundation.stylesheet.insertRule(rule, Foundation.stylesheet.cssRules.length);
							 | 
						||
| 
								 | 
							
								        } else {
							 | 
						||
| 
								 | 
							
								          var query = Foundation.media_queries[media];
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								          if (query !== undefined) {
							 | 
						||
| 
								 | 
							
								            Foundation.stylesheet.insertRule('@media ' +
							 | 
						||
| 
								 | 
							
								              Foundation.media_queries[media] + '{ ' + rule + ' }', Foundation.stylesheet.cssRules.length);
							 | 
						||
| 
								 | 
							
								          }
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								      },
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								      // Description:
							 | 
						||
| 
								 | 
							
								      //    Performs a callback function when an image is fully loaded
							 | 
						||
| 
								 | 
							
								      //
							 | 
						||
| 
								 | 
							
								      // Arguments:
							 | 
						||
| 
								 | 
							
								      //    Image (jQuery Object): Image(s) to check if loaded.
							 | 
						||
| 
								 | 
							
								      //
							 | 
						||
| 
								 | 
							
								      //    Callback (Function): Function to execute when image is fully loaded.
							 | 
						||
| 
								 | 
							
								      image_loaded : function (images, callback) {
							 | 
						||
| 
								 | 
							
								        var self = this,
							 | 
						||
| 
								 | 
							
								            unloaded = images.length;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        function pictures_has_height(images) {
							 | 
						||
| 
								 | 
							
								          var pictures_number = images.length;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								          for (var i = pictures_number - 1; i >= 0; i--) {
							 | 
						||
| 
								 | 
							
								            if(images.attr('height') === undefined) {
							 | 
						||
| 
								 | 
							
								              return false;
							 | 
						||
| 
								 | 
							
								            };
							 | 
						||
| 
								 | 
							
								          };
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								          return true;
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        if (unloaded === 0 || pictures_has_height(images)) {
							 | 
						||
| 
								 | 
							
								          callback(images);
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        images.each(function () {
							 | 
						||
| 
								 | 
							
								          single_image_loaded(self.S(this), function () {
							 | 
						||
| 
								 | 
							
								            unloaded -= 1;
							 | 
						||
| 
								 | 
							
								            if (unloaded === 0) {
							 | 
						||
| 
								 | 
							
								              callback(images);
							 | 
						||
| 
								 | 
							
								            }
							 | 
						||
| 
								 | 
							
								          });
							 | 
						||
| 
								 | 
							
								        });
							 | 
						||
| 
								 | 
							
								      },
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								      // Description:
							 | 
						||
| 
								 | 
							
								      //    Returns a random, alphanumeric string
							 | 
						||
| 
								 | 
							
								      //
							 | 
						||
| 
								 | 
							
								      // Arguments:
							 | 
						||
| 
								 | 
							
								      //    Length (Integer): Length of string to be generated. Defaults to random
							 | 
						||
| 
								 | 
							
								      //    integer.
							 | 
						||
| 
								 | 
							
								      //
							 | 
						||
| 
								 | 
							
								      // Returns:
							 | 
						||
| 
								 | 
							
								      //    Rand (String): Pseudo-random, alphanumeric string.
							 | 
						||
| 
								 | 
							
								      random_str : function () {
							 | 
						||
| 
								 | 
							
								        if (!this.fidx) {
							 | 
						||
| 
								 | 
							
								          this.fidx = 0;
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								        this.prefix = this.prefix || [(this.name || 'F'), (+new Date).toString(36)].join('-');
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        return this.prefix + (this.fidx++).toString(36);
							 | 
						||
| 
								 | 
							
								      },
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								      // Description:
							 | 
						||
| 
								 | 
							
								      //    Helper for window.matchMedia
							 | 
						||
| 
								 | 
							
								      //
							 | 
						||
| 
								 | 
							
								      // Arguments:
							 | 
						||
| 
								 | 
							
								      //    mq (String): Media query
							 | 
						||
| 
								 | 
							
								      //
							 | 
						||
| 
								 | 
							
								      // Returns:
							 | 
						||
| 
								 | 
							
								      //    (Boolean): Whether the media query passes or not
							 | 
						||
| 
								 | 
							
								      match : function (mq) {
							 | 
						||
| 
								 | 
							
								        return window.matchMedia(mq).matches;
							 | 
						||
| 
								 | 
							
								      },
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								      // Description:
							 | 
						||
| 
								 | 
							
								      //    Helpers for checking Foundation default media queries with JS
							 | 
						||
| 
								 | 
							
								      //
							 | 
						||
| 
								 | 
							
								      // Returns:
							 | 
						||
| 
								 | 
							
								      //    (Boolean): Whether the media query passes or not
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								      is_small_up : function () {
							 | 
						||
| 
								 | 
							
								        return this.match(Foundation.media_queries.small);
							 | 
						||
| 
								 | 
							
								      },
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								      is_medium_up : function () {
							 | 
						||
| 
								 | 
							
								        return this.match(Foundation.media_queries.medium);
							 | 
						||
| 
								 | 
							
								      },
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								      is_large_up : function () {
							 | 
						||
| 
								 | 
							
								        return this.match(Foundation.media_queries.large);
							 | 
						||
| 
								 | 
							
								      },
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								      is_xlarge_up : function () {
							 | 
						||
| 
								 | 
							
								        return this.match(Foundation.media_queries.xlarge);
							 | 
						||
| 
								 | 
							
								      },
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								      is_xxlarge_up : function () {
							 | 
						||
| 
								 | 
							
								        return this.match(Foundation.media_queries.xxlarge);
							 | 
						||
| 
								 | 
							
								      },
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								      is_small_only : function () {
							 | 
						||
| 
								 | 
							
								        return !this.is_medium_up() && !this.is_large_up() && !this.is_xlarge_up() && !this.is_xxlarge_up();
							 | 
						||
| 
								 | 
							
								      },
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								      is_medium_only : function () {
							 | 
						||
| 
								 | 
							
								        return this.is_medium_up() && !this.is_large_up() && !this.is_xlarge_up() && !this.is_xxlarge_up();
							 | 
						||
| 
								 | 
							
								      },
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								      is_large_only : function () {
							 | 
						||
| 
								 | 
							
								        return this.is_medium_up() && this.is_large_up() && !this.is_xlarge_up() && !this.is_xxlarge_up();
							 | 
						||
| 
								 | 
							
								      },
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								      is_xlarge_only : function () {
							 | 
						||
| 
								 | 
							
								        return this.is_medium_up() && this.is_large_up() && this.is_xlarge_up() && !this.is_xxlarge_up();
							 | 
						||
| 
								 | 
							
								      },
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								      is_xxlarge_only : function () {
							 | 
						||
| 
								 | 
							
								        return this.is_medium_up() && this.is_large_up() && this.is_xlarge_up() && this.is_xxlarge_up();
							 | 
						||
| 
								 | 
							
								      }
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								  };
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  $.fn.foundation = function () {
							 | 
						||
| 
								 | 
							
								    var args = Array.prototype.slice.call(arguments, 0);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    return this.each(function () {
							 | 
						||
| 
								 | 
							
								      Foundation.init.apply(Foundation, [this].concat(args));
							 | 
						||
| 
								 | 
							
								      return this;
							 | 
						||
| 
								 | 
							
								    });
							 | 
						||
| 
								 | 
							
								  };
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								}(jQuery, window, window.document));
							 |