Mercurial > wikked
comparison static/bootstrap/js/bootstrap-affix.js @ 61:130eccd396d8
Now using Boostrap with LESS.
| author | Ludovic Chabant <ludovic@chabant.com> |
|---|---|
| date | Wed, 06 Feb 2013 08:22:31 -0800 |
| parents | |
| children | a5a3d454eac9 |
comparison
equal
deleted
inserted
replaced
| 60:8250c977bc50 | 61:130eccd396d8 |
|---|---|
| 1 /* ========================================================== | |
| 2 * bootstrap-affix.js v2.2.2 | |
| 3 * http://twitter.github.com/bootstrap/javascript.html#affix | |
| 4 * ========================================================== | |
| 5 * Copyright 2012 Twitter, Inc. | |
| 6 * | |
| 7 * Licensed under the Apache License, Version 2.0 (the "License"); | |
| 8 * you may not use this file except in compliance with the License. | |
| 9 * You may obtain a copy of the License at | |
| 10 * | |
| 11 * http://www.apache.org/licenses/LICENSE-2.0 | |
| 12 * | |
| 13 * Unless required by applicable law or agreed to in writing, software | |
| 14 * distributed under the License is distributed on an "AS IS" BASIS, | |
| 15 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | |
| 16 * See the License for the specific language governing permissions and | |
| 17 * limitations under the License. | |
| 18 * ========================================================== */ | |
| 19 | |
| 20 | |
| 21 !function ($) { | |
| 22 | |
| 23 "use strict"; // jshint ;_; | |
| 24 | |
| 25 | |
| 26 /* AFFIX CLASS DEFINITION | |
| 27 * ====================== */ | |
| 28 | |
| 29 var Affix = function (element, options) { | |
| 30 this.options = $.extend({}, $.fn.affix.defaults, options) | |
| 31 this.$window = $(window) | |
| 32 .on('scroll.affix.data-api', $.proxy(this.checkPosition, this)) | |
| 33 .on('click.affix.data-api', $.proxy(function () { setTimeout($.proxy(this.checkPosition, this), 1) }, this)) | |
| 34 this.$element = $(element) | |
| 35 this.checkPosition() | |
| 36 } | |
| 37 | |
| 38 Affix.prototype.checkPosition = function () { | |
| 39 if (!this.$element.is(':visible')) return | |
| 40 | |
| 41 var scrollHeight = $(document).height() | |
| 42 , scrollTop = this.$window.scrollTop() | |
| 43 , position = this.$element.offset() | |
| 44 , offset = this.options.offset | |
| 45 , offsetBottom = offset.bottom | |
| 46 , offsetTop = offset.top | |
| 47 , reset = 'affix affix-top affix-bottom' | |
| 48 , affix | |
| 49 | |
| 50 if (typeof offset != 'object') offsetBottom = offsetTop = offset | |
| 51 if (typeof offsetTop == 'function') offsetTop = offset.top() | |
| 52 if (typeof offsetBottom == 'function') offsetBottom = offset.bottom() | |
| 53 | |
| 54 affix = this.unpin != null && (scrollTop + this.unpin <= position.top) ? | |
| 55 false : offsetBottom != null && (position.top + this.$element.height() >= scrollHeight - offsetBottom) ? | |
| 56 'bottom' : offsetTop != null && scrollTop <= offsetTop ? | |
| 57 'top' : false | |
| 58 | |
| 59 if (this.affixed === affix) return | |
| 60 | |
| 61 this.affixed = affix | |
| 62 this.unpin = affix == 'bottom' ? position.top - scrollTop : null | |
| 63 | |
| 64 this.$element.removeClass(reset).addClass('affix' + (affix ? '-' + affix : '')) | |
| 65 } | |
| 66 | |
| 67 | |
| 68 /* AFFIX PLUGIN DEFINITION | |
| 69 * ======================= */ | |
| 70 | |
| 71 var old = $.fn.affix | |
| 72 | |
| 73 $.fn.affix = function (option) { | |
| 74 return this.each(function () { | |
| 75 var $this = $(this) | |
| 76 , data = $this.data('affix') | |
| 77 , options = typeof option == 'object' && option | |
| 78 if (!data) $this.data('affix', (data = new Affix(this, options))) | |
| 79 if (typeof option == 'string') data[option]() | |
| 80 }) | |
| 81 } | |
| 82 | |
| 83 $.fn.affix.Constructor = Affix | |
| 84 | |
| 85 $.fn.affix.defaults = { | |
| 86 offset: 0 | |
| 87 } | |
| 88 | |
| 89 | |
| 90 /* AFFIX NO CONFLICT | |
| 91 * ================= */ | |
| 92 | |
| 93 $.fn.affix.noConflict = function () { | |
| 94 $.fn.affix = old | |
| 95 return this | |
| 96 } | |
| 97 | |
| 98 | |
| 99 /* AFFIX DATA-API | |
| 100 * ============== */ | |
| 101 | |
| 102 $(window).on('load', function () { | |
| 103 $('[data-spy="affix"]').each(function () { | |
| 104 var $spy = $(this) | |
| 105 , data = $spy.data() | |
| 106 | |
| 107 data.offset = data.offset || {} | |
| 108 | |
| 109 data.offsetBottom && (data.offset.bottom = data.offsetBottom) | |
| 110 data.offsetTop && (data.offset.top = data.offsetTop) | |
| 111 | |
| 112 $spy.affix(data) | |
| 113 }) | |
| 114 }) | |
| 115 | |
| 116 | |
| 117 }(window.jQuery); |
