bootstrap.js 61.4 KB
Newer Older
XhmikosR's avatar
XhmikosR committed
1001
  }
1002

XhmikosR's avatar
XhmikosR committed
1003
1004
1005
1006
  Modal.prototype.removeBackdrop = function () {
    this.$backdrop && this.$backdrop.remove()
    this.$backdrop = null
  }
1007

XhmikosR's avatar
XhmikosR committed
1008
1009
1010
  Modal.prototype.backdrop = function (callback) {
    var that = this
    var animate = this.$element.hasClass('fade') ? 'fade' : ''
1011

XhmikosR's avatar
XhmikosR committed
1012
1013
    if (this.isShown && this.options.backdrop) {
      var doAnimate = $.support.transition && animate
1014

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

Heinrich Fenkart's avatar
grunt    
Heinrich Fenkart committed
1018
      this.$element.on('click.dismiss.bs.modal', $.proxy(function (e) {
XhmikosR's avatar
XhmikosR committed
1019
1020
1021
1022
1023
        if (e.target !== e.currentTarget) return
        this.options.backdrop == 'static'
          ? this.$element[0].focus.call(this.$element[0])
          : this.hide.call(this)
      }, this))
1024

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

XhmikosR's avatar
XhmikosR committed
1027
      this.$backdrop.addClass('in')
1028

XhmikosR's avatar
XhmikosR committed
1029
      if (!callback) return
1030

XhmikosR's avatar
XhmikosR committed
1031
1032
1033
      doAnimate ?
        this.$backdrop
          .one('bsTransitionEnd', callback)
1034
          .emulateTransitionEnd(Modal.BACKDROP_TRANSITION_DURATION) :
XhmikosR's avatar
XhmikosR committed
1035
        callback()
1036

XhmikosR's avatar
XhmikosR committed
1037
1038
    } else if (!this.isShown && this.$backdrop) {
      this.$backdrop.removeClass('in')
Chris Rebert's avatar
Chris Rebert committed
1039

XhmikosR's avatar
XhmikosR committed
1040
1041
1042
      var callbackRemove = function () {
        that.removeBackdrop()
        callback && callback()
Chris Rebert's avatar
Chris Rebert committed
1043
      }
XhmikosR's avatar
XhmikosR committed
1044
1045
1046
      $.support.transition && this.$element.hasClass('fade') ?
        this.$backdrop
          .one('bsTransitionEnd', callbackRemove)
1047
          .emulateTransitionEnd(Modal.BACKDROP_TRANSITION_DURATION) :
XhmikosR's avatar
XhmikosR committed
1048
        callbackRemove()
1049

XhmikosR's avatar
XhmikosR committed
1050
1051
    } else if (callback) {
      callback()
Chris Rebert's avatar
Chris Rebert committed
1052
    }
XhmikosR's avatar
XhmikosR committed
1053
  }
1054

XhmikosR's avatar
XhmikosR committed
1055
  Modal.prototype.checkScrollbar = function () {
Mark Otto's avatar
grunt    
Mark Otto committed
1056
    this.scrollbarWidth = this.measureScrollbar()
XhmikosR's avatar
XhmikosR committed
1057
  }
fat's avatar
build    
fat committed
1058

XhmikosR's avatar
XhmikosR committed
1059
1060
1061
1062
  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
1063

XhmikosR's avatar
XhmikosR committed
1064
1065
1066
  Modal.prototype.resetScrollbar = function () {
    this.$body.css('padding-right', '')
  }
fat's avatar
build    
fat committed
1067

XhmikosR's avatar
XhmikosR committed
1068
  Modal.prototype.measureScrollbar = function () { // thx walsh
Mark Otto's avatar
grunt    
Mark Otto committed
1069
    if (document.body.clientWidth >= window.innerWidth) return 0
XhmikosR's avatar
XhmikosR committed
1070
1071
1072
1073
1074
1075
1076
    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
  }
1077
1078


XhmikosR's avatar
XhmikosR committed
1079
1080
  // MODAL PLUGIN DEFINITION
  // =======================
fat's avatar
fat committed
1081

XhmikosR's avatar
XhmikosR committed
1082
1083
1084
1085
1086
1087
1088
1089
1090
1091
1092
  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)
    })
  }
1093

XhmikosR's avatar
XhmikosR committed
1094
  var old = $.fn.modal
Mark Otto's avatar
Mark Otto committed
1095

XhmikosR's avatar
XhmikosR committed
1096
1097
  $.fn.modal             = Plugin
  $.fn.modal.Constructor = Modal
1098
1099


XhmikosR's avatar
XhmikosR committed
1100
1101
  // MODAL NO CONFLICT
  // =================
1102

XhmikosR's avatar
XhmikosR committed
1103
1104
1105
1106
  $.fn.modal.noConflict = function () {
    $.fn.modal = old
    return this
  }
1107
1108


XhmikosR's avatar
XhmikosR committed
1109
1110
  // MODAL DATA-API
  // ==============
1111

XhmikosR's avatar
XhmikosR committed
1112
1113
1114
1115
1116
  $(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())
1117

XhmikosR's avatar
XhmikosR committed
1118
    if ($this.is('a')) e.preventDefault()
1119

XhmikosR's avatar
XhmikosR committed
1120
1121
1122
1123
    $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
1124
      })
Mark Otto's avatar
Mark Otto committed
1125
    })
XhmikosR's avatar
XhmikosR committed
1126
    Plugin.call($target, option, this)
Jacob Thornton's avatar
Jacob Thornton committed
1127
  })
1128

XhmikosR's avatar
XhmikosR committed
1129
}(jQuery);
1130

1131
/* ========================================================================
Mark Otto's avatar
Mark Otto committed
1132
 * Bootstrap: tooltip.js v3.2.0
Mark Otto's avatar
Mark Otto committed
1133
 * http://getbootstrap.com/javascript/#tooltip
1134
 * Inspired by the original jQuery.tipsy by Jason Frame
1135
 * ========================================================================
1136
 * Copyright 2011-2014 Twitter, Inc.
1137
 * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
1138
 * ======================================================================== */
1139
1140


XhmikosR's avatar
XhmikosR committed
1141
1142
1143
1144
1145
1146
1147
1148
1149
1150
1151
1152
1153
1154
1155
1156
1157
+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
1158
  Tooltip.VERSION  = '3.2.0'
XhmikosR's avatar
XhmikosR committed
1159

1160
1161
  Tooltip.TRANSITION_DURATION = 150

XhmikosR's avatar
XhmikosR committed
1162
1163
1164
1165
1166
1167
1168
1169
1170
1171
1172
1173
1174
1175
1176
1177
1178
1179
1180
1181
1182
1183
1184
1185
1186
1187
1188
1189
1190
1191
1192
1193
1194
1195
1196
1197
1198
1199
  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))
      }
    }
1200

XhmikosR's avatar
XhmikosR committed
1201
1202
1203
1204
    this.options.selector ?
      (this._options = $.extend({}, this.options, { trigger: 'manual', selector: '' })) :
      this.fixTitle()
  }
1205

XhmikosR's avatar
XhmikosR committed
1206
1207
1208
  Tooltip.prototype.getDefaults = function () {
    return Tooltip.DEFAULTS
  }
1209

XhmikosR's avatar
XhmikosR committed
1210
1211
  Tooltip.prototype.getOptions = function (options) {
    options = $.extend({}, this.getDefaults(), this.$element.data(), options)
1212

XhmikosR's avatar
XhmikosR committed
1213
1214
1215
1216
    if (options.delay && typeof options.delay == 'number') {
      options.delay = {
        show: options.delay,
        hide: options.delay
1217
1218
      }
    }
1219

XhmikosR's avatar
XhmikosR committed
1220
1221
    return options
  }
Jacob Thornton's avatar
Jacob Thornton committed
1222

XhmikosR's avatar
XhmikosR committed
1223
1224
1225
  Tooltip.prototype.getDelegateOptions = function () {
    var options  = {}
    var defaults = this.getDefaults()
1226

XhmikosR's avatar
XhmikosR committed
1227
1228
1229
    this._options && $.each(this._options, function (key, value) {
      if (defaults[key] != value) options[key] = value
    })
fat's avatar
rebuild    
fat committed
1230

XhmikosR's avatar
XhmikosR committed
1231
1232
    return options
  }
Jacob Thornton's avatar
Jacob Thornton committed
1233

XhmikosR's avatar
XhmikosR committed
1234
1235
1236
  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
1237

XhmikosR's avatar
XhmikosR committed
1238
1239
1240
1241
1242
    if (self && self.$tip && self.$tip.is(':visible')) {
      self.hoverState = 'in'
      return
    }

XhmikosR's avatar
XhmikosR committed
1243
1244
1245
    if (!self) {
      self = new this.constructor(obj.currentTarget, this.getDelegateOptions())
      $(obj.currentTarget).data('bs.' + this.type, self)
Mark Otto's avatar
Mark Otto committed
1246
    }
1247

XhmikosR's avatar
XhmikosR committed
1248
    clearTimeout(self.timeout)
1249

XhmikosR's avatar
XhmikosR committed
1250
    self.hoverState = 'in'
1251

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

XhmikosR's avatar
XhmikosR committed
1254
1255
1256
1257
    self.timeout = setTimeout(function () {
      if (self.hoverState == 'in') self.show()
    }, self.options.delay.show)
  }
1258

XhmikosR's avatar
XhmikosR committed
1259
1260
1261
  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
1262

XhmikosR's avatar
XhmikosR committed
1263
1264
1265
    if (!self) {
      self = new this.constructor(obj.currentTarget, this.getDelegateOptions())
      $(obj.currentTarget).data('bs.' + this.type, self)
Mark Otto's avatar
Mark Otto committed
1266
    }
1267

XhmikosR's avatar
XhmikosR committed
1268
    clearTimeout(self.timeout)
fat's avatar
fat committed
1269

XhmikosR's avatar
XhmikosR committed
1270
    self.hoverState = 'out'
1271

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

XhmikosR's avatar
XhmikosR committed
1274
1275
1276
1277
    self.timeout = setTimeout(function () {
      if (self.hoverState == 'out') self.hide()
    }, self.options.delay.hide)
  }
1278

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

XhmikosR's avatar
XhmikosR committed
1282
1283
    if (this.hasContent() && this.enabled) {
      this.$element.trigger(e)
fat's avatar
fat committed
1284

XhmikosR's avatar
XhmikosR committed
1285
1286
1287
      var inDom = $.contains(document.documentElement, this.$element[0])
      if (e.isDefaultPrevented() || !inDom) return
      var that = this
1288

XhmikosR's avatar
XhmikosR committed
1289
      var $tip = this.tip()
fat's avatar
fat committed
1290

XhmikosR's avatar
XhmikosR committed
1291
      var tipId = this.getUID(this.type)
fat's avatar
fat committed
1292

XhmikosR's avatar
XhmikosR committed
1293
1294
1295
      this.setContent()
      $tip.attr('id', tipId)
      this.$element.attr('aria-describedby', tipId)
1296

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

XhmikosR's avatar
XhmikosR committed
1299
1300
1301
      var placement = typeof this.options.placement == 'function' ?
        this.options.placement.call(this, $tip[0], this.$element[0]) :
        this.options.placement
1302

XhmikosR's avatar
XhmikosR committed
1303
1304
1305
      var autoToken = /\s?auto?\s?/i
      var autoPlace = autoToken.test(placement)
      if (autoPlace) placement = placement.replace(autoToken, '') || 'top'
1306

XhmikosR's avatar
XhmikosR committed
1307
1308
1309
1310
1311
      $tip
        .detach()
        .css({ top: 0, left: 0, display: 'block' })
        .addClass(placement)
        .data('bs.' + this.type, this)
fat's avatar
fat committed
1312

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

XhmikosR's avatar
XhmikosR committed
1315
1316
1317
      var pos          = this.getPosition()
      var actualWidth  = $tip[0].offsetWidth
      var actualHeight = $tip[0].offsetHeight
Chris Rebert's avatar
Chris Rebert committed
1318

XhmikosR's avatar
XhmikosR committed
1319
1320
1321
1322
      if (autoPlace) {
        var orgPlacement = placement
        var $parent      = this.$element.parent()
        var parentDim    = this.getPosition($parent)
Chris Rebert's avatar
Chris Rebert committed
1323

XhmikosR's avatar
XhmikosR committed
1324
1325
1326
1327
1328
        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
1329

1330
        $tip
XhmikosR's avatar
XhmikosR committed
1331
          .removeClass(orgPlacement)
1332
          .addClass(placement)
XhmikosR's avatar
XhmikosR committed
1333
      }
1334

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

XhmikosR's avatar
XhmikosR committed
1337
      this.applyPlacement(calculatedOffset, placement)
fat's avatar
fat committed
1338

XhmikosR's avatar
XhmikosR committed
1339
1340
1341
1342
      var complete = function () {
        that.$element.trigger('shown.bs.' + that.type)
        that.hoverState = null
      }
fat's avatar
fat committed
1343

XhmikosR's avatar
XhmikosR committed
1344
1345
1346
      $.support.transition && this.$tip.hasClass('fade') ?
        $tip
          .one('bsTransitionEnd', complete)
1347
          .emulateTransitionEnd(Tooltip.TRANSITION_DURATION) :
XhmikosR's avatar
XhmikosR committed
1348
1349
1350
        complete()
    }
  }
fat's avatar
fat committed
1351

XhmikosR's avatar
XhmikosR committed
1352
1353
1354
1355
  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
1356

XhmikosR's avatar
XhmikosR committed
1357
1358
1359
    // 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
1360

XhmikosR's avatar
XhmikosR committed
1361
1362
1363
    // we must check for NaN for ie 8/9
    if (isNaN(marginTop))  marginTop  = 0
    if (isNaN(marginLeft)) marginLeft = 0
fat's avatar
fat committed
1364

XhmikosR's avatar
XhmikosR committed
1365
1366
    offset.top  = offset.top  + marginTop
    offset.left = offset.left + marginLeft
fat's avatar
fat committed
1367

XhmikosR's avatar
XhmikosR committed
1368
1369
1370
1371
1372
1373
1374
1375
    // $.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)
        })
1376
      }
XhmikosR's avatar
XhmikosR committed
1377
    }, offset), 0)
1378

XhmikosR's avatar
XhmikosR committed
1379
    $tip.addClass('in')
fat's avatar
fat committed
1380

XhmikosR's avatar
XhmikosR committed
1381
1382
1383
    // 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
1384

XhmikosR's avatar
XhmikosR committed
1385
1386
1387
    if (placement == 'top' && actualHeight != height) {
      offset.top = offset.top + height - actualHeight
    }
fat's avatar
fat committed
1388

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

XhmikosR's avatar
XhmikosR committed
1391
1392
    if (delta.left) offset.left += delta.left
    else offset.top += delta.top
1393

XhmikosR's avatar
XhmikosR committed
1394
1395
1396
    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'
1397

XhmikosR's avatar
XhmikosR committed
1398
1399
1400
    $tip.offset(offset)
    this.replaceArrow(arrowDelta, $tip[0][arrowOffsetPosition], arrowPosition)
  }
1401

XhmikosR's avatar
XhmikosR committed
1402
1403
1404
  Tooltip.prototype.replaceArrow = function (delta, dimension, position) {
    this.arrow().css(position, delta ? (50 * (1 - delta / dimension) + '%') : '')
  }
1405

XhmikosR's avatar
XhmikosR committed
1406
1407
1408
  Tooltip.prototype.setContent = function () {
    var $tip  = this.tip()
    var title = this.getTitle()
1409

XhmikosR's avatar
XhmikosR committed
1410
1411
1412
    $tip.find('.tooltip-inner')[this.options.html ? 'html' : 'text'](title)
    $tip.removeClass('fade in top bottom left right')
  }
1413

XhmikosR's avatar
XhmikosR committed
1414
1415
1416
1417
  Tooltip.prototype.hide = function () {
    var that = this
    var $tip = this.tip()
    var e    = $.Event('hide.bs.' + this.type)
1418

XhmikosR's avatar
XhmikosR committed
1419
1420
    function complete() {
      if (that.hoverState != 'in') $tip.detach()
Heinrich Fenkart's avatar
Heinrich Fenkart committed
1421
1422
1423
      that.$element
        .removeAttr('aria-describedby')
        .trigger('hidden.bs.' + that.type)
XhmikosR's avatar
XhmikosR committed
1424
    }
Jacob Thornton's avatar
Jacob Thornton committed
1425

XhmikosR's avatar
XhmikosR committed
1426
    this.$element.trigger(e)
1427

XhmikosR's avatar
XhmikosR committed
1428
    if (e.isDefaultPrevented()) return
1429

XhmikosR's avatar
XhmikosR committed
1430
    $tip.removeClass('in')
1431

XhmikosR's avatar
XhmikosR committed
1432
1433
1434
    $.support.transition && this.$tip.hasClass('fade') ?
      $tip
        .one('bsTransitionEnd', complete)
1435
        .emulateTransitionEnd(Tooltip.TRANSITION_DURATION) :
XhmikosR's avatar
XhmikosR committed
1436
      complete()
1437

XhmikosR's avatar
XhmikosR committed
1438
    this.hoverState = null
1439

XhmikosR's avatar
XhmikosR committed
1440
1441
    return this
  }
1442

XhmikosR's avatar
XhmikosR committed
1443
1444
1445
1446
  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', '')
1447
    }
XhmikosR's avatar
XhmikosR committed
1448
  }
1449

XhmikosR's avatar
XhmikosR committed
1450
1451
1452
  Tooltip.prototype.hasContent = function () {
    return this.getTitle()
  }
1453

XhmikosR's avatar
XhmikosR committed
1454
1455
  Tooltip.prototype.getPosition = function ($element) {
    $element   = $element || this.$element
Mark Otto's avatar
grunt    
Mark Otto committed
1456

XhmikosR's avatar
XhmikosR committed
1457
1458
    var el     = $element[0]
    var isBody = el.tagName == 'BODY'
Mark Otto's avatar
grunt    
Mark Otto committed
1459
1460
    var isSvg  = window.SVGElement && el instanceof window.SVGElement

Mark Otto's avatar
grunt    
Mark Otto committed
1461
    var elRect    = el.getBoundingClientRect()
Mark Otto's avatar
grunt    
Mark Otto committed
1462
1463
    var elOffset  = isBody ? { top: 0, left: 0 } : $element.offset()
    var scroll    = { scroll: isBody ? document.documentElement.scrollTop || document.body.scrollTop : $element.scrollTop() }
Chris Rebert's avatar
Chris Rebert committed
1464
    var outerDims = isSvg ? {} : {
XhmikosR's avatar
XhmikosR committed
1465
1466
      width:  isBody ? $(window).width()  : $element.outerWidth(),
      height: isBody ? $(window).height() : $element.outerHeight()
Chris Rebert's avatar
Chris Rebert committed
1467
    }
Mark Otto's avatar
grunt    
Mark Otto committed
1468
1469

    return $.extend({}, elRect, scroll, outerDims, elOffset)
XhmikosR's avatar
XhmikosR committed
1470
  }
1471

XhmikosR's avatar
XhmikosR committed
1472
1473
1474
1475
1476
  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   }
1477

XhmikosR's avatar
XhmikosR committed
1478
  }
1479

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

XhmikosR's avatar
XhmikosR committed
1484
1485
    var viewportPadding = this.options.viewport && this.options.viewport.padding || 0
    var viewportDimensions = this.getPosition(this.$viewport)
1486

XhmikosR's avatar
XhmikosR committed
1487
1488
1489
1490
1491
1492
1493
1494
1495
1496
1497
1498
1499
1500
1501
    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
1502
      }
Chris Rebert's avatar
Chris Rebert committed
1503
    }
fat's avatar
fat committed
1504

XhmikosR's avatar
XhmikosR committed
1505
1506
    return delta
  }
1507

XhmikosR's avatar
XhmikosR committed
1508
1509
1510
1511
  Tooltip.prototype.getTitle = function () {
    var title
    var $e = this.$element
    var o  = this.options
1512

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

XhmikosR's avatar
XhmikosR committed
1516
1517
    return title
  }
1518

XhmikosR's avatar
XhmikosR committed
1519
1520
1521
1522
1523
  Tooltip.prototype.getUID = function (prefix) {
    do prefix += ~~(Math.random() * 1000000)
    while (document.getElementById(prefix))
    return prefix
  }
1524

XhmikosR's avatar
XhmikosR committed
1525
1526
1527
  Tooltip.prototype.tip = function () {
    return (this.$tip = this.$tip || $(this.options.template))
  }
1528

XhmikosR's avatar
XhmikosR committed
1529
1530
1531
  Tooltip.prototype.arrow = function () {
    return (this.$arrow = this.$arrow || this.tip().find('.tooltip-arrow'))
  }
1532

XhmikosR's avatar
XhmikosR committed
1533
1534
1535
1536
1537
  Tooltip.prototype.validate = function () {
    if (!this.$element[0].parentNode) {
      this.hide()
      this.$element = null
      this.options  = null
Chris Rebert's avatar
Chris Rebert committed
1538
    }
XhmikosR's avatar
XhmikosR committed
1539
  }
1540

XhmikosR's avatar
XhmikosR committed
1541
1542
1543
  Tooltip.prototype.enable = function () {
    this.enabled = true
  }
1544

XhmikosR's avatar
XhmikosR committed
1545
1546
1547
  Tooltip.prototype.disable = function () {
    this.enabled = false
  }
Mark Otto's avatar
Mark Otto committed
1548

XhmikosR's avatar
XhmikosR committed
1549
1550
1551
  Tooltip.prototype.toggleEnabled = function () {
    this.enabled = !this.enabled
  }
Chris Rebert's avatar
Chris Rebert committed
1552

XhmikosR's avatar
XhmikosR committed
1553
1554
1555
1556
1557
1558
1559
1560
  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
1561
1562
    }

XhmikosR's avatar
XhmikosR committed
1563
1564
    self.tip().hasClass('in') ? self.leave(self) : self.enter(self)
  }
1565

XhmikosR's avatar
XhmikosR committed
1566
1567
1568
1569
  Tooltip.prototype.destroy = function () {
    clearTimeout(this.timeout)
    this.hide().$element.off('.' + this.type).removeData('bs.' + this.type)
  }
1570
1571


XhmikosR's avatar
XhmikosR committed
1572
1573
  // TOOLTIP PLUGIN DEFINITION
  // =========================
1574

XhmikosR's avatar
XhmikosR committed
1575
1576
1577
1578
1579
  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
1580

XhmikosR's avatar
XhmikosR committed
1581
1582
1583
1584
1585
      if (!data && option == 'destroy') return
      if (!data) $this.data('bs.tooltip', (data = new Tooltip(this, options)))
      if (typeof option == 'string') data[option]()
    })
  }
1586

XhmikosR's avatar
XhmikosR committed
1587
  var old = $.fn.tooltip
Mark Otto's avatar
Mark Otto committed
1588

XhmikosR's avatar
XhmikosR committed
1589
1590
  $.fn.tooltip             = Plugin
  $.fn.tooltip.Constructor = Tooltip
1591

1592

XhmikosR's avatar
XhmikosR committed
1593
1594
  // TOOLTIP NO CONFLICT
  // ===================
1595

XhmikosR's avatar
XhmikosR committed
1596
1597
1598
1599
  $.fn.tooltip.noConflict = function () {
    $.fn.tooltip = old
    return this
  }
1600

XhmikosR's avatar
XhmikosR committed
1601
}(jQuery);
1602

1603
/* ========================================================================
Mark Otto's avatar
Mark Otto committed
1604
 * Bootstrap: popover.js v3.2.0
Mark Otto's avatar
Mark Otto committed
1605
 * http://getbootstrap.com/javascript/#popovers
1606
 * ========================================================================
1607
 * Copyright 2011-2014 Twitter, Inc.
1608
 * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
1609
 * ======================================================================== */
1610
1611


XhmikosR's avatar
XhmikosR committed
1612
1613
+function ($) {
  'use strict';
Mark Otto's avatar
grunt    
Mark Otto committed
1614

XhmikosR's avatar
XhmikosR committed
1615
1616
  // POPOVER PUBLIC CLASS DEFINITION
  // ===============================
1617

XhmikosR's avatar
XhmikosR committed
1618
1619
1620
  var Popover = function (element, options) {
    this.init('popover', element, options)
  }
fat's avatar
fat committed
1621

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

Mark Otto's avatar
Mark Otto committed
1624
  Popover.VERSION  = '3.2.0'
1625

XhmikosR's avatar
XhmikosR committed
1626
1627
1628
1629
1630
1631
  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
1632
1633


XhmikosR's avatar
XhmikosR committed
1634
1635
  // NOTE: POPOVER EXTENDS tooltip.js
  // ================================
1636

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

XhmikosR's avatar
XhmikosR committed
1639
  Popover.prototype.constructor = Popover
1640

XhmikosR's avatar
XhmikosR committed
1641
1642
1643
  Popover.prototype.getDefaults = function () {
    return Popover.DEFAULTS
  }
1644

XhmikosR's avatar
XhmikosR committed
1645
1646
1647
1648
  Popover.prototype.setContent = function () {
    var $tip    = this.tip()
    var title   = this.getTitle()
    var content = this.getContent()
1649

XhmikosR's avatar
XhmikosR committed
1650
    $tip.find('.popover-title')[this.options.html ? 'html' : 'text'](title)
Mark Otto's avatar
grunt    
Mark Otto committed
1651
    $tip.find('.popover-content').children().detach().end()[ // we use append for html objects to maintain js events
XhmikosR's avatar
XhmikosR committed
1652
1653
      this.options.html ? (typeof content == 'string' ? 'html' : 'append') : 'text'
    ](content)
1654

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

XhmikosR's avatar
XhmikosR committed
1657
1658
1659
1660
    // 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()
  }
1661

XhmikosR's avatar
XhmikosR committed
1662
1663
1664
  Popover.prototype.hasContent = function () {
    return this.getTitle() || this.getContent()
  }
1665

XhmikosR's avatar
XhmikosR committed
1666
1667
1668
  Popover.prototype.getContent = function () {
    var $e = this.$element
    var o  = this.options
1669

XhmikosR's avatar
XhmikosR committed
1670
1671
1672
1673
1674
    return $e.attr('data-content')
      || (typeof o.content == 'function' ?
            o.content.call($e[0]) :
            o.content)
  }
fat's avatar
fat committed
1675

XhmikosR's avatar
XhmikosR committed
1676
1677
1678
  Popover.prototype.arrow = function () {
    return (this.$arrow = this.$arrow || this.tip().find('.arrow'))
  }
1679

XhmikosR's avatar
XhmikosR committed
1680
1681
1682
1683
  Popover.prototype.tip = function () {
    if (!this.$tip) this.$tip = $(this.options.template)
    return this.$tip
  }
1684

1685

XhmikosR's avatar
XhmikosR committed
1686
1687
  // POPOVER PLUGIN DEFINITION
  // =========================
1688

XhmikosR's avatar
XhmikosR committed
1689
1690
1691
1692
1693
  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
1694

XhmikosR's avatar
XhmikosR committed
1695
1696
1697
1698
1699
      if (!data && option == 'destroy') return
      if (!data) $this.data('bs.popover', (data = new Popover(this, options)))
      if (typeof option == 'string') data[option]()
    })
  }
1700

XhmikosR's avatar
XhmikosR committed
1701
  var old = $.fn.popover
Mark Otto's avatar
Mark Otto committed
1702

XhmikosR's avatar
XhmikosR committed
1703
1704
  $.fn.popover             = Plugin
  $.fn.popover.Constructor = Popover
fat's avatar
fat committed
1705

1706

XhmikosR's avatar
XhmikosR committed
1707
1708
  // POPOVER NO CONFLICT
  // ===================
1709

XhmikosR's avatar
XhmikosR committed
1710
1711
1712
1713
  $.fn.popover.noConflict = function () {
    $.fn.popover = old
    return this
  }
1714

XhmikosR's avatar
XhmikosR committed
1715
}(jQuery);
1716

1717
/* ========================================================================
Mark Otto's avatar
Mark Otto committed
1718
 * Bootstrap: scrollspy.js v3.2.0
Mark Otto's avatar
Mark Otto committed
1719
 * http://getbootstrap.com/javascript/#scrollspy
1720
 * ========================================================================
1721
 * Copyright 2011-2014 Twitter, Inc.
1722
 * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
1723
 * ======================================================================== */
1724
1725


XhmikosR's avatar
XhmikosR committed
1726
1727
+function ($) {
  'use strict';
1728

XhmikosR's avatar
XhmikosR committed
1729
1730
  // SCROLLSPY CLASS DEFINITION
  // ==========================
1731

XhmikosR's avatar
XhmikosR committed
1732
1733
  function ScrollSpy(element, options) {
    var process  = $.proxy(this.process, this)
1734

XhmikosR's avatar
XhmikosR committed
1735
1736
1737
1738
1739
1740
1741
1742
    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
1743

XhmikosR's avatar
XhmikosR committed
1744
1745
1746
1747
    this.$scrollElement.on('scroll.bs.scrollspy', process)
    this.refresh()
    this.process()
  }
1748

Mark Otto's avatar
Mark Otto committed
1749
  ScrollSpy.VERSION  = '3.2.0'
Mark Otto's avatar
grunt    
Mark Otto committed
1750

XhmikosR's avatar
XhmikosR committed
1751
1752
1753
  ScrollSpy.DEFAULTS = {
    offset: 10
  }
1754

XhmikosR's avatar
XhmikosR committed
1755
1756
1757
  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
1758

XhmikosR's avatar
XhmikosR committed
1759
1760
1761
  ScrollSpy.prototype.refresh = function () {
    var offsetMethod = 'offset'
    var offsetBase   = 0
Mark Otto's avatar
grunt    
Mark Otto committed
1762

XhmikosR's avatar
XhmikosR committed
1763
1764
1765
1766
    if (!$.isWindow(this.$scrollElement[0])) {
      offsetMethod = 'position'
      offsetBase   = this.$scrollElement.scrollTop()
    }
Mark Otto's avatar
grunt    
Mark Otto committed
1767

XhmikosR's avatar
XhmikosR committed
1768
1769
1770
    this.offsets = []
    this.targets = []
    this.scrollHeight = this.getScrollHeight()
fat's avatar
fat committed
1771

XhmikosR's avatar
XhmikosR committed
1772
    var self     = this
XhmikosR's avatar
XhmikosR committed
1773

XhmikosR's avatar
XhmikosR committed
1774
1775
1776
1777
1778
1779
    this.$body
      .find(this.selector)
      .map(function () {
        var $el   = $(this)
        var href  = $el.data('target') || $el.attr('href')
        var $href = /^#./.test(href) && $(href)
1780

XhmikosR's avatar
XhmikosR committed
1781
1782
1783
1784
1785
1786
1787
1788
1789
1790
1791
1792
1793
1794
1795
1796
1797
1798
1799
1800
1801
1802
1803
        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
1804
1805
    }

XhmikosR's avatar
XhmikosR committed
1806
1807
1808
    if (scrollTop >= maxScroll) {
      return activeTarget != (i = targets[targets.length - 1]) && this.activate(i)
    }
1809

XhmikosR's avatar
XhmikosR committed
1810
1811
    if (activeTarget && scrollTop <= offsets[0]) {
      return activeTarget != (i = targets[0]) && this.activate(i)
Chris Rebert's avatar
Chris Rebert committed
1812
    }
1813

XhmikosR's avatar
XhmikosR committed
1814
1815
1816
1817
1818
1819
1820
    for (i = offsets.length; i--;) {
      activeTarget != targets[i]
        && scrollTop >= offsets[i]
        && (!offsets[i + 1] || scrollTop <= offsets[i + 1])
        && this.activate(targets[i])
    }
  }
1821

XhmikosR's avatar
XhmikosR committed
1822
1823
  ScrollSpy.prototype.activate = function (target) {
    this.activeTarget = target
1824

XhmikosR's avatar
XhmikosR committed
1825
1826
1827
    $(this.selector)
      .parentsUntil(this.options.target, '.active')
      .removeClass('active')
1828

XhmikosR's avatar
XhmikosR committed
1829
1830
1831
    var selector = this.selector +
        '[data-target="' + target + '"],' +
        this.selector + '[href="' + target + '"]'
1832

XhmikosR's avatar
XhmikosR committed
1833
1834
1835
    var active = $(selector)
      .parents('li')
      .addClass('active')
1836

XhmikosR's avatar
XhmikosR committed
1837
1838
1839
1840
    if (active.parent('.dropdown-menu').length) {
      active = active
        .closest('li.dropdown')
        .addClass('active')
Chris Rebert's avatar
Chris Rebert committed
1841
    }
1842

XhmikosR's avatar
XhmikosR committed
1843
1844
    active.trigger('activate.bs.scrollspy')
  }
1845
1846


XhmikosR's avatar
XhmikosR committed
1847
1848
  // SCROLLSPY PLUGIN DEFINITION
  // ===========================
1849

XhmikosR's avatar
XhmikosR committed
1850
1851
1852
1853
1854
  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
1855

XhmikosR's avatar
XhmikosR committed
1856
1857
1858
1859
      if (!data) $this.data('bs.scrollspy', (data = new ScrollSpy(this, options)))
      if (typeof option == 'string') data[option]()
    })
  }
1860

XhmikosR's avatar
XhmikosR committed
1861
  var old = $.fn.scrollspy
1862

XhmikosR's avatar
XhmikosR committed
1863
1864
  $.fn.scrollspy             = Plugin
  $.fn.scrollspy.Constructor = ScrollSpy
1865

1866

XhmikosR's avatar
XhmikosR committed
1867
1868
  // SCROLLSPY NO CONFLICT
  // =====================
1869

XhmikosR's avatar
XhmikosR committed
1870
1871
1872
1873
  $.fn.scrollspy.noConflict = function () {
    $.fn.scrollspy = old
    return this
  }
1874

Chris Rebert's avatar
Chris Rebert committed
1875

XhmikosR's avatar
XhmikosR committed
1876
1877
  // SCROLLSPY DATA-API
  // ==================
Chris Rebert's avatar
Chris Rebert committed
1878

XhmikosR's avatar
XhmikosR committed
1879
1880
1881
1882
1883
  $(window).on('load.bs.scrollspy.data-api', function () {
    $('[data-spy="scroll"]').each(function () {
      var $spy = $(this)
      Plugin.call($spy, $spy.data())
    })
1884
  })
1885

XhmikosR's avatar
XhmikosR committed
1886
}(jQuery);
1887

1888
/* ========================================================================
Mark Otto's avatar
Mark Otto committed
1889
 * Bootstrap: tab.js v3.2.0
Mark Otto's avatar
Mark Otto committed
1890
 * http://getbootstrap.com/javascript/#tabs
1891
 * ========================================================================
1892
 * Copyright 2011-2014 Twitter, Inc.
1893
 * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
1894
 * ======================================================================== */
1895

1896

XhmikosR's avatar
XhmikosR committed
1897
1898
+function ($) {
  'use strict';
Mark Otto's avatar
grunt    
Mark Otto committed
1899

XhmikosR's avatar
XhmikosR committed
1900
1901
  // TAB CLASS DEFINITION
  // ====================
1902

XhmikosR's avatar
XhmikosR committed
1903
1904
1905
  var Tab = function (element) {
    this.element = $(element)
  }
1906

Mark Otto's avatar
Mark Otto committed
1907
  Tab.VERSION = '3.2.0'
Mark Otto's avatar
grunt    
Mark Otto committed
1908

1909
1910
  Tab.TRANSITION_DURATION = 150

XhmikosR's avatar
XhmikosR committed
1911
1912
1913
1914
  Tab.prototype.show = function () {
    var $this    = this.element
    var $ul      = $this.closest('ul:not(.dropdown-menu)')
    var selector = $this.data('target')
1915

XhmikosR's avatar
XhmikosR committed
1916
1917
1918
1919
    if (!selector) {
      selector = $this.attr('href')
      selector = selector && selector.replace(/.*(?=#[^\s]*$)/, '') // strip for ie7
    }
1920

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

XhmikosR's avatar
XhmikosR committed
1923
1924
1925
1926
    var previous = $ul.find('.active:last a')[0]
    var e        = $.Event('show.bs.tab', {
      relatedTarget: previous
    })
1927

XhmikosR's avatar
XhmikosR committed
1928
    $this.trigger(e)
1929

XhmikosR's avatar
XhmikosR committed
1930
    if (e.isDefaultPrevented()) return
1931

XhmikosR's avatar
XhmikosR committed
1932
    var $target = $(selector)
1933

XhmikosR's avatar
XhmikosR committed
1934
1935
1936
1937
1938
    this.activate($this.closest('li'), $ul)
    this.activate($target, $target.parent(), function () {
      $this.trigger({
        type: 'shown.bs.tab',
        relatedTarget: previous
1939
      })
XhmikosR's avatar
XhmikosR committed
1940
1941
    })
  }
1942

XhmikosR's avatar
XhmikosR committed
1943
1944
1945
1946
  Tab.prototype.activate = function (element, container, callback) {
    var $active    = container.find('> .active')
    var transition = callback
      && $.support.transition
Mark Otto's avatar
grunt    
Mark Otto committed
1947
      && (($active.length && $active.hasClass('fade')) || !!container.find('> .fade').length)
1948

XhmikosR's avatar
XhmikosR committed
1949
1950
1951
1952
1953
    function next() {
      $active
        .removeClass('active')
        .find('> .dropdown-menu > .active')
        .removeClass('active')
1954

XhmikosR's avatar
XhmikosR committed
1955
1956
1957
1958
1959
1960
1961
      element.addClass('active')

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

XhmikosR's avatar
XhmikosR committed
1964
1965
1966
      if (element.parent('.dropdown-menu')) {
        element.closest('li.dropdown').addClass('active')
      }
fat's avatar
fat committed
1967

XhmikosR's avatar
XhmikosR committed
1968
      callback && callback()
1969
    }
fat's avatar
fat committed
1970

Mark Otto's avatar
grunt    
Mark Otto committed
1971
    $active.length && transition ?
XhmikosR's avatar
XhmikosR committed
1972
1973
      $active
        .one('bsTransitionEnd', next)
1974
        .emulateTransitionEnd(Tab.TRANSITION_DURATION) :
XhmikosR's avatar
XhmikosR committed
1975
      next()
1976

XhmikosR's avatar
XhmikosR committed
1977
1978
    $active.removeClass('in')
  }
1979
1980


XhmikosR's avatar
XhmikosR committed
1981
1982
  // TAB PLUGIN DEFINITION
  // =====================
fat's avatar
fat committed
1983

XhmikosR's avatar
XhmikosR committed
1984
1985
1986
1987
  function Plugin(option) {
    return this.each(function () {
      var $this = $(this)
      var data  = $this.data('bs.tab')
1988

XhmikosR's avatar
XhmikosR committed
1989
1990
1991
1992
      if (!data) $this.data('bs.tab', (data = new Tab(this)))
      if (typeof option == 'string') data[option]()
    })
  }
Mark Otto's avatar
Mark Otto committed
1993

XhmikosR's avatar
XhmikosR committed
1994
  var old = $.fn.tab
1995

XhmikosR's avatar
XhmikosR committed
1996
1997
  $.fn.tab             = Plugin
  $.fn.tab.Constructor = Tab
1998

1999

XhmikosR's avatar
XhmikosR committed
2000
  // TAB NO CONFLICT
For faster browsing, not all history is shown. View entire blame