bootstrap.js 59.4 KB
Newer Older
1
/*!
Mark Otto's avatar
Mark Otto committed
2
 * Bootstrap v3.2.0 (http://getbootstrap.com)
3
 * Copyright 2011-2014 Twitter, Inc.
Mark Otto's avatar
Mark Otto committed
4
 * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
Chris Rebert's avatar
Chris Rebert committed
5
 */
6

7
if (typeof jQuery === 'undefined') { throw new Error('Bootstrap\'s JavaScript requires jQuery') }
8

9
/* ========================================================================
Mark Otto's avatar
Mark Otto committed
10
 * Bootstrap: transition.js v3.2.0
Mark Otto's avatar
Mark Otto committed
11
 * http://getbootstrap.com/javascript/#transitions
12
 * ========================================================================
13
 * Copyright 2011-2014 Twitter, Inc.
14
 * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
15
 * ======================================================================== */
16
17


XhmikosR's avatar
XhmikosR committed
18
19
+function ($) {
  'use strict';
Mark Otto's avatar
grunt    
Mark Otto committed
20

XhmikosR's avatar
XhmikosR committed
21
22
  // CSS TRANSITION SUPPORT (Shoutout: http://www.modernizr.com/)
  // ============================================================
23

XhmikosR's avatar
XhmikosR committed
24
25
  function transitionEnd() {
    var el = document.createElement('bootstrap')
26

XhmikosR's avatar
XhmikosR committed
27
28
29
30
31
32
    var transEndEventNames = {
      WebkitTransition : 'webkitTransitionEnd',
      MozTransition    : 'transitionend',
      OTransition      : 'oTransitionEnd otransitionend',
      transition       : 'transitionend'
    }
33

XhmikosR's avatar
XhmikosR committed
34
35
36
    for (var name in transEndEventNames) {
      if (el.style[name] !== undefined) {
        return { end: transEndEventNames[name] }
37
      }
Chris Rebert's avatar
Chris Rebert committed
38
39
    }

XhmikosR's avatar
XhmikosR committed
40
41
    return false // explicit for ie8 (  ._.)
  }
42

XhmikosR's avatar
XhmikosR committed
43
44
45
46
47
48
49
50
51
  // http://blog.alexmaccaw.com/css-transitions
  $.fn.emulateTransitionEnd = function (duration) {
    var called = false
    var $el = this
    $(this).one('bsTransitionEnd', function () { called = true })
    var callback = function () { if (!called) $($el).trigger($.support.transition.end) }
    setTimeout(callback, duration)
    return this
  }
52

XhmikosR's avatar
XhmikosR committed
53
54
  $(function () {
    $.support.transition = transitionEnd()
Chris Rebert's avatar
Chris Rebert committed
55

XhmikosR's avatar
XhmikosR committed
56
    if (!$.support.transition) return
57

XhmikosR's avatar
XhmikosR committed
58
59
60
61
62
63
64
    $.event.special.bsTransitionEnd = {
      bindType: $.support.transition.end,
      delegateType: $.support.transition.end,
      handle: function (e) {
        if ($(e.target).is(this)) return e.handleObj.handler.apply(this, arguments)
      }
    }
fat's avatar
fat committed
65
  })
66

XhmikosR's avatar
XhmikosR committed
67
}(jQuery);
68

69
/* ========================================================================
Mark Otto's avatar
Mark Otto committed
70
 * Bootstrap: alert.js v3.2.0
Mark Otto's avatar
Mark Otto committed
71
 * http://getbootstrap.com/javascript/#alerts
72
 * ========================================================================
73
 * Copyright 2011-2014 Twitter, Inc.
74
 * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
75
 * ======================================================================== */
76
77


XhmikosR's avatar
XhmikosR committed
78
79
+function ($) {
  'use strict';
80

XhmikosR's avatar
XhmikosR committed
81
82
  // ALERT CLASS DEFINITION
  // ======================
83

XhmikosR's avatar
XhmikosR committed
84
85
86
87
  var dismiss = '[data-dismiss="alert"]'
  var Alert   = function (el) {
    $(el).on('click', dismiss, this.close)
  }
Mark Otto's avatar
grunt    
Mark Otto committed
88

Mark Otto's avatar
Mark Otto committed
89
  Alert.VERSION = '3.2.0'
90

XhmikosR's avatar
XhmikosR committed
91
92
93
  Alert.prototype.close = function (e) {
    var $this    = $(this)
    var selector = $this.attr('data-target')
94

XhmikosR's avatar
XhmikosR committed
95
96
97
98
    if (!selector) {
      selector = $this.attr('href')
      selector = selector && selector.replace(/.*(?=#[^\s]*$)/, '') // strip for ie7
    }
99

XhmikosR's avatar
XhmikosR committed
100
    var $parent = $(selector)
101

XhmikosR's avatar
XhmikosR committed
102
    if (e) e.preventDefault()
103

XhmikosR's avatar
XhmikosR committed
104
105
106
    if (!$parent.length) {
      $parent = $this.hasClass('alert') ? $this : $this.parent()
    }
107

XhmikosR's avatar
XhmikosR committed
108
    $parent.trigger(e = $.Event('close.bs.alert'))
Chris Rebert's avatar
Chris Rebert committed
109

XhmikosR's avatar
XhmikosR committed
110
    if (e.isDefaultPrevented()) return
111

XhmikosR's avatar
XhmikosR committed
112
    $parent.removeClass('in')
113

XhmikosR's avatar
XhmikosR committed
114
115
116
    function removeElement() {
      // detach from parent, fire event then clean up data
      $parent.detach().trigger('closed.bs.alert').remove()
117
118
    }

XhmikosR's avatar
XhmikosR committed
119
120
121
122
123
124
    $.support.transition && $parent.hasClass('fade') ?
      $parent
        .one('bsTransitionEnd', removeElement)
        .emulateTransitionEnd(150) :
      removeElement()
  }
125
126


XhmikosR's avatar
XhmikosR committed
127
128
  // ALERT PLUGIN DEFINITION
  // =======================
129

XhmikosR's avatar
XhmikosR committed
130
131
132
133
  function Plugin(option) {
    return this.each(function () {
      var $this = $(this)
      var data  = $this.data('bs.alert')
fat's avatar
fat committed
134

XhmikosR's avatar
XhmikosR committed
135
136
137
138
      if (!data) $this.data('bs.alert', (data = new Alert(this)))
      if (typeof option == 'string') data[option].call($this)
    })
  }
139

XhmikosR's avatar
XhmikosR committed
140
  var old = $.fn.alert
Mark Otto's avatar
Mark Otto committed
141

XhmikosR's avatar
XhmikosR committed
142
143
  $.fn.alert             = Plugin
  $.fn.alert.Constructor = Alert
144
145


XhmikosR's avatar
XhmikosR committed
146
147
  // ALERT NO CONFLICT
  // =================
148

XhmikosR's avatar
XhmikosR committed
149
150
151
152
  $.fn.alert.noConflict = function () {
    $.fn.alert = old
    return this
  }
153
154


XhmikosR's avatar
XhmikosR committed
155
156
  // ALERT DATA-API
  // ==============
157

XhmikosR's avatar
XhmikosR committed
158
  $(document).on('click.bs.alert.data-api', dismiss, Alert.prototype.close)
159

XhmikosR's avatar
XhmikosR committed
160
}(jQuery);
161

162
/* ========================================================================
Mark Otto's avatar
Mark Otto committed
163
 * Bootstrap: button.js v3.2.0
Mark Otto's avatar
Mark Otto committed
164
 * http://getbootstrap.com/javascript/#buttons
165
 * ========================================================================
166
 * Copyright 2011-2014 Twitter, Inc.
167
 * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
168
 * ======================================================================== */
169
170


XhmikosR's avatar
XhmikosR committed
171
172
+function ($) {
  'use strict';
fat's avatar
fat committed
173

XhmikosR's avatar
XhmikosR committed
174
175
  // BUTTON PUBLIC CLASS DEFINITION
  // ==============================
Mark Otto's avatar
grunt    
Mark Otto committed
176

XhmikosR's avatar
XhmikosR committed
177
178
179
180
181
  var Button = function (element, options) {
    this.$element  = $(element)
    this.options   = $.extend({}, Button.DEFAULTS, options)
    this.isLoading = false
  }
182

Mark Otto's avatar
Mark Otto committed
183
  Button.VERSION  = '3.2.0'
184

XhmikosR's avatar
XhmikosR committed
185
186
187
  Button.DEFAULTS = {
    loadingText: 'loading...'
  }
fat's avatar
fat committed
188

XhmikosR's avatar
XhmikosR committed
189
190
191
192
193
  Button.prototype.setState = function (state) {
    var d    = 'disabled'
    var $el  = this.$element
    var val  = $el.is('input') ? 'val' : 'html'
    var data = $el.data()
194

XhmikosR's avatar
XhmikosR committed
195
    state = state + 'Text'
196

XhmikosR's avatar
XhmikosR committed
197
    if (data.resetText == null) $el.data('resetText', $el[val]())
Chris Rebert's avatar
Chris Rebert committed
198

XhmikosR's avatar
XhmikosR committed
199
    $el[val](data[state] == null ? this.options[state] : data[state])
Chris Rebert's avatar
Chris Rebert committed
200

XhmikosR's avatar
XhmikosR committed
201
202
203
204
205
206
207
208
    // push to event loop to allow forms to submit
    setTimeout($.proxy(function () {
      if (state == 'loadingText') {
        this.isLoading = true
        $el.addClass(d).attr(d, d)
      } else if (this.isLoading) {
        this.isLoading = false
        $el.removeClass(d).removeAttr(d)
209
      }
XhmikosR's avatar
XhmikosR committed
210
211
212
213
214
215
216
217
218
219
220
221
222
223
    }, this), 0)
  }

  Button.prototype.toggle = function () {
    var changed = true
    var $parent = this.$element.closest('[data-toggle="buttons"]')

    if ($parent.length) {
      var $input = this.$element.find('input')
      if ($input.prop('type') == 'radio') {
        if ($input.prop('checked') && this.$element.hasClass('active')) changed = false
        else $parent.find('.active').removeClass('active')
      }
      if (changed) $input.prop('checked', !this.$element.hasClass('active')).trigger('change')
fat's avatar
fat committed
224
    }
225

XhmikosR's avatar
XhmikosR committed
226
227
    if (changed) this.$element.toggleClass('active')
  }
228
229


XhmikosR's avatar
XhmikosR committed
230
231
  // BUTTON PLUGIN DEFINITION
  // ========================
232

XhmikosR's avatar
XhmikosR committed
233
234
235
236
237
  function Plugin(option) {
    return this.each(function () {
      var $this   = $(this)
      var data    = $this.data('bs.button')
      var options = typeof option == 'object' && option
fat's avatar
fat committed
238

XhmikosR's avatar
XhmikosR committed
239
      if (!data) $this.data('bs.button', (data = new Button(this, options)))
fat's avatar
fat committed
240

XhmikosR's avatar
XhmikosR committed
241
242
243
244
      if (option == 'toggle') data.toggle()
      else if (option) data.setState(option)
    })
  }
245

XhmikosR's avatar
XhmikosR committed
246
  var old = $.fn.button
Mark Otto's avatar
Mark Otto committed
247

XhmikosR's avatar
XhmikosR committed
248
249
  $.fn.button             = Plugin
  $.fn.button.Constructor = Button
250
251


XhmikosR's avatar
XhmikosR committed
252
253
  // BUTTON NO CONFLICT
  // ==================
254

XhmikosR's avatar
XhmikosR committed
255
256
257
258
  $.fn.button.noConflict = function () {
    $.fn.button = old
    return this
  }
259
260


XhmikosR's avatar
XhmikosR committed
261
262
  // BUTTON DATA-API
  // ===============
263

XhmikosR's avatar
XhmikosR committed
264
265
266
267
268
  $(document).on('click.bs.button.data-api', '[data-toggle^="button"]', function (e) {
    var $btn = $(e.target)
    if (!$btn.hasClass('btn')) $btn = $btn.closest('.btn')
    Plugin.call($btn, 'toggle')
    e.preventDefault()
269
270
  })

XhmikosR's avatar
XhmikosR committed
271
}(jQuery);
272

273
/* ========================================================================
Mark Otto's avatar
Mark Otto committed
274
 * Bootstrap: carousel.js v3.2.0
Mark Otto's avatar
Mark Otto committed
275
 * http://getbootstrap.com/javascript/#carousel
276
 * ========================================================================
277
 * Copyright 2011-2014 Twitter, Inc.
278
 * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
279
 * ======================================================================== */
280
281


XhmikosR's avatar
XhmikosR committed
282
283
+function ($) {
  'use strict';
284

XhmikosR's avatar
XhmikosR committed
285
286
  // CAROUSEL CLASS DEFINITION
  // =========================
287

XhmikosR's avatar
XhmikosR committed
288
289
290
291
292
293
294
295
296
  var Carousel = function (element, options) {
    this.$element    = $(element).on('keydown.bs.carousel', $.proxy(this.keydown, this))
    this.$indicators = this.$element.find('.carousel-indicators')
    this.options     = options
    this.paused      =
    this.sliding     =
    this.interval    =
    this.$active     =
    this.$items      = null
fat's avatar
fat committed
297

XhmikosR's avatar
XhmikosR committed
298
299
300
301
    this.options.pause == 'hover' && this.$element
      .on('mouseenter.bs.carousel', $.proxy(this.pause, this))
      .on('mouseleave.bs.carousel', $.proxy(this.cycle, this))
  }
302

Mark Otto's avatar
Mark Otto committed
303
  Carousel.VERSION  = '3.2.0'
Mark Otto's avatar
grunt    
Mark Otto committed
304

XhmikosR's avatar
XhmikosR committed
305
306
307
308
309
  Carousel.DEFAULTS = {
    interval: 5000,
    pause: 'hover',
    wrap: true
  }
310

XhmikosR's avatar
XhmikosR committed
311
312
313
314
315
  Carousel.prototype.keydown = function (e) {
    switch (e.which) {
      case 37: this.prev(); break
      case 39: this.next(); break
      default: return
Mark Otto's avatar
Mark Otto committed
316
317
    }

XhmikosR's avatar
XhmikosR committed
318
319
    e.preventDefault()
  }
320

XhmikosR's avatar
XhmikosR committed
321
322
  Carousel.prototype.cycle = function (e) {
    e || (this.paused = false)
fat's avatar
fat committed
323

XhmikosR's avatar
XhmikosR committed
324
    this.interval && clearInterval(this.interval)
325

XhmikosR's avatar
XhmikosR committed
326
327
328
    this.options.interval
      && !this.paused
      && (this.interval = setInterval($.proxy(this.next, this), this.options.interval))
329

XhmikosR's avatar
XhmikosR committed
330
331
    return this
  }
332

XhmikosR's avatar
XhmikosR committed
333
334
335
336
  Carousel.prototype.getItemIndex = function (item) {
    this.$items = item.parent().children('.item')
    return this.$items.index(item || this.$active)
  }
337

XhmikosR's avatar
XhmikosR committed
338
339
340
  Carousel.prototype.to = function (pos) {
    var that        = this
    var activeIndex = this.getItemIndex(this.$active = this.$element.find('.item.active'))
341

XhmikosR's avatar
XhmikosR committed
342
    if (pos > (this.$items.length - 1) || pos < 0) return
fat's avatar
fat committed
343

XhmikosR's avatar
XhmikosR committed
344
345
    if (this.sliding)       return this.$element.one('slid.bs.carousel', function () { that.to(pos) }) // yes, "slid"
    if (activeIndex == pos) return this.pause().cycle()
346

XhmikosR's avatar
XhmikosR committed
347
348
    return this.slide(pos > activeIndex ? 'next' : 'prev', $(this.$items[pos]))
  }
fat's avatar
fat committed
349

XhmikosR's avatar
XhmikosR committed
350
351
352
353
354
355
  Carousel.prototype.pause = function (e) {
    e || (this.paused = true)

    if (this.$element.find('.next, .prev').length && $.support.transition) {
      this.$element.trigger($.support.transition.end)
      this.cycle(true)
356
357
    }

XhmikosR's avatar
XhmikosR committed
358
    this.interval = clearInterval(this.interval)
359

XhmikosR's avatar
XhmikosR committed
360
361
    return this
  }
362

XhmikosR's avatar
XhmikosR committed
363
364
365
366
  Carousel.prototype.next = function () {
    if (this.sliding) return
    return this.slide('next')
  }
367

XhmikosR's avatar
XhmikosR committed
368
369
370
371
  Carousel.prototype.prev = function () {
    if (this.sliding) return
    return this.slide('prev')
  }
372

XhmikosR's avatar
XhmikosR committed
373
374
375
376
377
378
379
  Carousel.prototype.slide = function (type, next) {
    var $active   = this.$element.find('.item.active')
    var $next     = next || $active[type]()
    var isCycling = this.interval
    var direction = type == 'next' ? 'left' : 'right'
    var fallback  = type == 'next' ? 'first' : 'last'
    var that      = this
Jacob Thornton's avatar
Jacob Thornton committed
380

XhmikosR's avatar
XhmikosR committed
381
382
383
    if (!$next.length) {
      if (!this.options.wrap) return
      $next = this.$element.find('.item')[fallback]()
Jacob Thornton's avatar
Jacob Thornton committed
384
385
    }

XhmikosR's avatar
XhmikosR committed
386
    if ($next.hasClass('active')) return (this.sliding = false)
387

XhmikosR's avatar
XhmikosR committed
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
    var relatedTarget = $next[0]
    var slideEvent = $.Event('slide.bs.carousel', {
      relatedTarget: relatedTarget,
      direction: direction
    })
    this.$element.trigger(slideEvent)
    if (slideEvent.isDefaultPrevented()) return

    this.sliding = true

    isCycling && this.pause()

    if (this.$indicators.length) {
      this.$indicators.find('.active').removeClass('active')
      var $nextIndicator = $(this.$indicators.children()[this.getItemIndex($next)])
      $nextIndicator && $nextIndicator.addClass('active')
    }

    var slidEvent = $.Event('slid.bs.carousel', { relatedTarget: relatedTarget, direction: direction }) // yes, "slid"
    if ($.support.transition && this.$element.hasClass('slide')) {
      $next.addClass(type)
      $next[0].offsetWidth // force reflow
      $active.addClass(direction)
      $next.addClass(direction)
      $active
        .one('bsTransitionEnd', function () {
          $next.removeClass([type, direction].join(' ')).addClass('active')
          $active.removeClass(['active', direction].join(' '))
          that.sliding = false
          setTimeout(function () {
            that.$element.trigger(slidEvent)
          }, 0)
        })
        .emulateTransitionEnd($active.css('transition-duration').slice(0, -1) * 1000)
    } else {
      $active.removeClass('active')
      $next.addClass('active')
      this.sliding = false
      this.$element.trigger(slidEvent)
    }
fat's avatar
fat committed
428

XhmikosR's avatar
XhmikosR committed
429
    isCycling && this.cycle()
430

XhmikosR's avatar
XhmikosR committed
431
432
    return this
  }
433
434


XhmikosR's avatar
XhmikosR committed
435
436
  // CAROUSEL PLUGIN DEFINITION
  // ==========================
Chris Rebert's avatar
Chris Rebert committed
437

XhmikosR's avatar
XhmikosR committed
438
439
440
441
442
443
444
445
446
447
448
449
450
  function Plugin(option) {
    return this.each(function () {
      var $this   = $(this)
      var data    = $this.data('bs.carousel')
      var options = $.extend({}, Carousel.DEFAULTS, $this.data(), typeof option == 'object' && option)
      var action  = typeof option == 'string' ? option : options.slide

      if (!data) $this.data('bs.carousel', (data = new Carousel(this, options)))
      if (typeof option == 'number') data.to(option)
      else if (action) data[action]()
      else if (options.interval) data.pause().cycle()
    })
  }
451

XhmikosR's avatar
XhmikosR committed
452
  var old = $.fn.carousel
Mark Otto's avatar
Mark Otto committed
453

XhmikosR's avatar
XhmikosR committed
454
455
  $.fn.carousel             = Plugin
  $.fn.carousel.Constructor = Carousel
456
457


XhmikosR's avatar
XhmikosR committed
458
459
  // CAROUSEL NO CONFLICT
  // ====================
460

XhmikosR's avatar
XhmikosR committed
461
462
463
464
  $.fn.carousel.noConflict = function () {
    $.fn.carousel = old
    return this
  }
465

fat's avatar
fat committed
466

XhmikosR's avatar
XhmikosR committed
467
468
  // CAROUSEL DATA-API
  // =================
469

XhmikosR's avatar
XhmikosR committed
470
471
472
473
474
475
476
477
  $(document).on('click.bs.carousel.data-api', '[data-slide], [data-slide-to]', function (e) {
    var href
    var $this   = $(this)
    var $target = $($this.attr('data-target') || (href = $this.attr('href')) && href.replace(/.*(?=#[^\s]+$)/, '')) // strip for ie7
    if (!$target.hasClass('carousel')) return
    var options = $.extend({}, $target.data(), $this.data())
    var slideIndex = $this.attr('data-slide-to')
    if (slideIndex) options.interval = false
478

XhmikosR's avatar
XhmikosR committed
479
    Plugin.call($target, options)
480

XhmikosR's avatar
XhmikosR committed
481
482
    if (slideIndex) {
      $target.data('bs.carousel').to(slideIndex)
483
484
    }

XhmikosR's avatar
XhmikosR committed
485
486
    e.preventDefault()
  })
487

XhmikosR's avatar
XhmikosR committed
488
489
490
491
  $(window).on('load', function () {
    $('[data-ride="carousel"]').each(function () {
      var $carousel = $(this)
      Plugin.call($carousel, $carousel.data())
fat's avatar
fat committed
492
493
494
    })
  })

XhmikosR's avatar
XhmikosR committed
495
}(jQuery);
496

497
/* ========================================================================
Mark Otto's avatar
Mark Otto committed
498
 * Bootstrap: collapse.js v3.2.0
Mark Otto's avatar
Mark Otto committed
499
 * http://getbootstrap.com/javascript/#collapse
500
 * ========================================================================
501
 * Copyright 2011-2014 Twitter, Inc.
502
 * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
503
 * ======================================================================== */
504
505


XhmikosR's avatar
XhmikosR committed
506
507
+function ($) {
  'use strict';
508

XhmikosR's avatar
XhmikosR committed
509
510
  // COLLAPSE PUBLIC CLASS DEFINITION
  // ================================
Mark Otto's avatar
grunt    
Mark Otto committed
511

XhmikosR's avatar
XhmikosR committed
512
513
514
515
  var Collapse = function (element, options) {
    this.$element      = $(element)
    this.options       = $.extend({}, Collapse.DEFAULTS, options)
    this.transitioning = null
516

XhmikosR's avatar
XhmikosR committed
517
518
519
    if (this.options.parent) this.$parent = $(this.options.parent)
    if (this.options.toggle) this.toggle()
  }
520

Mark Otto's avatar
Mark Otto committed
521
  Collapse.VERSION  = '3.2.0'
522

XhmikosR's avatar
XhmikosR committed
523
524
525
  Collapse.DEFAULTS = {
    toggle: true
  }
fat's avatar
fat committed
526

XhmikosR's avatar
XhmikosR committed
527
528
529
530
  Collapse.prototype.dimension = function () {
    var hasWidth = this.$element.hasClass('width')
    return hasWidth ? 'width' : 'height'
  }
531

XhmikosR's avatar
XhmikosR committed
532
533
  Collapse.prototype.show = function () {
    if (this.transitioning || this.$element.hasClass('in')) return
534

XhmikosR's avatar
XhmikosR committed
535
536
537
    var startEvent = $.Event('show.bs.collapse')
    this.$element.trigger(startEvent)
    if (startEvent.isDefaultPrevented()) return
538

XhmikosR's avatar
XhmikosR committed
539
    var actives = this.$parent && this.$parent.find('> .panel > .in')
540

XhmikosR's avatar
XhmikosR committed
541
542
543
544
545
546
    if (actives && actives.length) {
      var hasData = actives.data('bs.collapse')
      if (hasData && hasData.transitioning) return
      Plugin.call(actives, 'hide')
      hasData || actives.data('bs.collapse', null)
    }
547

XhmikosR's avatar
XhmikosR committed
548
    var dimension = this.dimension()
549

XhmikosR's avatar
XhmikosR committed
550
551
552
    this.$element
      .removeClass('collapse')
      .addClass('collapsing')[dimension](0)
553

XhmikosR's avatar
XhmikosR committed
554
    this.transitioning = 1
555

XhmikosR's avatar
XhmikosR committed
556
557
558
559
560
    var complete = function () {
      this.$element
        .removeClass('collapsing')
        .addClass('collapse in')[dimension]('')
      this.transitioning = 0
Chris Rebert's avatar
Chris Rebert committed
561
      this.$element
XhmikosR's avatar
XhmikosR committed
562
        .trigger('shown.bs.collapse')
Chris Rebert's avatar
Chris Rebert committed
563
    }
564

XhmikosR's avatar
XhmikosR committed
565
    if (!$.support.transition) return complete.call(this)
fat's avatar
fat committed
566

XhmikosR's avatar
XhmikosR committed
567
    var scrollSize = $.camelCase(['scroll', dimension].join('-'))
fat's avatar
fat committed
568

XhmikosR's avatar
XhmikosR committed
569
570
571
572
    this.$element
      .one('bsTransitionEnd', $.proxy(complete, this))
      .emulateTransitionEnd(350)[dimension](this.$element[0][scrollSize])
  }
573

XhmikosR's avatar
XhmikosR committed
574
575
  Collapse.prototype.hide = function () {
    if (this.transitioning || !this.$element.hasClass('in')) return
576

XhmikosR's avatar
XhmikosR committed
577
578
579
    var startEvent = $.Event('hide.bs.collapse')
    this.$element.trigger(startEvent)
    if (startEvent.isDefaultPrevented()) return
580

XhmikosR's avatar
XhmikosR committed
581
    var dimension = this.dimension()
582

XhmikosR's avatar
XhmikosR committed
583
584
585
586
587
588
    this.$element[dimension](this.$element[dimension]())[0].offsetHeight

    this.$element
      .addClass('collapsing')
      .removeClass('collapse')
      .removeClass('in')
589

XhmikosR's avatar
XhmikosR committed
590
    this.transitioning = 1
591

XhmikosR's avatar
XhmikosR committed
592
593
    var complete = function () {
      this.transitioning = 0
Chris Rebert's avatar
Chris Rebert committed
594
      this.$element
XhmikosR's avatar
XhmikosR committed
595
596
597
        .trigger('hidden.bs.collapse')
        .removeClass('collapsing')
        .addClass('collapse')
Chris Rebert's avatar
Chris Rebert committed
598
    }
599

XhmikosR's avatar
XhmikosR committed
600
    if (!$.support.transition) return complete.call(this)
601

XhmikosR's avatar
XhmikosR committed
602
603
604
605
606
    this.$element
      [dimension](0)
      .one('bsTransitionEnd', $.proxy(complete, this))
      .emulateTransitionEnd(350)
  }
607

XhmikosR's avatar
XhmikosR committed
608
609
610
  Collapse.prototype.toggle = function () {
    this[this.$element.hasClass('in') ? 'hide' : 'show']()
  }
611

612

XhmikosR's avatar
XhmikosR committed
613
614
  // COLLAPSE PLUGIN DEFINITION
  // ==========================
615

XhmikosR's avatar
XhmikosR committed
616
617
618
619
620
  function Plugin(option) {
    return this.each(function () {
      var $this   = $(this)
      var data    = $this.data('bs.collapse')
      var options = $.extend({}, Collapse.DEFAULTS, $this.data(), typeof option == 'object' && option)
Mark Otto's avatar
Mark Otto committed
621

XhmikosR's avatar
XhmikosR committed
622
623
624
625
626
      if (!data && options.toggle && option == 'show') option = !option
      if (!data) $this.data('bs.collapse', (data = new Collapse(this, options)))
      if (typeof option == 'string') data[option]()
    })
  }
627

XhmikosR's avatar
XhmikosR committed
628
  var old = $.fn.collapse
629

XhmikosR's avatar
XhmikosR committed
630
631
  $.fn.collapse             = Plugin
  $.fn.collapse.Constructor = Collapse
632

633

XhmikosR's avatar
XhmikosR committed
634
635
  // COLLAPSE NO CONFLICT
  // ====================
636

XhmikosR's avatar
XhmikosR committed
637
638
639
640
  $.fn.collapse.noConflict = function () {
    $.fn.collapse = old
    return this
  }
641

642

XhmikosR's avatar
XhmikosR committed
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
  // COLLAPSE DATA-API
  // =================

  $(document).on('click.bs.collapse.data-api', '[data-toggle="collapse"]', function (e) {
    var href
    var $this   = $(this)
    var target  = $this.attr('data-target')
        || e.preventDefault()
        || (href = $this.attr('href')) && href.replace(/.*(?=#[^\s]+$)/, '') // strip for ie7
    var $target = $(target)
    var data    = $target.data('bs.collapse')
    var option  = data ? 'toggle' : $this.data()
    var parent  = $this.attr('data-parent')
    var $parent = parent && $(parent)

    if (!data || !data.transitioning) {
      if ($parent) $parent.find('[data-toggle="collapse"][data-parent="' + parent + '"]').not($this).addClass('collapsed')
      $this[$target.hasClass('in') ? 'addClass' : 'removeClass']('collapsed')
    }
fat's avatar
fat committed
662

XhmikosR's avatar
XhmikosR committed
663
    Plugin.call($target, option)
664
665
  })

XhmikosR's avatar
XhmikosR committed
666
}(jQuery);
667

668
/* ========================================================================
Mark Otto's avatar
Mark Otto committed
669
 * Bootstrap: dropdown.js v3.2.0
Mark Otto's avatar
Mark Otto committed
670
 * http://getbootstrap.com/javascript/#dropdowns
671
 * ========================================================================
672
 * Copyright 2011-2014 Twitter, Inc.
673
 * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
674
 * ======================================================================== */
675
676


XhmikosR's avatar
XhmikosR committed
677
678
+function ($) {
  'use strict';
Chris Rebert's avatar
Chris Rebert committed
679

XhmikosR's avatar
XhmikosR committed
680
681
  // DROPDOWN CLASS DEFINITION
  // =========================
Mark Otto's avatar
grunt    
Mark Otto committed
682

XhmikosR's avatar
XhmikosR committed
683
684
685
686
687
  var backdrop = '.dropdown-backdrop'
  var toggle   = '[data-toggle="dropdown"]'
  var Dropdown = function (element) {
    $(element).on('click.bs.dropdown', this.toggle)
  }
688

Mark Otto's avatar
Mark Otto committed
689
  Dropdown.VERSION = '3.2.0'
Mark Otto's avatar
grunt    
Mark Otto committed
690

XhmikosR's avatar
XhmikosR committed
691
692
  Dropdown.prototype.toggle = function (e) {
    var $this = $(this)
693

XhmikosR's avatar
XhmikosR committed
694
    if ($this.is('.disabled, :disabled')) return
695

XhmikosR's avatar
XhmikosR committed
696
697
    var $parent  = getParent($this)
    var isActive = $parent.hasClass('open')
698

XhmikosR's avatar
XhmikosR committed
699
    clearMenus()
fat's avatar
fat committed
700

XhmikosR's avatar
XhmikosR committed
701
702
703
704
705
    if (!isActive) {
      if ('ontouchstart' in document.documentElement && !$parent.closest('.navbar-nav').length) {
        // if mobile we use a backdrop because click events don't delegate
        $('<div class="dropdown-backdrop"/>').insertAfter($(this)).on('click', clearMenus)
      }
706

XhmikosR's avatar
XhmikosR committed
707
708
      var relatedTarget = { relatedTarget: this }
      $parent.trigger(e = $.Event('show.bs.dropdown', relatedTarget))
709

XhmikosR's avatar
XhmikosR committed
710
      if (e.isDefaultPrevented()) return
711

XhmikosR's avatar
XhmikosR committed
712
      $this.trigger('focus')
Mark Otto's avatar
Mark Otto committed
713

XhmikosR's avatar
XhmikosR committed
714
715
716
      $parent
        .toggleClass('open')
        .trigger('shown.bs.dropdown', relatedTarget)
fat's avatar
rebuild    
fat committed
717
    }
718

XhmikosR's avatar
XhmikosR committed
719
720
    return false
  }
721

XhmikosR's avatar
XhmikosR committed
722
723
  Dropdown.prototype.keydown = function (e) {
    if (!/(38|40|27)/.test(e.keyCode)) return
724

XhmikosR's avatar
XhmikosR committed
725
    var $this = $(this)
726

XhmikosR's avatar
XhmikosR committed
727
728
    e.preventDefault()
    e.stopPropagation()
729

XhmikosR's avatar
XhmikosR committed
730
    if ($this.is('.disabled, :disabled')) return
731

XhmikosR's avatar
XhmikosR committed
732
733
    var $parent  = getParent($this)
    var isActive = $parent.hasClass('open')
734

XhmikosR's avatar
XhmikosR committed
735
736
737
738
    if (!isActive || (isActive && e.keyCode == 27)) {
      if (e.which == 27) $parent.find(toggle).trigger('focus')
      return $this.trigger('click')
    }
739

XhmikosR's avatar
XhmikosR committed
740
741
    var desc = ' li:not(.divider):visible a'
    var $items = $parent.find('[role="menu"]' + desc + ', [role="listbox"]' + desc)
742

XhmikosR's avatar
XhmikosR committed
743
    if (!$items.length) return
744

XhmikosR's avatar
XhmikosR committed
745
    var index = $items.index($items.filter(':focus'))
746

XhmikosR's avatar
XhmikosR committed
747
748
749
    if (e.keyCode == 38 && index > 0)                 index--                        // up
    if (e.keyCode == 40 && index < $items.length - 1) index++                        // down
    if (!~index)                                      index = 0
750

XhmikosR's avatar
XhmikosR committed
751
752
    $items.eq(index).trigger('focus')
  }
Chris Rebert's avatar
Chris Rebert committed
753

XhmikosR's avatar
XhmikosR committed
754
755
756
757
758
759
760
761
762
763
764
765
  function clearMenus(e) {
    if (e && e.which === 3) return
    $(backdrop).remove()
    $(toggle).each(function () {
      var $parent = getParent($(this))
      var relatedTarget = { relatedTarget: this }
      if (!$parent.hasClass('open')) return
      $parent.trigger(e = $.Event('hide.bs.dropdown', relatedTarget))
      if (e.isDefaultPrevented()) return
      $parent.removeClass('open').trigger('hidden.bs.dropdown', relatedTarget)
    })
  }
766

XhmikosR's avatar
XhmikosR committed
767
768
  function getParent($this) {
    var selector = $this.attr('data-target')
769

XhmikosR's avatar
XhmikosR committed
770
771
772
    if (!selector) {
      selector = $this.attr('href')
      selector = selector && /#[A-Za-z]/.test(selector) && selector.replace(/.*(?=#[^\s]*$)/, '') // strip for ie7
773
774
    }

XhmikosR's avatar
XhmikosR committed
775
    var $parent = selector && $(selector)
776

XhmikosR's avatar
XhmikosR committed
777
778
    return $parent && $parent.length ? $parent : $this.parent()
  }
779
780


XhmikosR's avatar
XhmikosR committed
781
782
  // DROPDOWN PLUGIN DEFINITION
  // ==========================
783

XhmikosR's avatar
XhmikosR committed
784
785
786
787
  function Plugin(option) {
    return this.each(function () {
      var $this = $(this)
      var data  = $this.data('bs.dropdown')
788

XhmikosR's avatar
XhmikosR committed
789
790
791
792
      if (!data) $this.data('bs.dropdown', (data = new Dropdown(this)))
      if (typeof option == 'string') data[option].call($this)
    })
  }
Mark Otto's avatar
Mark Otto committed
793

XhmikosR's avatar
XhmikosR committed
794
  var old = $.fn.dropdown
795

XhmikosR's avatar
XhmikosR committed
796
797
  $.fn.dropdown             = Plugin
  $.fn.dropdown.Constructor = Dropdown
798

799

XhmikosR's avatar
XhmikosR committed
800
801
  // DROPDOWN NO CONFLICT
  // ====================
802

XhmikosR's avatar
XhmikosR committed
803
804
805
806
  $.fn.dropdown.noConflict = function () {
    $.fn.dropdown = old
    return this
  }
807

808

XhmikosR's avatar
XhmikosR committed
809
810
811
812
813
814
815
816
  // APPLY TO STANDARD DROPDOWN ELEMENTS
  // ===================================

  $(document)
    .on('click.bs.dropdown.data-api', clearMenus)
    .on('click.bs.dropdown.data-api', '.dropdown form', function (e) { e.stopPropagation() })
    .on('click.bs.dropdown.data-api', toggle, Dropdown.prototype.toggle)
    .on('keydown.bs.dropdown.data-api', toggle + ', [role="menu"], [role="listbox"]', Dropdown.prototype.keydown)
817

XhmikosR's avatar
XhmikosR committed
818
}(jQuery);
819

820
/* ========================================================================
Mark Otto's avatar
Mark Otto committed
821
 * Bootstrap: modal.js v3.2.0
Mark Otto's avatar
Mark Otto committed
822
 * http://getbootstrap.com/javascript/#modals
823
 * ========================================================================
824
 * Copyright 2011-2014 Twitter, Inc.
825
 * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
826
 * ======================================================================== */
827
828


XhmikosR's avatar
XhmikosR committed
829
830
+function ($) {
  'use strict';
831

XhmikosR's avatar
XhmikosR committed
832
833
  // MODAL CLASS DEFINITION
  // ======================
834

XhmikosR's avatar
XhmikosR committed
835
836
837
838
839
840
841
  var Modal = function (element, options) {
    this.options        = options
    this.$body          = $(document.body)
    this.$element       = $(element)
    this.$backdrop      =
    this.isShown        = null
    this.scrollbarWidth = 0
842

XhmikosR's avatar
XhmikosR committed
843
844
845
846
847
848
    if (this.options.remote) {
      this.$element
        .find('.modal-content')
        .load(this.options.remote, $.proxy(function () {
          this.$element.trigger('loaded.bs.modal')
        }, this))
849
    }
XhmikosR's avatar
XhmikosR committed
850
  }
851

Mark Otto's avatar
Mark Otto committed
852
  Modal.VERSION  = '3.2.0'
Mark Otto's avatar
grunt    
Mark Otto committed
853

XhmikosR's avatar
XhmikosR committed
854
855
856
857
858
  Modal.DEFAULTS = {
    backdrop: true,
    keyboard: true,
    show: true
  }
859

XhmikosR's avatar
XhmikosR committed
860
861
862
  Modal.prototype.toggle = function (_relatedTarget) {
    return this.isShown ? this.hide() : this.show(_relatedTarget)
  }
863

XhmikosR's avatar
XhmikosR committed
864
865
866
  Modal.prototype.show = function (_relatedTarget) {
    var that = this
    var e    = $.Event('show.bs.modal', { relatedTarget: _relatedTarget })
867

XhmikosR's avatar
XhmikosR committed
868
    this.$element.trigger(e)
869

XhmikosR's avatar
XhmikosR committed
870
    if (this.isShown || e.isDefaultPrevented()) return
871

XhmikosR's avatar
XhmikosR committed
872
    this.isShown = true
fat's avatar
build    
fat committed
873

XhmikosR's avatar
XhmikosR committed
874
875
    this.checkScrollbar()
    this.$body.addClass('modal-open')
876

XhmikosR's avatar
XhmikosR committed
877
878
    this.setScrollbar()
    this.escape()
fat's avatar
rebuild    
fat committed
879

XhmikosR's avatar
XhmikosR committed
880
    this.$element.on('click.dismiss.bs.modal', '[data-dismiss="modal"]', $.proxy(this.hide, this))
881

XhmikosR's avatar
XhmikosR committed
882
883
    this.backdrop(function () {
      var transition = $.support.transition && that.$element.hasClass('fade')
884

XhmikosR's avatar
XhmikosR committed
885
886
887
      if (!that.$element.parent().length) {
        that.$element.appendTo(that.$body) // don't move modals dom position
      }
888

XhmikosR's avatar
XhmikosR committed
889
890
891
      that.$element
        .show()
        .scrollTop(0)
Jacob Thornton's avatar
Jacob Thornton committed
892

XhmikosR's avatar
XhmikosR committed
893
894
895
      if (transition) {
        that.$element[0].offsetWidth // force reflow
      }
896

XhmikosR's avatar
XhmikosR committed
897
898
899
      that.$element
        .addClass('in')
        .attr('aria-hidden', false)
900

XhmikosR's avatar
XhmikosR committed
901
      that.enforceFocus()
902

XhmikosR's avatar
XhmikosR committed
903
      var e = $.Event('shown.bs.modal', { relatedTarget: _relatedTarget })
904

XhmikosR's avatar
XhmikosR committed
905
906
907
908
909
910
911
912
913
      transition ?
        that.$element.find('.modal-dialog') // wait for modal to slide in
          .one('bsTransitionEnd', function () {
            that.$element.trigger('focus').trigger(e)
          })
          .emulateTransitionEnd(300) :
        that.$element.trigger('focus').trigger(e)
    })
  }
914

XhmikosR's avatar
XhmikosR committed
915
916
  Modal.prototype.hide = function (e) {
    if (e) e.preventDefault()
917

XhmikosR's avatar
XhmikosR committed
918
    e = $.Event('hide.bs.modal')
fat's avatar
build    
fat committed
919

XhmikosR's avatar
XhmikosR committed
920
    this.$element.trigger(e)
921

XhmikosR's avatar
XhmikosR committed
922
    if (!this.isShown || e.isDefaultPrevented()) return
923

XhmikosR's avatar
XhmikosR committed
924
    this.isShown = false
925

XhmikosR's avatar
XhmikosR committed
926
    this.$body.removeClass('modal-open')
927

XhmikosR's avatar
XhmikosR committed
928
929
    this.resetScrollbar()
    this.escape()
Chris Rebert's avatar
Chris Rebert committed
930

XhmikosR's avatar
XhmikosR committed
931
    $(document).off('focusin.bs.modal')
Chris Rebert's avatar
Chris Rebert committed
932

XhmikosR's avatar
XhmikosR committed
933
934
935
936
    this.$element
      .removeClass('in')
      .attr('aria-hidden', true)
      .off('click.dismiss.bs.modal')
937

XhmikosR's avatar
XhmikosR committed
938
939
940
941
942
943
    $.support.transition && this.$element.hasClass('fade') ?
      this.$element
        .one('bsTransitionEnd', $.proxy(this.hideModal, this))
        .emulateTransitionEnd(300) :
      this.hideModal()
  }
944

XhmikosR's avatar
XhmikosR committed
945
946
947
948
949
950
951
952
953
954
955
956
957
958
959
960
961
962
963
964
965
966
967
968
969
970
971
  Modal.prototype.enforceFocus = function () {
    $(document)
      .off('focusin.bs.modal') // guard against infinite focus loop
      .on('focusin.bs.modal', $.proxy(function (e) {
        if (this.$element[0] !== e.target && !this.$element.has(e.target).length) {
          this.$element.trigger('focus')
        }
      }, this))
  }

  Modal.prototype.escape = function () {
    if (this.isShown && this.options.keyboard) {
      this.$element.on('keyup.dismiss.bs.modal', $.proxy(function (e) {
        e.which == 27 && this.hide()
      }, this))
    } else if (!this.isShown) {
      this.$element.off('keyup.dismiss.bs.modal')
    }
  }

  Modal.prototype.hideModal = function () {
    var that = this
    this.$element.hide()
    this.backdrop(function () {
      that.$element.trigger('hidden.bs.modal')
    })
  }
972

XhmikosR's avatar
XhmikosR committed
973
974
975
976
  Modal.prototype.removeBackdrop = function () {
    this.$backdrop && this.$backdrop.remove()
    this.$backdrop = null
  }
977

XhmikosR's avatar
XhmikosR committed
978
979
980
  Modal.prototype.backdrop = function (callback) {
    var that = this
    var animate = this.$element.hasClass('fade') ? 'fade' : ''
981

XhmikosR's avatar
XhmikosR committed
982
983
    if (this.isShown && this.options.backdrop) {
      var doAnimate = $.support.transition && animate
984

XhmikosR's avatar
XhmikosR committed
985
986
      this.$backdrop = $('<div class="modal-backdrop ' + animate + '" />')
        .appendTo(this.$body)
987

XhmikosR's avatar
XhmikosR committed
988
989
990
991
992
993
      this.$element.on('click.dismiss.bs.modal', $.proxy(function (e) {
        if (e.target !== e.currentTarget) return
        this.options.backdrop == 'static'
          ? this.$element[0].focus.call(this.$element[0])
          : this.hide.call(this)
      }, this))
994

XhmikosR's avatar
XhmikosR committed
995
      if (doAnimate) this.$backdrop[0].offsetWidth // force reflow
996

XhmikosR's avatar
XhmikosR committed
997
      this.$backdrop.addClass('in')
998

XhmikosR's avatar
XhmikosR committed
999
      if (!callback) return
1000

XhmikosR's avatar
XhmikosR committed
1001
1002
1003
1004
1005
      doAnimate ?
        this.$backdrop
          .one('bsTransitionEnd', callback)
          .emulateTransitionEnd(150) :
        callback()
1006

XhmikosR's avatar
XhmikosR committed
1007
1008
    } else if (!this.isShown && this.$backdrop) {
      this.$backdrop.removeClass('in')
Chris Rebert's avatar
Chris Rebert committed
1009

XhmikosR's avatar
XhmikosR committed
1010
1011
1012
      var callbackRemove = function () {
        that.removeBackdrop()
        callback && callback()
Chris Rebert's avatar
Chris Rebert committed
1013
      }
XhmikosR's avatar
XhmikosR committed
1014
1015
1016
1017
1018
      $.support.transition && this.$element.hasClass('fade') ?
        this.$backdrop
          .one('bsTransitionEnd', callbackRemove)
          .emulateTransitionEnd(150) :
        callbackRemove()
1019

XhmikosR's avatar
XhmikosR committed
1020
1021
    } else if (callback) {
      callback()
Chris Rebert's avatar
Chris Rebert committed
1022
    }
XhmikosR's avatar
XhmikosR committed
1023
  }
1024

XhmikosR's avatar
XhmikosR committed
1025
1026
1027
1028
  Modal.prototype.checkScrollbar = function () {
    if (document.body.clientWidth >= window.innerWidth) return
    this.scrollbarWidth = this.scrollbarWidth || this.measureScrollbar()
  }
fat's avatar
build    
fat committed
1029

XhmikosR's avatar
XhmikosR committed
1030
1031
1032
1033
  Modal.prototype.setScrollbar = function () {
    var bodyPad = parseInt((this.$body.css('padding-right') || 0), 10)
    if (this.scrollbarWidth) this.$body.css('padding-right', bodyPad + this.scrollbarWidth)
  }
fat's avatar
build    
fat committed
1034

XhmikosR's avatar
XhmikosR committed
1035
1036
1037
  Modal.prototype.resetScrollbar = function () {
    this.$body.css('padding-right', '')
  }
fat's avatar
build    
fat committed
1038

XhmikosR's avatar
XhmikosR committed
1039
1040
1041
1042
1043
1044
1045
1046
  Modal.prototype.measureScrollbar = function () { // thx walsh
    var scrollDiv = document.createElement('div')
    scrollDiv.className = 'modal-scrollbar-measure'
    this.$body.append(scrollDiv)
    var scrollbarWidth = scrollDiv.offsetWidth - scrollDiv.clientWidth
    this.$body[0].removeChild(scrollDiv)
    return scrollbarWidth
  }
1047
1048


XhmikosR's avatar
XhmikosR committed
1049
1050
  // MODAL PLUGIN DEFINITION
  // =======================
fat's avatar
fat committed
1051

XhmikosR's avatar
XhmikosR committed
1052
1053
1054
1055
1056
1057
1058
1059
1060
1061
1062
  function Plugin(option, _relatedTarget) {
    return this.each(function () {
      var $this   = $(this)
      var data    = $this.data('bs.modal')
      var options = $.extend({}, Modal.DEFAULTS, $this.data(), typeof option == 'object' && option)

      if (!data) $this.data('bs.modal', (data = new Modal(this, options)))
      if (typeof option == 'string') data[option](_relatedTarget)
      else if (options.show) data.show(_relatedTarget)
    })
  }
1063

XhmikosR's avatar
XhmikosR committed
1064
  var old = $.fn.modal
Mark Otto's avatar
Mark Otto committed
1065

XhmikosR's avatar
XhmikosR committed
1066
1067
  $.fn.modal             = Plugin
  $.fn.modal.Constructor = Modal
1068
1069


XhmikosR's avatar
XhmikosR committed
1070
1071
  // MODAL NO CONFLICT
  // =================
1072

XhmikosR's avatar
XhmikosR committed
1073
1074
1075
1076
  $.fn.modal.noConflict = function () {
    $.fn.modal = old
    return this
  }
1077
1078


XhmikosR's avatar
XhmikosR committed
1079
1080
  // MODAL DATA-API
  // ==============
1081

XhmikosR's avatar
XhmikosR committed
1082
1083
1084
1085
1086
  $(document).on('click.bs.modal.data-api', '[data-toggle="modal"]', function (e) {
    var $this   = $(this)
    var href    = $this.attr('href')
    var $target = $($this.attr('data-target') || (href && href.replace(/.*(?=#[^\s]+$)/, ''))) // strip for ie7
    var option  = $target.data('bs.modal') ? 'toggle' : $.extend({ remote: !/#/.test(href) && href }, $target.data(), $this.data())
1087

XhmikosR's avatar
XhmikosR committed
1088
    if ($this.is('a')) e.preventDefault()
1089

XhmikosR's avatar
XhmikosR committed
1090
1091
1092
1093
    $target.one('show.bs.modal', function (showEvent) {
      if (showEvent.isDefaultPrevented()) return // only register focus restorer if modal will actually get shown
      $target.one('hidden.bs.modal', function () {
        $this.is(':visible') && $this.trigger('focus')
Mark Otto's avatar
grunt    
Mark Otto committed
1094
      })
Mark Otto's avatar
Mark Otto committed
1095
    })
XhmikosR's avatar
XhmikosR committed
1096
    Plugin.call($target, option, this)
Jacob Thornton's avatar
Jacob Thornton committed
1097
  })
1098

XhmikosR's avatar
XhmikosR committed
1099
}(jQuery);
1100

1101
/* ========================================================================
Mark Otto's avatar
Mark Otto committed
1102
 * Bootstrap: tooltip.js v3.2.0
Mark Otto's avatar
Mark Otto committed
1103
 * http://getbootstrap.com/javascript/#tooltip
1104
 * Inspired by the original jQuery.tipsy by Jason Frame
1105
 * ========================================================================
1106
 * Copyright 2011-2014 Twitter, Inc.
1107
 * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
1108
 * ======================================================================== */
1109
1110


XhmikosR's avatar
XhmikosR committed
1111
1112
1113
1114
1115
1116
1117
1118
1119
1120
1121
1122
1123
1124
1125
1126
1127
+function ($) {
  'use strict';

  // TOOLTIP PUBLIC CLASS DEFINITION
  // ===============================

  var Tooltip = function (element, options) {
    this.type       =
    this.options    =
    this.enabled    =
    this.timeout    =
    this.hoverState =
    this.$element   = null

    this.init('tooltip', element, options)
  }

Mark Otto's avatar
Mark Otto committed
1128
  Tooltip.VERSION  = '3.2.0'
XhmikosR's avatar
XhmikosR committed
1129
1130
1131
1132
1133
1134
1135
1136
1137
1138
1139
1140
1141
1142
1143
1144
1145
1146
1147
1148
1149
1150
1151
1152
1153
1154
1155
1156
1157
1158
1159
1160
1161
1162
1163
1164
1165
1166
1167

  Tooltip.DEFAULTS = {
    animation: true,
    placement: 'top',
    selector: false,
    template: '<div class="tooltip" role="tooltip"><div class="tooltip-arrow"></div><div class="tooltip-inner"></div></div>',
    trigger: 'hover focus',
    title: '',
    delay: 0,
    html: false,
    container: false,
    viewport: {
      selector: 'body',
      padding: 0
    }
  }

  Tooltip.prototype.init = function (type, element, options) {
    this.enabled   = true
    this.type      = type
    this.$element  = $(element)
    this.options   = this.getOptions(options)
    this.$viewport = this.options.viewport && $(this.options.viewport.selector || this.options.viewport)

    var triggers = this.options.trigger.split(' ')

    for (var i = triggers.length; i--;) {
      var trigger = triggers[i]

      if (trigger == 'click') {
        this.$element.on('click.' + this.type, this.options.selector, $.proxy(this.toggle, this))
      } else if (trigger != 'manual') {
        var eventIn  = trigger == 'hover' ? 'mouseenter' : 'focusin'
        var eventOut = trigger == 'hover' ? 'mouseleave' : 'focusout'

        this.$element.on(eventIn  + '.' + this.type, this.options.selector, $.proxy(this.enter, this))
        this.$element.on(eventOut + '.' + this.type, this.options.selector, $.proxy(this.leave, this))
      }
    }
1168

XhmikosR's avatar
XhmikosR committed
1169
1170
1171
1172
    this.options.selector ?
      (this._options = $.extend({}, this.options, { trigger: 'manual', selector: '' })) :
      this.fixTitle()
  }
1173

XhmikosR's avatar
XhmikosR committed
1174
1175
1176
  Tooltip.prototype.getDefaults = function () {
    return Tooltip.DEFAULTS
  }
1177

XhmikosR's avatar
XhmikosR committed
1178
1179
  Tooltip.prototype.getOptions = function (options) {
    options = $.extend({}, this.getDefaults(), this.$element.data(), options)
1180

XhmikosR's avatar
XhmikosR committed
1181
1182
1183
1184
    if (options.delay && typeof options.delay == 'number') {
      options.delay = {
        show: options.delay,
        hide: options.delay
1185
1186
      }
    }
1187

XhmikosR's avatar
XhmikosR committed
1188
1189
    return options
  }
Jacob Thornton's avatar
Jacob Thornton committed
1190

XhmikosR's avatar
XhmikosR committed
1191
1192
1193
  Tooltip.prototype.getDelegateOptions = function () {
    var options  = {}
    var defaults = this.getDefaults()
1194

XhmikosR's avatar
XhmikosR committed
1195
1196
1197
    this._options && $.each(this._options, function (key, value) {
      if (defaults[key] != value) options[key] = value
    })
fat's avatar
rebuild    
fat committed
1198

XhmikosR's avatar
XhmikosR committed
1199
1200
    return options
  }
Jacob Thornton's avatar
Jacob Thornton committed
1201

XhmikosR's avatar
XhmikosR committed
1202
1203
1204
  Tooltip.prototype.enter = function (obj) {
    var self = obj instanceof this.constructor ?
      obj : $(obj.currentTarget).data('bs.' + this.type)
Mark Otto's avatar
Mark Otto committed
1205

XhmikosR's avatar
XhmikosR committed
1206
1207
1208
    if (!self) {
      self = new this.constructor(obj.currentTarget, this.getDelegateOptions())
      $(obj.currentTarget).data('bs.' + this.type, self)
Mark Otto's avatar
Mark Otto committed
1209
    }
1210

XhmikosR's avatar
XhmikosR committed
1211
    clearTimeout(self.timeout)
1212

XhmikosR's avatar
XhmikosR committed
1213
    self.hoverState = 'in'
1214

XhmikosR's avatar
XhmikosR committed
1215
    if (!self.options.delay || !self.options.delay.show) return self.show()
1216

XhmikosR's avatar
XhmikosR committed
1217
1218
1219
1220
    self.timeout = setTimeout(function () {
      if (self.hoverState == 'in') self.show()
    }, self.options.delay.show)
  }
1221

XhmikosR's avatar
XhmikosR committed
1222
1223
1224
  Tooltip.prototype.leave = function (obj) {
    var self = obj instanceof this.constructor ?
      obj : $(obj.currentTarget).data('bs.' + this.type)
Mark Otto's avatar
Mark Otto committed
1225

XhmikosR's avatar
XhmikosR committed
1226
1227
1228
    if (!self) {
      self = new this.constructor(obj.currentTarget, this.getDelegateOptions())
      $(obj.currentTarget).data('bs.' + this.type, self)
Mark Otto's avatar
Mark Otto committed
1229
    }
1230

XhmikosR's avatar
XhmikosR committed
1231
    clearTimeout(self.timeout)
fat's avatar
fat committed
1232

XhmikosR's avatar
XhmikosR committed
1233
    self.hoverState = 'out'
1234

XhmikosR's avatar
XhmikosR committed
1235
    if (!self.options.delay || !self.options.delay.hide) return self.hide()
1236

XhmikosR's avatar
XhmikosR committed
1237
1238
1239
1240
    self.timeout = setTimeout(function () {
      if (self.hoverState == 'out') self.hide()
    }, self.options.delay.hide)
  }
1241

XhmikosR's avatar
XhmikosR committed
1242
1243
  Tooltip.prototype.show = function () {
    var e = $.Event('show.bs.' + this.type)
Chris Rebert's avatar
Chris Rebert committed
1244

XhmikosR's avatar
XhmikosR committed
1245
1246
    if (this.hasContent() && this.enabled) {
      this.$element.trigger(e)
fat's avatar
fat committed
1247

XhmikosR's avatar
XhmikosR committed
1248
1249
1250
      var inDom = $.contains(document.documentElement, this.$element[0])
      if (e.isDefaultPrevented() || !inDom) return
      var that = this
1251

XhmikosR's avatar
XhmikosR committed
1252
      var $tip = this.tip()
fat's avatar
fat committed
1253

XhmikosR's avatar
XhmikosR committed
1254
      var tipId = this.getUID(this.type)
fat's avatar
fat committed
1255

XhmikosR's avatar
XhmikosR committed
1256
1257
1258
      this.setContent()
      $tip.attr('id', tipId)
      this.$element.attr('aria-describedby', tipId)
1259

XhmikosR's avatar
XhmikosR committed
1260
      if (this.options.animation) $tip.addClass('fade')
1261

XhmikosR's avatar
XhmikosR committed
1262
1263
1264
      var placement = typeof this.options.placement == 'function' ?
        this.options.placement.call(this, $tip[0], this.$element[0]) :
        this.options.placement
1265

XhmikosR's avatar
XhmikosR committed
1266
1267
1268
      var autoToken = /\s?auto?\s?/i
      var autoPlace = autoToken.test(placement)
      if (autoPlace) placement = placement.replace(autoToken, '') || 'top'
1269

XhmikosR's avatar
XhmikosR committed
1270
1271
1272
1273
1274
      $tip
        .detach()
        .css({ top: 0, left: 0, display: 'block' })
        .addClass(placement)
        .data('bs.' + this.type, this)
fat's avatar
fat committed
1275

XhmikosR's avatar
XhmikosR committed
1276
      this.options.container ? $tip.appendTo(this.options.container) : $tip.insertAfter(this.$element)
1277

XhmikosR's avatar
XhmikosR committed
1278
1279
1280
      var pos          = this.getPosition()
      var actualWidth  = $tip[0].offsetWidth
      var actualHeight = $tip[0].offsetHeight
Chris Rebert's avatar
Chris Rebert committed
1281

XhmikosR's avatar
XhmikosR committed
1282
1283
1284
1285
      if (autoPlace) {
        var orgPlacement = placement
        var $parent      = this.$element.parent()
        var parentDim    = this.getPosition($parent)
Chris Rebert's avatar
Chris Rebert committed
1286

XhmikosR's avatar
XhmikosR committed
1287
1288
1289
1290
1291
        placement = placement == 'bottom' && pos.top   + pos.height       + actualHeight - parentDim.scroll > parentDim.height ? 'top'    :
                    placement == 'top'    && pos.top   - parentDim.scroll - actualHeight < 0                                   ? 'bottom' :
                    placement == 'right'  && pos.right + actualWidth      > parentDim.width                                    ? 'left'   :
                    placement == 'left'   && pos.left  - actualWidth      < parentDim.left                                     ? 'right'  :
                    placement
fat's avatar
fat committed
1292

1293
        $tip
XhmikosR's avatar
XhmikosR committed
1294
          .removeClass(orgPlacement)
1295
          .addClass(placement)
XhmikosR's avatar
XhmikosR committed
1296
      }
1297

XhmikosR's avatar
XhmikosR committed
1298
      var calculatedOffset = this.getCalculatedOffset(placement, pos, actualWidth, actualHeight)
1299

XhmikosR's avatar
XhmikosR committed
1300
      this.applyPlacement(calculatedOffset, placement)
fat's avatar
fat committed
1301

XhmikosR's avatar
XhmikosR committed
1302
1303
1304
1305
      var complete = function () {
        that.$element.trigger('shown.bs.' + that.type)
        that.hoverState = null
      }
fat's avatar
fat committed
1306

XhmikosR's avatar
XhmikosR committed
1307
1308
1309
1310
1311
1312
1313
      $.support.transition && this.$tip.hasClass('fade') ?
        $tip
          .one('bsTransitionEnd', complete)
          .emulateTransitionEnd(150) :
        complete()
    }
  }
fat's avatar
fat committed
1314

XhmikosR's avatar
XhmikosR committed
1315
1316
1317
1318
  Tooltip.prototype.applyPlacement = function (offset, placement) {
    var $tip   = this.tip()
    var width  = $tip[0].offsetWidth
    var height = $tip[0].offsetHeight
fat's avatar
fat committed
1319

XhmikosR's avatar
XhmikosR committed
1320
1321
1322
    // manually read margins because getBoundingClientRect includes difference
    var marginTop = parseInt($tip.css('margin-top'), 10)
    var marginLeft = parseInt($tip.css('margin-left'), 10)
fat's avatar
fat committed
1323

XhmikosR's avatar
XhmikosR committed
1324
1325
1326
    // we must check for NaN for ie 8/9
    if (isNaN(marginTop))  marginTop  = 0
    if (isNaN(marginLeft)) marginLeft = 0
fat's avatar
fat committed
1327

XhmikosR's avatar
XhmikosR committed
1328
1329
    offset.top  = offset.top  + marginTop
    offset.left = offset.left + marginLeft
fat's avatar
fat committed
1330

XhmikosR's avatar
XhmikosR committed
1331
1332
1333
1334
1335
1336
1337
1338
    // $.fn.offset doesn't round pixel values
    // so we use setOffset directly with our own function B-0
    $.offset.setOffset($tip[0], $.extend({
      using: function (props) {
        $tip.css({
          top: Math.round(props.top),
          left: Math.round(props.left)
        })
1339
      }
XhmikosR's avatar
XhmikosR committed
1340
    }, offset), 0)
1341

XhmikosR's avatar
XhmikosR committed
1342
    $tip.addClass('in')
fat's avatar
fat committed
1343

XhmikosR's avatar
XhmikosR committed
1344
1345
1346
    // check to see if placing tip in new offset caused the tip to resize itself
    var actualWidth  = $tip[0].offsetWidth
    var actualHeight = $tip[0].offsetHeight
fat's avatar
fat committed
1347

XhmikosR's avatar
XhmikosR committed
1348
1349
1350
    if (placement == 'top' && actualHeight != height) {
      offset.top = offset.top + height - actualHeight
    }
fat's avatar
fat committed
1351

XhmikosR's avatar
XhmikosR committed
1352
    var delta = this.getViewportAdjustedDelta(placement, offset, actualWidth, actualHeight)
fat's avatar
fat committed
1353

XhmikosR's avatar
XhmikosR committed
1354
1355
    if (delta.left) offset.left += delta.left
    else offset.top += delta.top
1356

XhmikosR's avatar
XhmikosR committed
1357
1358
1359
    var arrowDelta          = delta.left ? delta.left * 2 - width + actualWidth : delta.top * 2 - height + actualHeight
    var arrowPosition       = delta.left ? 'left'        : 'top'
    var arrowOffsetPosition = delta.left ? 'offsetWidth' : 'offsetHeight'
1360

XhmikosR's avatar
XhmikosR committed
1361
1362
1363
    $tip.offset(offset)
    this.replaceArrow(arrowDelta, $tip[0][arrowOffsetPosition], arrowPosition)
  }
1364

XhmikosR's avatar
XhmikosR committed
1365
1366
1367
  Tooltip.prototype.replaceArrow = function (delta, dimension, position) {
    this.arrow().css(position, delta ? (50 * (1 - delta / dimension) + '%') : '')
  }
1368

XhmikosR's avatar
XhmikosR committed
1369
1370
1371
  Tooltip.prototype.setContent = function () {
    var $tip  = this.tip()
    var title = this.getTitle()
1372

XhmikosR's avatar
XhmikosR committed
1373
1374
1375
    $tip.find('.tooltip-inner')[this.options.html ? 'html' : 'text'](title)
    $tip.removeClass('fade in top bottom left right')
  }
1376

XhmikosR's avatar
XhmikosR committed
1377
1378
1379
1380
  Tooltip.prototype.hide = function () {
    var that = this
    var $tip = this.tip()
    var e    = $.Event('hide.bs.' + this.type)
1381

XhmikosR's avatar
XhmikosR committed
1382
    this.$element.removeAttr('aria-describedby')
1383

XhmikosR's avatar
XhmikosR committed
1384
1385
1386
1387
    function complete() {
      if (that.hoverState != 'in') $tip.detach()
      that.$element.trigger('hidden.bs.' + that.type)
    }
Jacob Thornton's avatar
Jacob Thornton committed
1388

XhmikosR's avatar
XhmikosR committed
1389
    this.$element.trigger(e)
1390

XhmikosR's avatar
XhmikosR committed
1391
    if (e.isDefaultPrevented()) return
1392

XhmikosR's avatar
XhmikosR committed
1393
    $tip.removeClass('in')
1394

XhmikosR's avatar
XhmikosR committed
1395
1396
1397
1398
1399
    $.support.transition && this.$tip.hasClass('fade') ?
      $tip
        .one('bsTransitionEnd', complete)
        .emulateTransitionEnd(150) :
      complete()
1400

XhmikosR's avatar
XhmikosR committed
1401
    this.hoverState = null
1402

XhmikosR's avatar
XhmikosR committed
1403
1404
    return this
  }
1405

XhmikosR's avatar
XhmikosR committed
1406
1407
1408
1409
  Tooltip.prototype.fixTitle = function () {
    var $e = this.$element
    if ($e.attr('title') || typeof ($e.attr('data-original-title')) != 'string') {
      $e.attr('data-original-title', $e.attr('title') || '').attr('title', '')
1410
    }
XhmikosR's avatar
XhmikosR committed
1411
  }
1412

XhmikosR's avatar
XhmikosR committed
1413
1414
1415
  Tooltip.prototype.hasContent = function () {
    return this.getTitle()
  }
1416

XhmikosR's avatar
XhmikosR committed
1417
1418
1419
1420
  Tooltip.prototype.getPosition = function ($element) {
    $element   = $element || this.$element
    var el     = $element[0]
    var isBody = el.tagName == 'BODY'
Chris Rebert's avatar
Chris Rebert committed
1421
1422
    var isSvg = window.SVGElement && el instanceof window.SVGElement
    var outerDims = isSvg ? {} : {
XhmikosR's avatar
XhmikosR committed
1423
1424
      width:  isBody ? $(window).width()  : $element.outerWidth(),
      height: isBody ? $(window).height() : $element.outerHeight()
Chris Rebert's avatar
Chris Rebert committed
1425
1426
1427
1428
    }
    return $.extend({}, (typeof el.getBoundingClientRect == 'function') ? el.getBoundingClientRect() : null, {
      scroll: isBody ? document.documentElement.scrollTop || document.body.scrollTop : $element.scrollTop()
    }, outerDims, isBody ? { top: 0, left: 0 } : $element.offset())
XhmikosR's avatar
XhmikosR committed
1429
  }
1430

XhmikosR's avatar
XhmikosR committed
1431
1432
1433
1434
1435
  Tooltip.prototype.getCalculatedOffset = function (placement, pos, actualWidth, actualHeight) {
    return placement == 'bottom' ? { top: pos.top + pos.height,   left: pos.left + pos.width / 2 - actualWidth / 2  } :
           placement == 'top'    ? { top: pos.top - actualHeight, left: pos.left + pos.width / 2 - actualWidth / 2  } :
           placement == 'left'   ? { top: pos.top + pos.height / 2 - actualHeight / 2, left: pos.left - actualWidth } :
        /* placement == 'right' */ { top: pos.top + pos.height / 2 - actualHeight / 2, left: pos.left + pos.width   }
1436

XhmikosR's avatar
XhmikosR committed
1437
  }
1438

XhmikosR's avatar
XhmikosR committed
1439
1440
1441
  Tooltip.prototype.getViewportAdjustedDelta = function (placement, pos, actualWidth, actualHeight) {
    var delta = { top: 0, left: 0 }
    if (!this.$viewport) return delta
1442

XhmikosR's avatar
XhmikosR committed
1443
1444
    var viewportPadding = this.options.viewport && this.options.viewport.padding || 0
    var viewportDimensions = this.getPosition(this.$viewport)
1445

XhmikosR's avatar
XhmikosR committed
1446
1447
1448
1449
1450
1451
1452
1453
1454
1455
1456
1457
1458
1459
1460
    if (/right|left/.test(placement)) {
      var topEdgeOffset    = pos.top - viewportPadding - viewportDimensions.scroll
      var bottomEdgeOffset = pos.top + viewportPadding - viewportDimensions.scroll + actualHeight
      if (topEdgeOffset < viewportDimensions.top) { // top overflow
        delta.top = viewportDimensions.top - topEdgeOffset
      } else if (bottomEdgeOffset > viewportDimensions.top + viewportDimensions.height) { // bottom overflow
        delta.top = viewportDimensions.top + viewportDimensions.height - bottomEdgeOffset
      }
    } else {
      var leftEdgeOffset  = pos.left - viewportPadding
      var rightEdgeOffset = pos.left + viewportPadding + actualWidth
      if (leftEdgeOffset < viewportDimensions.left) { // left overflow
        delta.left = viewportDimensions.left - leftEdgeOffset
      } else if (rightEdgeOffset > viewportDimensions.width) { // right overflow
        delta.left = viewportDimensions.left + viewportDimensions.width - rightEdgeOffset
1461
      }
Chris Rebert's avatar
Chris Rebert committed
1462
    }
fat's avatar
fat committed
1463

XhmikosR's avatar
XhmikosR committed
1464
1465
    return delta
  }
1466

XhmikosR's avatar
XhmikosR committed
1467
1468
1469
1470
  Tooltip.prototype.getTitle = function () {
    var title
    var $e = this.$element
    var o  = this.options
1471

XhmikosR's avatar
XhmikosR committed
1472
1473
    title = $e.attr('data-original-title')
      || (typeof o.title == 'function' ? o.title.call($e[0]) :  o.title)
1474

XhmikosR's avatar
XhmikosR committed
1475
1476
    return title
  }
1477

XhmikosR's avatar
XhmikosR committed
1478
1479
1480
1481
1482
  Tooltip.prototype.getUID = function (prefix) {
    do prefix += ~~(Math.random() * 1000000)
    while (document.getElementById(prefix))
    return prefix
  }
1483

XhmikosR's avatar
XhmikosR committed
1484
1485
1486
  Tooltip.prototype.tip = function () {
    return (this.$tip = this.$tip || $(this.options.template))
  }
1487

XhmikosR's avatar
XhmikosR committed
1488
1489
1490
  Tooltip.prototype.arrow = function () {
    return (this.$arrow = this.$arrow || this.tip().find('.tooltip-arrow'))
  }
1491

XhmikosR's avatar
XhmikosR committed
1492
1493
1494
1495
1496
  Tooltip.prototype.validate = function () {
    if (!this.$element[0].parentNode) {
      this.hide()
      this.$element = null
      this.options  = null
Chris Rebert's avatar
Chris Rebert committed
1497
    }
XhmikosR's avatar
XhmikosR committed
1498
  }
1499

XhmikosR's avatar
XhmikosR committed
1500
1501
1502
  Tooltip.prototype.enable = function () {
    this.enabled = true
  }
1503

XhmikosR's avatar
XhmikosR committed
1504
1505
1506
  Tooltip.prototype.disable = function () {
    this.enabled = false
  }
Mark Otto's avatar
Mark Otto committed
1507

XhmikosR's avatar
XhmikosR committed
1508
1509
1510
  Tooltip.prototype.toggleEnabled = function () {
    this.enabled = !this.enabled
  }
Chris Rebert's avatar
Chris Rebert committed
1511

XhmikosR's avatar
XhmikosR committed
1512
1513
1514
1515
1516
1517
1518
1519
  Tooltip.prototype.toggle = function (e) {
    var self = this
    if (e) {
      self = $(e.currentTarget).data('bs.' + this.type)
      if (!self) {
        self = new this.constructor(e.currentTarget, this.getDelegateOptions())
        $(e.currentTarget).data('bs.' + this.type, self)
      }
Mark Otto's avatar
Mark Otto committed
1520
1521
    }

XhmikosR's avatar
XhmikosR committed
1522
1523
    self.tip().hasClass('in') ? self.leave(self) : self.enter(self)
  }
1524

XhmikosR's avatar
XhmikosR committed
1525
1526
1527
1528
  Tooltip.prototype.destroy = function () {
    clearTimeout(this.timeout)
    this.hide().$element.off('.' + this.type).removeData('bs.' + this.type)
  }
1529
1530


XhmikosR's avatar
XhmikosR committed
1531
1532
  // TOOLTIP PLUGIN DEFINITION
  // =========================
1533

XhmikosR's avatar
XhmikosR committed
1534
1535
1536
1537
1538
  function Plugin(option) {
    return this.each(function () {
      var $this   = $(this)
      var data    = $this.data('bs.tooltip')
      var options = typeof option == 'object' && option
fat's avatar
fat committed
1539

XhmikosR's avatar
XhmikosR committed
1540
1541
1542
1543
1544
      if (!data && option == 'destroy') return
      if (!data) $this.data('bs.tooltip', (data = new Tooltip(this, options)))
      if (typeof option == 'string') data[option]()
    })
  }
1545

XhmikosR's avatar
XhmikosR committed
1546
  var old = $.fn.tooltip
Mark Otto's avatar
Mark Otto committed
1547

XhmikosR's avatar
XhmikosR committed
1548
1549
  $.fn.tooltip             = Plugin
  $.fn.tooltip.Constructor = Tooltip
1550

1551

XhmikosR's avatar
XhmikosR committed
1552
1553
  // TOOLTIP NO CONFLICT
  // ===================
1554

XhmikosR's avatar
XhmikosR committed
1555
1556
1557
1558
  $.fn.tooltip.noConflict = function () {
    $.fn.tooltip = old
    return this
  }
1559

XhmikosR's avatar
XhmikosR committed
1560
}(jQuery);
1561

1562
/* ========================================================================
Mark Otto's avatar
Mark Otto committed
1563
 * Bootstrap: popover.js v3.2.0
Mark Otto's avatar
Mark Otto committed
1564
 * http://getbootstrap.com/javascript/#popovers
1565
 * ========================================================================
1566
 * Copyright 2011-2014 Twitter, Inc.
1567
 * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
1568
 * ======================================================================== */
1569
1570


XhmikosR's avatar
XhmikosR committed
1571
1572
+function ($) {
  'use strict';
Mark Otto's avatar
grunt    
Mark Otto committed
1573

XhmikosR's avatar
XhmikosR committed
1574
1575
  // POPOVER PUBLIC CLASS DEFINITION
  // ===============================
1576

XhmikosR's avatar
XhmikosR committed
1577
1578
1579
  var Popover = function (element, options) {
    this.init('popover', element, options)
  }
fat's avatar
fat committed
1580

XhmikosR's avatar
XhmikosR committed
1581
  if (!$.fn.tooltip) throw new Error('Popover requires tooltip.js')
1582

Mark Otto's avatar
Mark Otto committed
1583
  Popover.VERSION  = '3.2.0'
1584

XhmikosR's avatar
XhmikosR committed
1585
1586
1587
1588
1589
1590
  Popover.DEFAULTS = $.extend({}, $.fn.tooltip.Constructor.DEFAULTS, {
    placement: 'right',
    trigger: 'click',
    content: '',
    template: '<div class="popover" role="tooltip"><div class="arrow"></div><h3 class="popover-title"></h3><div class="popover-content"></div></div>'
  })
fat's avatar
fat committed
1591
1592


XhmikosR's avatar
XhmikosR committed
1593
1594
  // NOTE: POPOVER EXTENDS tooltip.js
  // ================================
1595

XhmikosR's avatar
XhmikosR committed
1596
  Popover.prototype = $.extend({}, $.fn.tooltip.Constructor.prototype)
fat's avatar
fat committed
1597

XhmikosR's avatar
XhmikosR committed
1598
  Popover.prototype.constructor = Popover
1599

XhmikosR's avatar
XhmikosR committed
1600
1601
1602
  Popover.prototype.getDefaults = function () {
    return Popover.DEFAULTS
  }
1603

XhmikosR's avatar
XhmikosR committed
1604
1605
1606
1607
  Popover.prototype.setContent = function () {
    var $tip    = this.tip()
    var title   = this.getTitle()
    var content = this.getContent()
1608

XhmikosR's avatar
XhmikosR committed
1609
1610
1611
1612
    $tip.find('.popover-title')[this.options.html ? 'html' : 'text'](title)
    $tip.find('.popover-content').empty()[ // we use append for html objects to maintain js events
      this.options.html ? (typeof content == 'string' ? 'html' : 'append') : 'text'
    ](content)
1613

XhmikosR's avatar
XhmikosR committed
1614
    $tip.removeClass('fade top bottom left right in')
1615

XhmikosR's avatar
XhmikosR committed
1616
1617
1618
1619
    // IE8 doesn't accept hiding via the `:empty` pseudo selector, we have to do
    // this manually by checking the contents.
    if (!$tip.find('.popover-title').html()) $tip.find('.popover-title').hide()
  }
1620

XhmikosR's avatar
XhmikosR committed
1621
1622
1623
  Popover.prototype.hasContent = function () {
    return this.getTitle() || this.getContent()
  }
1624

XhmikosR's avatar
XhmikosR committed
1625
1626
1627
  Popover.prototype.getContent = function () {
    var $e = this.$element
    var o  = this.options
1628

XhmikosR's avatar
XhmikosR committed
1629
1630
1631
1632
1633
    return $e.attr('data-content')
      || (typeof o.content == 'function' ?
            o.content.call($e[0]) :
            o.content)
  }
fat's avatar
fat committed
1634

XhmikosR's avatar
XhmikosR committed
1635
1636
1637
  Popover.prototype.arrow = function () {
    return (this.$arrow = this.$arrow || this.tip().find('.arrow'))
  }
1638

XhmikosR's avatar
XhmikosR committed
1639
1640
1641
1642
  Popover.prototype.tip = function () {
    if (!this.$tip) this.$tip = $(this.options.template)
    return this.$tip
  }
1643

1644

XhmikosR's avatar
XhmikosR committed
1645
1646
  // POPOVER PLUGIN DEFINITION
  // =========================
1647

XhmikosR's avatar
XhmikosR committed
1648
1649
1650
1651
1652
  function Plugin(option) {
    return this.each(function () {
      var $this   = $(this)
      var data    = $this.data('bs.popover')
      var options = typeof option == 'object' && option
Chris Rebert's avatar
Chris Rebert committed
1653

XhmikosR's avatar
XhmikosR committed
1654
1655
1656
1657
1658
      if (!data && option == 'destroy') return
      if (!data) $this.data('bs.popover', (data = new Popover(this, options)))
      if (typeof option == 'string') data[option]()
    })
  }
1659

XhmikosR's avatar
XhmikosR committed
1660
  var old = $.fn.popover
Mark Otto's avatar
Mark Otto committed
1661

XhmikosR's avatar
XhmikosR committed
1662
1663
  $.fn.popover             = Plugin
  $.fn.popover.Constructor = Popover
fat's avatar
fat committed
1664

1665

XhmikosR's avatar
XhmikosR committed
1666
1667
  // POPOVER NO CONFLICT
  // ===================
1668

XhmikosR's avatar
XhmikosR committed
1669
1670
1671
1672
  $.fn.popover.noConflict = function () {
    $.fn.popover = old
    return this
  }
1673

XhmikosR's avatar
XhmikosR committed
1674
}(jQuery);
1675

1676
/* ========================================================================
Mark Otto's avatar
Mark Otto committed
1677
 * Bootstrap: scrollspy.js v3.2.0
Mark Otto's avatar
Mark Otto committed
1678
 * http://getbootstrap.com/javascript/#scrollspy
1679
 * ========================================================================
1680
 * Copyright 2011-2014 Twitter, Inc.
1681
 * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
1682
 * ======================================================================== */
1683
1684


XhmikosR's avatar
XhmikosR committed
1685
1686
+function ($) {
  'use strict';
1687

XhmikosR's avatar
XhmikosR committed
1688
1689
  // SCROLLSPY CLASS DEFINITION
  // ==========================
1690

XhmikosR's avatar
XhmikosR committed
1691
1692
  function ScrollSpy(element, options) {
    var process  = $.proxy(this.process, this)
1693

XhmikosR's avatar
XhmikosR committed
1694
1695
1696
1697
1698
1699
1700
1701
    this.$body          = $('body')
    this.$scrollElement = $(element).is('body') ? $(window) : $(element)
    this.options        = $.extend({}, ScrollSpy.DEFAULTS, options)
    this.selector       = (this.options.target || '') + ' .nav li > a'
    this.offsets        = []
    this.targets        = []
    this.activeTarget   = null
    this.scrollHeight   = 0
1702

XhmikosR's avatar
XhmikosR committed
1703
1704
1705
1706
    this.$scrollElement.on('scroll.bs.scrollspy', process)
    this.refresh()
    this.process()
  }
1707

Mark Otto's avatar
Mark Otto committed
1708
  ScrollSpy.VERSION  = '3.2.0'
Mark Otto's avatar
grunt    
Mark Otto committed
1709

XhmikosR's avatar
XhmikosR committed
1710
1711
1712
  ScrollSpy.DEFAULTS = {
    offset: 10
  }
1713

XhmikosR's avatar
XhmikosR committed
1714
1715
1716
  ScrollSpy.prototype.getScrollHeight = function () {
    return this.$scrollElement[0].scrollHeight || Math.max(this.$body[0].scrollHeight, document.documentElement.scrollHeight)
  }
Mark Otto's avatar
grunt    
Mark Otto committed
1717

XhmikosR's avatar
XhmikosR committed
1718
1719
1720
  ScrollSpy.prototype.refresh = function () {
    var offsetMethod = 'offset'
    var offsetBase   = 0
Mark Otto's avatar
grunt    
Mark Otto committed
1721

XhmikosR's avatar
XhmikosR committed
1722
1723
1724
1725
    if (!$.isWindow(this.$scrollElement[0])) {
      offsetMethod = 'position'
      offsetBase   = this.$scrollElement.scrollTop()
    }
Mark Otto's avatar
grunt    
Mark Otto committed
1726

XhmikosR's avatar
XhmikosR committed
1727
1728
1729
    this.offsets = []
    this.targets = []
    this.scrollHeight = this.getScrollHeight()
fat's avatar
fat committed
1730

XhmikosR's avatar
XhmikosR committed
1731
    var self     = this
XhmikosR's avatar
XhmikosR committed
1732

XhmikosR's avatar
XhmikosR committed
1733
1734
1735
1736
1737
1738
    this.$body
      .find(this.selector)
      .map(function () {
        var $el   = $(this)
        var href  = $el.data('target') || $el.attr('href')
        var $href = /^#./.test(href) && $(href)
1739

XhmikosR's avatar
XhmikosR committed
1740
1741
1742
1743
1744
1745
1746
1747
1748
1749
1750
1751
1752
1753
1754
1755
1756
1757
1758
1759
1760
1761
1762
        return ($href
          && $href.length
          && $href.is(':visible')
          && [[$href[offsetMethod]().top + offsetBase, 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.getScrollHeight()
    var maxScroll    = this.options.offset + scrollHeight - this.$scrollElement.height()
    var offsets      = this.offsets
    var targets      = this.targets
    var activeTarget = this.activeTarget
    var i

    if (this.scrollHeight != scrollHeight) {
      this.refresh()
Mark Otto's avatar
grunt    
Mark Otto committed
1763
1764
    }

XhmikosR's avatar
XhmikosR committed
1765
1766
1767
    if (scrollTop >= maxScroll) {
      return activeTarget != (i = targets[targets.length - 1]) && this.activate(i)
    }
1768

XhmikosR's avatar
XhmikosR committed
1769
1770
    if (activeTarget && scrollTop <= offsets[0]) {
      return activeTarget != (i = targets[0]) && this.activate(i)
Chris Rebert's avatar
Chris Rebert committed
1771
    }
1772

XhmikosR's avatar
XhmikosR committed
1773
1774
1775
1776
1777
1778
1779
    for (i = offsets.length; i--;) {
      activeTarget != targets[i]
        && scrollTop >= offsets[i]
        && (!offsets[i + 1] || scrollTop <= offsets[i + 1])
        && this.activate(targets[i])
    }
  }
1780

XhmikosR's avatar
XhmikosR committed
1781
1782
  ScrollSpy.prototype.activate = function (target) {
    this.activeTarget = target
1783

XhmikosR's avatar
XhmikosR committed
1784
1785
1786
    $(this.selector)
      .parentsUntil(this.options.target, '.active')
      .removeClass('active')
1787

XhmikosR's avatar
XhmikosR committed
1788
1789
1790
    var selector = this.selector +
        '[data-target="' + target + '"],' +
        this.selector + '[href="' + target + '"]'
1791

XhmikosR's avatar
XhmikosR committed
1792
1793
1794
    var active = $(selector)
      .parents('li')
      .addClass('active')
1795

XhmikosR's avatar
XhmikosR committed
1796
1797
1798
1799
    if (active.parent('.dropdown-menu').length) {
      active = active
        .closest('li.dropdown')
        .addClass('active')
Chris Rebert's avatar
Chris Rebert committed
1800
    }
1801

XhmikosR's avatar
XhmikosR committed
1802
1803
    active.trigger('activate.bs.scrollspy')
  }
1804
1805


XhmikosR's avatar
XhmikosR committed
1806
1807
  // SCROLLSPY PLUGIN DEFINITION
  // ===========================
1808

XhmikosR's avatar
XhmikosR committed
1809
1810
1811
1812
1813
  function Plugin(option) {
    return this.each(function () {
      var $this   = $(this)
      var data    = $this.data('bs.scrollspy')
      var options = typeof option == 'object' && option
Mark Otto's avatar
Mark Otto committed
1814

XhmikosR's avatar
XhmikosR committed
1815
1816
1817
1818
      if (!data) $this.data('bs.scrollspy', (data = new ScrollSpy(this, options)))
      if (typeof option == 'string') data[option]()
    })
  }
1819

XhmikosR's avatar
XhmikosR committed
1820
  var old = $.fn.scrollspy
1821

XhmikosR's avatar
XhmikosR committed
1822
1823
  $.fn.scrollspy             = Plugin
  $.fn.scrollspy.Constructor = ScrollSpy
1824

1825

XhmikosR's avatar
XhmikosR committed
1826
1827
  // SCROLLSPY NO CONFLICT
  // =====================
1828

XhmikosR's avatar
XhmikosR committed
1829
1830
1831
1832
  $.fn.scrollspy.noConflict = function () {
    $.fn.scrollspy = old
    return this
  }
1833

Chris Rebert's avatar
Chris Rebert committed
1834

XhmikosR's avatar
XhmikosR committed
1835
1836
  // SCROLLSPY DATA-API
  // ==================
Chris Rebert's avatar
Chris Rebert committed
1837

XhmikosR's avatar
XhmikosR committed
1838
1839
1840
1841
1842
  $(window).on('load.bs.scrollspy.data-api', function () {
    $('[data-spy="scroll"]').each(function () {
      var $spy = $(this)
      Plugin.call($spy, $spy.data())
    })
1843
  })
1844

XhmikosR's avatar
XhmikosR committed
1845
}(jQuery);
1846

1847
/* ========================================================================
Mark Otto's avatar
Mark Otto committed
1848
 * Bootstrap: tab.js v3.2.0
Mark Otto's avatar
Mark Otto committed
1849
 * http://getbootstrap.com/javascript/#tabs
1850
 * ========================================================================
1851
 * Copyright 2011-2014 Twitter, Inc.
1852
 * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
1853
 * ======================================================================== */
1854

1855

XhmikosR's avatar
XhmikosR committed
1856
1857
+function ($) {
  'use strict';
Mark Otto's avatar
grunt    
Mark Otto committed
1858

XhmikosR's avatar
XhmikosR committed
1859
1860
  // TAB CLASS DEFINITION
  // ====================
1861

XhmikosR's avatar
XhmikosR committed
1862
1863
1864
  var Tab = function (element) {
    this.element = $(element)
  }
1865

Mark Otto's avatar
Mark Otto committed
1866
  Tab.VERSION = '3.2.0'
Mark Otto's avatar
grunt    
Mark Otto committed
1867

XhmikosR's avatar
XhmikosR committed
1868
1869
1870
1871
  Tab.prototype.show = function () {
    var $this    = this.element
    var $ul      = $this.closest('ul:not(.dropdown-menu)')
    var selector = $this.data('target')
1872

XhmikosR's avatar
XhmikosR committed
1873
1874
1875
1876
    if (!selector) {
      selector = $this.attr('href')
      selector = selector && selector.replace(/.*(?=#[^\s]*$)/, '') // strip for ie7
    }
1877

XhmikosR's avatar
XhmikosR committed
1878
    if ($this.parent('li').hasClass('active')) return
1879

XhmikosR's avatar
XhmikosR committed
1880
1881
1882
1883
    var previous = $ul.find('.active:last a')[0]
    var e        = $.Event('show.bs.tab', {
      relatedTarget: previous
    })
1884

XhmikosR's avatar
XhmikosR committed
1885
    $this.trigger(e)
1886

XhmikosR's avatar
XhmikosR committed
1887
    if (e.isDefaultPrevented()) return
1888

XhmikosR's avatar
XhmikosR committed
1889
    var $target = $(selector)
1890

XhmikosR's avatar
XhmikosR committed
1891
1892
1893
1894
1895
    this.activate($this.closest('li'), $ul)
    this.activate($target, $target.parent(), function () {
      $this.trigger({
        type: 'shown.bs.tab',
        relatedTarget: previous
1896
      })
XhmikosR's avatar
XhmikosR committed
1897
1898
    })
  }
1899

XhmikosR's avatar
XhmikosR committed
1900
1901
1902
1903
1904
  Tab.prototype.activate = function (element, container, callback) {
    var $active    = container.find('> .active')
    var transition = callback
      && $.support.transition
      && $active.hasClass('fade')
1905

XhmikosR's avatar
XhmikosR committed
1906
1907
1908
1909
1910
    function next() {
      $active
        .removeClass('active')
        .find('> .dropdown-menu > .active')
        .removeClass('active')
1911

XhmikosR's avatar
XhmikosR committed
1912
1913
1914
1915
1916
1917
1918
      element.addClass('active')

      if (transition) {
        element[0].offsetWidth // reflow for transition
        element.addClass('in')
      } else {
        element.removeClass('fade')
1919
      }
1920

XhmikosR's avatar
XhmikosR committed
1921
1922
1923
      if (element.parent('.dropdown-menu')) {
        element.closest('li.dropdown').addClass('active')
      }
fat's avatar
fat committed
1924

XhmikosR's avatar
XhmikosR committed
1925
      callback && callback()
1926
    }
fat's avatar
fat committed
1927

XhmikosR's avatar
XhmikosR committed
1928
1929
1930
1931
1932
    transition ?
      $active
        .one('bsTransitionEnd', next)
        .emulateTransitionEnd(150) :
      next()
1933

XhmikosR's avatar
XhmikosR committed
1934
1935
    $active.removeClass('in')
  }
1936
1937


XhmikosR's avatar
XhmikosR committed
1938
1939
  // TAB PLUGIN DEFINITION
  // =====================
fat's avatar
fat committed
1940

XhmikosR's avatar
XhmikosR committed
1941
1942
1943
1944
  function Plugin(option) {
    return this.each(function () {
      var $this = $(this)
      var data  = $this.data('bs.tab')
1945

XhmikosR's avatar
XhmikosR committed
1946
1947
1948
1949
      if (!data) $this.data('bs.tab', (data = new Tab(this)))
      if (typeof option == 'string') data[option]()
    })
  }
Mark Otto's avatar
Mark Otto committed
1950

XhmikosR's avatar
XhmikosR committed
1951
  var old = $.fn.tab
1952

XhmikosR's avatar
XhmikosR committed
1953
1954
  $.fn.tab             = Plugin
  $.fn.tab.Constructor = Tab
1955

1956

XhmikosR's avatar
XhmikosR committed
1957
1958
  // TAB NO CONFLICT
  // ===============
1959

XhmikosR's avatar
XhmikosR committed
1960
1961
1962
1963
  $.fn.tab.noConflict = function () {
    $.fn.tab = old
    return this
  }
1964
1965


XhmikosR's avatar
XhmikosR committed
1966
1967
1968
1969
1970
1971
  // TAB DATA-API
  // ============

  $(document).on('click.bs.tab.data-api', '[data-toggle="tab"], [data-toggle="pill"]', function (e) {
    e.preventDefault()
    Plugin.call($(this), 'show')
1972
1973
  })

XhmikosR's avatar
XhmikosR committed
1974
}(jQuery);
1975

1976
/* ========================================================================
Mark Otto's avatar
Mark Otto committed
1977
 * Bootstrap: affix.js v3.2.0
Mark Otto's avatar
Mark Otto committed
1978
 * http://getbootstrap.com/javascript/#affix
1979
 * ========================================================================
1980
 * Copyright 2011-2014 Twitter, Inc.
1981
 * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
1982
 * ======================================================================== */
Mark Otto's avatar
Mark Otto committed
1983
1984


XhmikosR's avatar
XhmikosR committed
1985
1986
+function ($) {
  'use strict';
Mark Otto's avatar
grunt    
Mark Otto committed
1987

XhmikosR's avatar
XhmikosR committed
1988
1989
  // AFFIX CLASS DEFINITION
  // ======================
Mark Otto's avatar
Mark Otto committed
1990

XhmikosR's avatar
XhmikosR committed
1991
1992
  var Affix = function (element, options) {
    this.options = $.extend({}, Affix.DEFAULTS, options)
Mark Otto's avatar
Mark Otto committed
1993

XhmikosR's avatar
XhmikosR committed
1994
1995
1996
    this.$target = $(this.options.target)
      .on('scroll.bs.affix.data-api', $.proxy(this.checkPosition, this))
      .on('click.bs.affix.data-api',  $.proxy(this.checkPositionWithEventLoop, this))
Chris Rebert's avatar
Chris Rebert committed
1997

XhmikosR's avatar
XhmikosR committed
1998
1999
2000
2001
    this.$element     = $(element)
    this.affixed      =
    this.unpin        =
    this.pinnedOffset = null
fat's avatar
fat committed
2002

XhmikosR's avatar
XhmikosR committed
2003
2004
    this.checkPosition()
  }
fat's avatar
fat committed
2005

Mark Otto's avatar
Mark Otto committed
2006
  Affix.VERSION  = '3.2.0'
2007

XhmikosR's avatar
XhmikosR committed
2008
  Affix.RESET    = 'affix affix-top affix-bottom'
Mark Otto's avatar
grunt    
Mark Otto committed
2009

XhmikosR's avatar
XhmikosR committed
2010
2011
2012
2013
  Affix.DEFAULTS = {
    offset: 0,
    target: window
  }
2014

XhmikosR's avatar
XhmikosR committed
2015
2016
2017
2018
2019
2020
2021
  Affix.prototype.getPinnedOffset = function () {
    if (this.pinnedOffset) return this.pinnedOffset
    this.$element.removeClass(Affix.RESET).addClass('affix')
    var scrollTop = this.$target.scrollTop()
    var position  = this.$element.offset()
    return (this.pinnedOffset = position.top - scrollTop)
  }
2022

XhmikosR's avatar
XhmikosR committed
2023
2024
2025
  Affix.prototype.checkPositionWithEventLoop = function () {
    setTimeout($.proxy(this.checkPosition, this), 1)
  }
fat's avatar
fat committed
2026

XhmikosR's avatar
XhmikosR committed
2027
2028
  Affix.prototype.checkPosition = function () {
    if (!this.$element.is(':visible')) return
2029

XhmikosR's avatar
XhmikosR committed
2030
2031
2032
2033
2034
2035
    var scrollHeight = $(document).height()
    var scrollTop    = this.$target.scrollTop()
    var position     = this.$element.offset()
    var offset       = this.options.offset
    var offsetTop    = offset.top
    var offsetBottom = offset.bottom
2036

XhmikosR's avatar
XhmikosR committed
2037
2038
2039
    if (typeof offset != 'object')         offsetBottom = offsetTop = offset
    if (typeof offsetTop == 'function')    offsetTop    = offset.top(this.$element)
    if (typeof offsetBottom == 'function') offsetBottom = offset.bottom(this.$element)
2040

XhmikosR's avatar
XhmikosR committed
2041
2042
2043
    var affix = this.unpin   != null && (scrollTop + this.unpin <= position.top) ? false :
                offsetBottom != null && (position.top + this.$element.height() >= scrollHeight - offsetBottom) ? 'bottom' :
                offsetTop    != null && (scrollTop <= offsetTop) ? 'top' : false
2044

XhmikosR's avatar
XhmikosR committed
2045
2046
    if (this.affixed === affix) return
    if (this.unpin != null) this.$element.css('top', '')
2047

XhmikosR's avatar
XhmikosR committed
2048
2049
    var affixType = 'affix' + (affix ? '-' + affix : '')
    var e         = $.Event(affixType + '.bs.affix')
2050

XhmikosR's avatar
XhmikosR committed
2051
    this.$element.trigger(e)
2052

XhmikosR's avatar
XhmikosR committed
2053
    if (e.isDefaultPrevented()) return
2054

XhmikosR's avatar
XhmikosR committed
2055
2056
    this.affixed = affix
    this.unpin = affix == 'bottom' ? this.getPinnedOffset() : null
2057

XhmikosR's avatar
XhmikosR committed
2058
2059
2060
    this.$element
      .removeClass(Affix.RESET)
      .addClass(affixType)
Mark Otto's avatar
grunt    
Mark Otto committed
2061
      .trigger(affixType.replace('affix', 'affixed') + '.bs.affix')
2062

XhmikosR's avatar
XhmikosR committed
2063
2064
2065
2066
    if (affix == 'bottom') {
      this.$element.offset({
        top: scrollHeight - this.$element.height() - offsetBottom
      })
2067
    }
XhmikosR's avatar
XhmikosR committed
2068
  }
Mark Otto's avatar
Mark Otto committed
2069

2070

XhmikosR's avatar
XhmikosR committed
2071
2072
  // AFFIX PLUGIN DEFINITION
  // =======================
2073

XhmikosR's avatar
XhmikosR committed
2074
2075
2076
2077
2078
  function Plugin(option) {
    return this.each(function () {
      var $this   = $(this)
      var data    = $this.data('bs.affix')
      var options = typeof option == 'object' && option
2079

XhmikosR's avatar
XhmikosR committed
2080
2081
2082
2083
      if (!data) $this.data('bs.affix', (data = new Affix(this, options)))
      if (typeof option == 'string') data[option]()
    })
  }
2084

XhmikosR's avatar
XhmikosR committed
2085
  var old = $.fn.affix
Mark Otto's avatar
Mark Otto committed
2086

XhmikosR's avatar
XhmikosR committed
2087
2088
  $.fn.affix             = Plugin
  $.fn.affix.Constructor = Affix
2089
2090


XhmikosR's avatar
XhmikosR committed
2091
2092
  // AFFIX NO CONFLICT
  // =================
2093

XhmikosR's avatar
XhmikosR committed
2094
2095
2096
2097
  $.fn.affix.noConflict = function () {
    $.fn.affix = old
    return this
  }
2098
2099


XhmikosR's avatar
XhmikosR committed
2100
2101
  // AFFIX DATA-API
  // ==============
2102

XhmikosR's avatar
XhmikosR committed
2103
2104
2105
2106
  $(window).on('load', function () {
    $('[data-spy="affix"]').each(function () {
      var $spy = $(this)
      var data = $spy.data()
2107

XhmikosR's avatar
XhmikosR committed
2108
      data.offset = data.offset || {}
2109

XhmikosR's avatar
XhmikosR committed
2110
2111
      if (data.offsetBottom) data.offset.bottom = data.offsetBottom
      if (data.offsetTop)    data.offset.top    = data.offsetTop
2112

XhmikosR's avatar
XhmikosR committed
2113
      Plugin.call($spy, data)
2114
    })
Mark Otto's avatar
Mark Otto committed
2115
2116
  })

XhmikosR's avatar
XhmikosR committed
2117
}(jQuery);