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

Jacob Thornton's avatar
Jacob Thornton committed
20
21
22

!function ( $ ) {

23
24
  function ScrollSpy() {
    var process = $.proxy(this.process, this)
25
26
27
28
29
    this.selector = '.nav li > a'

    this.$body = $('body').delegate(this.selector, 'click', process)
    this.$scrollElement = $('[data-spy="scroll"]').bind('scroll', process)

30
    this.refresh()
31
    this.process()
Jacob Thornton's avatar
Jacob Thornton committed
32
33
34
35
  }

  ScrollSpy.prototype = {

36
      refresh: function () {
37
38
39
40
41
42
        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
43
44

        this.offsets = $.map(this.targets, function (id) {
45
          return $(id).position().top
Jacob Thornton's avatar
Jacob Thornton committed
46
47
48
        })
      }

49
    , process: function () {
50
        var scrollTop = this.$scrollElement.scrollTop() + 10
Jacob Thornton's avatar
Jacob Thornton committed
51
52
53
54
55
56
57
58
59
          , 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])
60
            && this.activate( targets[i] )
Jacob Thornton's avatar
Jacob Thornton committed
61
62
63
        }
      }

64
65
66
    , activate: function (target) {
        var active

Jacob Thornton's avatar
Jacob Thornton committed
67
68
        this.activeTarget = target

69
        this.$body
70
          .find(this.selector).parent('.active')
Jacob Thornton's avatar
Jacob Thornton committed
71
72
          .removeClass('active')

73
        active = this.$body
74
          .find(this.selector + '[href="' + target + '"]')
Jacob Thornton's avatar
Jacob Thornton committed
75
76
          .parent('li')
          .addClass('active')
77
78
79
80
81

        if ( active.parent('.dropdown-menu') )  {
          active.closest('li.dropdown').addClass('active')
        }

Jacob Thornton's avatar
Jacob Thornton committed
82
83
84
85
      }

  }

86
  $(function () { new ScrollSpy() })
87

88
}( window.jQuery || window.ender )