bootstrap-scrollspy.js 3.58 KB
Newer Older
Jacob Thornton's avatar
Jacob Thornton committed
1
/* =============================================================
Jacob Thornton's avatar
Jacob Thornton committed
2
 * bootstrap-scrollspy.js v2.0.2
Jacob Thornton's avatar
Jacob Thornton committed
3
4
 * http://twitter.github.com/bootstrap/javascript.html#scrollspy
 * =============================================================
Mark Otto's avatar
Mark Otto committed
5
 * Copyright 2012 Twitter, Inc.
Jacob Thornton's avatar
Jacob Thornton committed
6
7
8
9
10
11
12
13
14
15
16
17
 *
 * 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.
Jacob Thornton's avatar
Jacob Thornton committed
18
19
 * ============================================================== */

Jacob Thornton's avatar
Jacob Thornton committed
20
21
!function ( $ ) {

22
23
24
25
26
  "use strict"

  /* SCROLLSPY CLASS DEFINITION
   * ========================== */

27
  function ScrollSpy( element, options) {
28
    var process = $.proxy(this.process, this)
29
      , $element = $(element).is('body') ? $(window) : $(element)
Jacob Thornton's avatar
Jacob Thornton committed
30
      , href
31
    this.options = $.extend({}, $.fn.scrollspy.defaults, options)
32
33
    this.$scrollElement = $element.on('scroll.scroll.data-api', process)
    this.selector = (this.options.target
Jacob Thornton's avatar
Jacob Thornton committed
34
      || ((href = $(element).attr('href')) && href.replace(/.*(?=#[^\s]+$)/, '')) //strip for ie7
35
      || '') + ' .nav li > a'
36
    this.$body = $('body').on('click.scroll.data-api', this.selector, process)
37
    this.refresh()
38
    this.process()
Jacob Thornton's avatar
Jacob Thornton committed
39
40
41
42
  }

  ScrollSpy.prototype = {

43
44
45
      constructor: ScrollSpy

    , refresh: function () {
46
47
48
49
50
51
        this.targets = this.$body
          .find(this.selector)
          .map(function () {
            var href = $(this).attr('href')
            return /^#\w/.test(href) && $(href).length ? href : null
          })
Jacob Thornton's avatar
Jacob Thornton committed
52
53

        this.offsets = $.map(this.targets, function (id) {
54
          return $(id).position().top
Jacob Thornton's avatar
Jacob Thornton committed
55
56
57
        })
      }

58
    , process: function () {
59
        var scrollTop = this.$scrollElement.scrollTop() + this.options.offset
Jacob Thornton's avatar
Jacob Thornton committed
60
61
62
63
64
65
66
67
68
          , offsets = this.offsets
          , targets = this.targets
          , activeTarget = this.activeTarget
          , i

        for (i = offsets.length; i--;) {
          activeTarget != targets[i]
            && scrollTop >= offsets[i]
            && (!offsets[i + 1] || scrollTop <= offsets[i + 1])
69
            && this.activate( targets[i] )
Jacob Thornton's avatar
Jacob Thornton committed
70
71
72
        }
      }

73
74
75
    , activate: function (target) {
        var active

Jacob Thornton's avatar
Jacob Thornton committed
76
77
        this.activeTarget = target

78
        this.$body
79
          .find(this.selector).parent('.active')
Jacob Thornton's avatar
Jacob Thornton committed
80
81
          .removeClass('active')

82
        active = this.$body
83
          .find(this.selector + '[href="' + target + '"]')
Jacob Thornton's avatar
Jacob Thornton committed
84
85
          .parent('li')
          .addClass('active')
86
87
88
89

        if ( active.parent('.dropdown-menu') )  {
          active.closest('li.dropdown').addClass('active')
        }
Jacob Thornton's avatar
Jacob Thornton committed
90
91
92
93
      }

  }

94
95
96
97
98
99
100
101

 /* SCROLLSPY PLUGIN DEFINITION
  * =========================== */

  $.fn.scrollspy = function ( option ) {
    return this.each(function () {
      var $this = $(this)
        , data = $this.data('scrollspy')
102
103
        , options = typeof option == 'object' && option
      if (!data) $this.data('scrollspy', (data = new ScrollSpy(this, options)))
104
105
106
107
      if (typeof option == 'string') data[option]()
    })
  }

108
  $.fn.scrollspy.Constructor = ScrollSpy
109

110
111
112
113
  $.fn.scrollspy.defaults = {
    offset: 10
  }

114
115

 /* SCROLLSPY DATA-API
116
  * ================== */
117

118
  $(function () {
119
120
121
122
    $('[data-spy="scroll"]').each(function () {
      var $spy = $(this)
      $spy.scrollspy($spy.data())
    })
123
  })
124

125
}( window.jQuery );