Template:Team:Berkeley/scrollspy

From 2013.igem.org

(Difference between revisions)
(Created page with "<html> <script type="text/javascript"> /* ============================================================= * bootstrap-scrollspy.js v2.0.4 * http://twitter.github.com/bootstrap/j...")
Line 2: Line 2:
<script type="text/javascript">
<script type="text/javascript">
 +
/* ========================================================================
 +
* Bootstrap: scrollspy.js v3.0.0
 +
* http://twbs.github.com/bootstrap/javascript.html#scrollspy
 +
* ========================================================================
 +
* Copyright 2012 Twitter, Inc.
 +
*
 +
* Licensed under the Apache License, Version 2.0 (the "License");
 +
* you may not use this file except in compliance with the License.
 +
* You may obtain a copy of the License at
 +
*
 +
* http://www.apache.org/licenses/LICENSE-2.0
 +
*
 +
* Unless required by applicable law or agreed to in writing, software
 +
* distributed under the License is distributed on an "AS IS" BASIS,
 +
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 +
* See the License for the specific language governing permissions and
 +
* limitations under the License.
 +
* ======================================================================== */
 +
 +
 +
+function ($) { "use strict";
 +
 +
  // SCROLLSPY CLASS DEFINITION
 +
  // ==========================
 +
 +
  function ScrollSpy(element, options) {
 +
    var href
 +
    var process  = $.proxy(this.process, this)
 +
 +
    this.$element      = $(element).is('body') ? $(window) : $(element)
 +
    this.$body          = $('body')
 +
    this.$scrollElement = this.$element.on('scroll.bs.scroll-spy.data-api', process)
 +
    this.options        = $.extend({}, ScrollSpy.DEFAULTS, options)
 +
    this.selector      = (this.options.target
 +
      || ((href = $(element).attr('href')) && href.replace(/.*(?=#[^\s]+$)/, '')) //strip for ie7
 +
      || '') + ' .nav li > a'
 +
    this.offsets        = $([])
 +
    this.targets        = $([])
 +
    this.activeTarget  = null
 +
 +
    this.refresh()
 +
    this.process()
 +
  }
 +
 +
  ScrollSpy.DEFAULTS = {
 +
    offset: 10
 +
  }
 +
 +
  ScrollSpy.prototype.refresh = function () {
 +
    var offsetMethod = this.$element[0] == window ? 'offset' : 'position'
 +
 +
    this.offsets = $([])
 +
    this.targets = $([])
 +
 +
    var self    = this
 +
    var $targets = this.$body
 +
      .find(this.selector)
 +
      .map(function () {
 +
        var $el  = $(this)
 +
        var href  = $el.data('target') || $el.attr('href')
 +
        var $href = /^#\w/.test(href) && $(href)
 +
 +
        return ($href
 +
          && $href.length
 +
          && [[ $href[offsetMethod]().top + (!$.isWindow(self.$scrollElement.get(0)) && self.$scrollElement.scrollTop()), href ]]) || null
 +
      })
 +
      .sort(function (a, b) { return a[0] - b[0] })
 +
      .each(function () {
 +
        self.offsets.push(this[0])
 +
        self.targets.push(this[1])
 +
      })
 +
  }
 +
 +
  ScrollSpy.prototype.process = function () {
 +
    var scrollTop    = this.$scrollElement.scrollTop() + this.options.offset
 +
    var scrollHeight = this.$scrollElement[0].scrollHeight || this.$body[0].scrollHeight
 +
    var maxScroll    = scrollHeight - this.$scrollElement.height()
 +
    var offsets      = this.offsets
 +
    var targets      = this.targets
 +
    var activeTarget = this.activeTarget
 +
    var i
 +
 +
    if (scrollTop >= maxScroll) {
 +
      return activeTarget != (i = targets.last()[0]) && this.activate(i)
 +
    }
 +
 +
    for (i = offsets.length; i--;) {
 +
      activeTarget != targets[i]
 +
        && scrollTop >= offsets[i]
 +
        && (!offsets[i + 1] || scrollTop <= offsets[i + 1])
 +
        && this.activate( targets[i] )
 +
    }
 +
  }
 +
 +
  ScrollSpy.prototype.activate = function (target) {
 +
    this.activeTarget = target
 +
 +
    $(this.selector)
 +
      .parents('.active')
 +
      .removeClass('active')
 +
 +
    var selector = this.selector
 +
      + '[data-target="' + target + '"],'
 +
      + this.selector + '[href="' + target + '"]'
 +
 +
    var active = $(selector)
 +
      .parents('li')
 +
      .addClass('active')
 +
 +
    if (active.parent('.dropdown-menu').length)  {
 +
      active = active
 +
        .closest('li.dropdown')
 +
        .addClass('active')
 +
    }
 +
 +
    active.trigger('activate')
 +
  }
 +
 +
 +
  // SCROLLSPY PLUGIN DEFINITION
 +
  // ===========================
 +
 +
  var old = $.fn.scrollspy
 +
 +
  $.fn.scrollspy = function (option) {
 +
    return this.each(function () {
 +
      var $this  = $(this)
 +
      var data    = $this.data('bs.scrollspy')
 +
      var options = typeof option == 'object' && option
 +
 +
      if (!data) $this.data('bs.scrollspy', (data = new ScrollSpy(this, options)))
 +
      if (typeof option == 'string') data[option]()
 +
    })
 +
  }
 +
 +
  $.fn.scrollspy.Constructor = ScrollSpy
 +
 +
 +
  // SCROLLSPY NO CONFLICT
 +
  // =====================
 +
 +
  $.fn.scrollspy.noConflict = function () {
 +
    $.fn.scrollspy = old
 +
    return this
 +
  }
 +
 +
 +
  // SCROLLSPY DATA-API
 +
  // ==================
 +
 +
  $(window).on('load', function () {
 +
    $('[data-spy="scroll"]').each(function () {
 +
      var $spy = $(this)
 +
      $spy.scrollspy($spy.data())
 +
    })
 +
  })
 +
 +
}(window.jQuery);
 +
 +
/* =============================================================
/* =============================================================
  * bootstrap-scrollspy.js v2.0.4
  * bootstrap-scrollspy.js v2.0.4

Revision as of 00:55, 22 October 2013