bootstrap.js 61.2 KB
Newer Older
XhmikosR's avatar
XhmikosR committed
1001
1002
1003
    this.$backdrop && this.$backdrop.remove()
    this.$backdrop = null
  }
1004

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

XhmikosR's avatar
XhmikosR committed
1009
1010
    if (this.isShown && this.options.backdrop) {
      var doAnimate = $.support.transition && animate
1011

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

Mark Otto's avatar
grunt    
Mark Otto committed
1015
      this.$element.on('mousedown.dismiss.bs.modal', $.proxy(function (e) {
XhmikosR's avatar
XhmikosR committed
1016
1017
1018
1019
1020
        if (e.target !== e.currentTarget) return
        this.options.backdrop == 'static'
          ? this.$element[0].focus.call(this.$element[0])
          : this.hide.call(this)
      }, this))
1021

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

XhmikosR's avatar
XhmikosR committed
1024
      this.$backdrop.addClass('in')
1025

XhmikosR's avatar
XhmikosR committed
1026
      if (!callback) return
1027

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

XhmikosR's avatar
XhmikosR committed
1034
1035
    } else if (!this.isShown && this.$backdrop) {
      this.$backdrop.removeClass('in')
Chris Rebert's avatar
Chris Rebert committed
1036

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

XhmikosR's avatar
XhmikosR committed
1047
1048
    } else if (callback) {
      callback()
Chris Rebert's avatar
Chris Rebert committed
1049
    }
XhmikosR's avatar
XhmikosR committed
1050
  }
1051

XhmikosR's avatar
XhmikosR committed
1052
1053
1054
1055
  Modal.prototype.checkScrollbar = function () {
    if (document.body.clientWidth >= window.innerWidth) return
    this.scrollbarWidth = this.scrollbarWidth || this.measureScrollbar()
  }
fat's avatar
build    
fat committed
1056

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

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

XhmikosR's avatar
XhmikosR committed
1066
1067
1068
1069
1070
1071
1072
1073
  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
  }
1074
1075


XhmikosR's avatar
XhmikosR committed
1076
1077
  // MODAL PLUGIN DEFINITION
  // =======================
fat's avatar
fat committed
1078

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

XhmikosR's avatar
XhmikosR committed
1091
  var old = $.fn.modal
Mark Otto's avatar
Mark Otto committed
1092

XhmikosR's avatar
XhmikosR committed
1093
1094
  $.fn.modal             = Plugin
  $.fn.modal.Constructor = Modal
1095
1096


XhmikosR's avatar
XhmikosR committed
1097
1098
  // MODAL NO CONFLICT
  // =================
1099

XhmikosR's avatar
XhmikosR committed
1100
1101
1102
1103
  $.fn.modal.noConflict = function () {
    $.fn.modal = old
    return this
  }
1104
1105


XhmikosR's avatar
XhmikosR committed
1106
1107
  // MODAL DATA-API
  // ==============
1108

XhmikosR's avatar
XhmikosR committed
1109
1110
1111
1112
1113
  $(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())
1114

XhmikosR's avatar
XhmikosR committed
1115
    if ($this.is('a')) e.preventDefault()
1116

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

XhmikosR's avatar
XhmikosR committed
1126
}(jQuery);
1127

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


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

1157
1158
  Tooltip.TRANSITION_DURATION = 150

XhmikosR's avatar
XhmikosR committed
1159
1160
1161
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
  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))
      }
    }
1197

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

XhmikosR's avatar
XhmikosR committed
1203
1204
1205
  Tooltip.prototype.getDefaults = function () {
    return Tooltip.DEFAULTS
  }
1206

XhmikosR's avatar
XhmikosR committed
1207
1208
  Tooltip.prototype.getOptions = function (options) {
    options = $.extend({}, this.getDefaults(), this.$element.data(), options)
1209

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

XhmikosR's avatar
XhmikosR committed
1217
1218
    return options
  }
Jacob Thornton's avatar
Jacob Thornton committed
1219

XhmikosR's avatar
XhmikosR committed
1220
1221
1222
  Tooltip.prototype.getDelegateOptions = function () {
    var options  = {}
    var defaults = this.getDefaults()
1223

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

XhmikosR's avatar
XhmikosR committed
1228
1229
    return options
  }
Jacob Thornton's avatar
Jacob Thornton committed
1230

XhmikosR's avatar
XhmikosR committed
1231
1232
1233
  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
1234

XhmikosR's avatar
XhmikosR committed
1235
1236
1237
    if (!self) {
      self = new this.constructor(obj.currentTarget, this.getDelegateOptions())
      $(obj.currentTarget).data('bs.' + this.type, self)
Mark Otto's avatar
Mark Otto committed
1238
    }
1239

XhmikosR's avatar
XhmikosR committed
1240
    clearTimeout(self.timeout)
1241

XhmikosR's avatar
XhmikosR committed
1242
    self.hoverState = 'in'
1243

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

XhmikosR's avatar
XhmikosR committed
1246
1247
1248
1249
    self.timeout = setTimeout(function () {
      if (self.hoverState == 'in') self.show()
    }, self.options.delay.show)
  }
1250

XhmikosR's avatar
XhmikosR committed
1251
1252
1253
  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
1254

XhmikosR's avatar
XhmikosR committed
1255
1256
1257
    if (!self) {
      self = new this.constructor(obj.currentTarget, this.getDelegateOptions())
      $(obj.currentTarget).data('bs.' + this.type, self)
Mark Otto's avatar
Mark Otto committed
1258
    }
1259

XhmikosR's avatar
XhmikosR committed
1260
    clearTimeout(self.timeout)
fat's avatar
fat committed
1261

XhmikosR's avatar
XhmikosR committed
1262
    self.hoverState = 'out'
1263

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

XhmikosR's avatar
XhmikosR committed
1266
1267
1268
1269
    self.timeout = setTimeout(function () {
      if (self.hoverState == 'out') self.hide()
    }, self.options.delay.hide)
  }
1270

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

XhmikosR's avatar
XhmikosR committed
1274
1275
    if (this.hasContent() && this.enabled) {
      this.$element.trigger(e)
fat's avatar
fat committed
1276

XhmikosR's avatar
XhmikosR committed
1277
1278
1279
      var inDom = $.contains(document.documentElement, this.$element[0])
      if (e.isDefaultPrevented() || !inDom) return
      var that = this
1280

XhmikosR's avatar
XhmikosR committed
1281
      var $tip = this.tip()
fat's avatar
fat committed
1282

XhmikosR's avatar
XhmikosR committed
1283
      var tipId = this.getUID(this.type)
fat's avatar
fat committed
1284

XhmikosR's avatar
XhmikosR committed
1285
1286
1287
      this.setContent()
      $tip.attr('id', tipId)
      this.$element.attr('aria-describedby', tipId)
1288

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

XhmikosR's avatar
XhmikosR committed
1291
1292
1293
      var placement = typeof this.options.placement == 'function' ?
        this.options.placement.call(this, $tip[0], this.$element[0]) :
        this.options.placement
1294

XhmikosR's avatar
XhmikosR committed
1295
1296
1297
      var autoToken = /\s?auto?\s?/i
      var autoPlace = autoToken.test(placement)
      if (autoPlace) placement = placement.replace(autoToken, '') || 'top'
1298

XhmikosR's avatar
XhmikosR committed
1299
1300
1301
1302
1303
      $tip
        .detach()
        .css({ top: 0, left: 0, display: 'block' })
        .addClass(placement)
        .data('bs.' + this.type, this)
fat's avatar
fat committed
1304

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

XhmikosR's avatar
XhmikosR committed
1307
1308
1309
      var pos          = this.getPosition()
      var actualWidth  = $tip[0].offsetWidth
      var actualHeight = $tip[0].offsetHeight
Chris Rebert's avatar
Chris Rebert committed
1310

XhmikosR's avatar
XhmikosR committed
1311
1312
1313
1314
      if (autoPlace) {
        var orgPlacement = placement
        var $parent      = this.$element.parent()
        var parentDim    = this.getPosition($parent)
Chris Rebert's avatar
Chris Rebert committed
1315

XhmikosR's avatar
XhmikosR committed
1316
1317
1318
1319
1320
        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
1321

1322
        $tip
XhmikosR's avatar
XhmikosR committed
1323
          .removeClass(orgPlacement)
1324
          .addClass(placement)
XhmikosR's avatar
XhmikosR committed
1325
      }
1326

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

XhmikosR's avatar
XhmikosR committed
1329
      this.applyPlacement(calculatedOffset, placement)
fat's avatar
fat committed
1330

XhmikosR's avatar
XhmikosR committed
1331
1332
1333
1334
      var complete = function () {
        that.$element.trigger('shown.bs.' + that.type)
        that.hoverState = null
      }
fat's avatar
fat committed
1335

XhmikosR's avatar
XhmikosR committed
1336
1337
1338
      $.support.transition && this.$tip.hasClass('fade') ?
        $tip
          .one('bsTransitionEnd', complete)
1339
          .emulateTransitionEnd(Tooltip.TRANSITION_DURATION) :
XhmikosR's avatar
XhmikosR committed
1340
1341
1342
        complete()
    }
  }
fat's avatar
fat committed
1343

XhmikosR's avatar
XhmikosR committed
1344
1345
1346
1347
  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
1348

XhmikosR's avatar
XhmikosR committed
1349
1350
1351
    // 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
1352

XhmikosR's avatar
XhmikosR committed
1353
1354
1355
    // we must check for NaN for ie 8/9
    if (isNaN(marginTop))  marginTop  = 0
    if (isNaN(marginLeft)) marginLeft = 0
fat's avatar
fat committed
1356

XhmikosR's avatar
XhmikosR committed
1357
1358
    offset.top  = offset.top  + marginTop
    offset.left = offset.left + marginLeft
fat's avatar
fat committed
1359

XhmikosR's avatar
XhmikosR committed
1360
1361
1362
1363
1364
1365
1366
1367
    // $.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)
        })
1368
      }
XhmikosR's avatar
XhmikosR committed
1369
    }, offset), 0)
1370

XhmikosR's avatar
XhmikosR committed
1371
    $tip.addClass('in')
fat's avatar
fat committed
1372

XhmikosR's avatar
XhmikosR committed
1373
1374
1375
    // 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
1376

XhmikosR's avatar
XhmikosR committed
1377
1378
1379
    if (placement == 'top' && actualHeight != height) {
      offset.top = offset.top + height - actualHeight
    }
fat's avatar
fat committed
1380

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

XhmikosR's avatar
XhmikosR committed
1383
1384
    if (delta.left) offset.left += delta.left
    else offset.top += delta.top
1385

XhmikosR's avatar
XhmikosR committed
1386
1387
1388
    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'
1389

XhmikosR's avatar
XhmikosR committed
1390
1391
1392
    $tip.offset(offset)
    this.replaceArrow(arrowDelta, $tip[0][arrowOffsetPosition], arrowPosition)
  }
1393

XhmikosR's avatar
XhmikosR committed
1394
1395
1396
  Tooltip.prototype.replaceArrow = function (delta, dimension, position) {
    this.arrow().css(position, delta ? (50 * (1 - delta / dimension) + '%') : '')
  }
1397

XhmikosR's avatar
XhmikosR committed
1398
1399
1400
  Tooltip.prototype.setContent = function () {
    var $tip  = this.tip()
    var title = this.getTitle()
1401

XhmikosR's avatar
XhmikosR committed
1402
1403
1404
    $tip.find('.tooltip-inner')[this.options.html ? 'html' : 'text'](title)
    $tip.removeClass('fade in top bottom left right')
  }
1405

XhmikosR's avatar
XhmikosR committed
1406
1407
1408
1409
  Tooltip.prototype.hide = function () {
    var that = this
    var $tip = this.tip()
    var e    = $.Event('hide.bs.' + this.type)
1410

XhmikosR's avatar
XhmikosR committed
1411
    this.$element.removeAttr('aria-describedby')
1412

XhmikosR's avatar
XhmikosR committed
1413
1414
1415
1416
    function complete() {
      if (that.hoverState != 'in') $tip.detach()
      that.$element.trigger('hidden.bs.' + that.type)
    }
Jacob Thornton's avatar
Jacob Thornton committed
1417

XhmikosR's avatar
XhmikosR committed
1418
    this.$element.trigger(e)
1419

XhmikosR's avatar
XhmikosR committed
1420
    if (e.isDefaultPrevented()) return
1421

XhmikosR's avatar
XhmikosR committed
1422
    $tip.removeClass('in')
1423

XhmikosR's avatar
XhmikosR committed
1424
1425
1426
    $.support.transition && this.$tip.hasClass('fade') ?
      $tip
        .one('bsTransitionEnd', complete)
1427
        .emulateTransitionEnd(Tooltip.TRANSITION_DURATION) :
XhmikosR's avatar
XhmikosR committed
1428
      complete()
1429

XhmikosR's avatar
XhmikosR committed
1430
    this.hoverState = null
1431

XhmikosR's avatar
XhmikosR committed
1432
1433
    return this
  }
1434

XhmikosR's avatar
XhmikosR committed
1435
1436
1437
1438
  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', '')
1439
    }
XhmikosR's avatar
XhmikosR committed
1440
  }
1441

XhmikosR's avatar
XhmikosR committed
1442
1443
1444
  Tooltip.prototype.hasContent = function () {
    return this.getTitle()
  }
1445

XhmikosR's avatar
XhmikosR committed
1446
1447
  Tooltip.prototype.getPosition = function ($element) {
    $element   = $element || this.$element
Mark Otto's avatar
grunt    
Mark Otto committed
1448

XhmikosR's avatar
XhmikosR committed
1449
1450
    var el     = $element[0]
    var isBody = el.tagName == 'BODY'
Mark Otto's avatar
grunt    
Mark Otto committed
1451
1452
    var isSvg  = window.SVGElement && el instanceof window.SVGElement

XhmikosR's avatar
XhmikosR committed
1453
    var elRect    = el.getBoundingClientRect ? el.getBoundingClientRect() : null
Mark Otto's avatar
grunt    
Mark Otto committed
1454
1455
    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
1456
    var outerDims = isSvg ? {} : {
XhmikosR's avatar
XhmikosR committed
1457
1458
      width:  isBody ? $(window).width()  : $element.outerWidth(),
      height: isBody ? $(window).height() : $element.outerHeight()
Chris Rebert's avatar
Chris Rebert committed
1459
    }
Mark Otto's avatar
grunt    
Mark Otto committed
1460
1461

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

XhmikosR's avatar
XhmikosR committed
1464
1465
1466
1467
1468
  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   }
1469

XhmikosR's avatar
XhmikosR committed
1470
  }
1471

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

XhmikosR's avatar
XhmikosR committed
1476
1477
    var viewportPadding = this.options.viewport && this.options.viewport.padding || 0
    var viewportDimensions = this.getPosition(this.$viewport)
1478

XhmikosR's avatar
XhmikosR committed
1479
1480
1481
1482
1483
1484
1485
1486
1487
1488
1489
1490
1491
1492
1493
    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
1494
      }
Chris Rebert's avatar
Chris Rebert committed
1495
    }
fat's avatar
fat committed
1496

XhmikosR's avatar
XhmikosR committed
1497
1498
    return delta
  }
1499

XhmikosR's avatar
XhmikosR committed
1500
1501
1502
1503
  Tooltip.prototype.getTitle = function () {
    var title
    var $e = this.$element
    var o  = this.options
1504

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

XhmikosR's avatar
XhmikosR committed
1508
1509
    return title
  }
1510

XhmikosR's avatar
XhmikosR committed
1511
1512
1513
1514
1515
  Tooltip.prototype.getUID = function (prefix) {
    do prefix += ~~(Math.random() * 1000000)
    while (document.getElementById(prefix))
    return prefix
  }
1516

XhmikosR's avatar
XhmikosR committed
1517
1518
1519
  Tooltip.prototype.tip = function () {
    return (this.$tip = this.$tip || $(this.options.template))
  }
1520

XhmikosR's avatar
XhmikosR committed
1521
1522
1523
  Tooltip.prototype.arrow = function () {
    return (this.$arrow = this.$arrow || this.tip().find('.tooltip-arrow'))
  }
1524

XhmikosR's avatar
XhmikosR committed
1525
1526
1527
1528
1529
  Tooltip.prototype.validate = function () {
    if (!this.$element[0].parentNode) {
      this.hide()
      this.$element = null
      this.options  = null
Chris Rebert's avatar
Chris Rebert committed
1530
    }
XhmikosR's avatar
XhmikosR committed
1531
  }
1532

XhmikosR's avatar
XhmikosR committed
1533
1534
1535
  Tooltip.prototype.enable = function () {
    this.enabled = true
  }
1536

XhmikosR's avatar
XhmikosR committed
1537
1538
1539
  Tooltip.prototype.disable = function () {
    this.enabled = false
  }
Mark Otto's avatar
Mark Otto committed
1540

XhmikosR's avatar
XhmikosR committed
1541
1542
1543
  Tooltip.prototype.toggleEnabled = function () {
    this.enabled = !this.enabled
  }
Chris Rebert's avatar
Chris Rebert committed
1544

XhmikosR's avatar
XhmikosR committed
1545
1546
1547
1548
1549
1550
1551
1552
  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
1553
1554
    }

XhmikosR's avatar
XhmikosR committed
1555
1556
    self.tip().hasClass('in') ? self.leave(self) : self.enter(self)
  }
1557

XhmikosR's avatar
XhmikosR committed
1558
1559
1560
1561
  Tooltip.prototype.destroy = function () {
    clearTimeout(this.timeout)
    this.hide().$element.off('.' + this.type).removeData('bs.' + this.type)
  }
1562
1563


XhmikosR's avatar
XhmikosR committed
1564
1565
  // TOOLTIP PLUGIN DEFINITION
  // =========================
1566

XhmikosR's avatar
XhmikosR committed
1567
1568
1569
1570
1571
  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
1572

XhmikosR's avatar
XhmikosR committed
1573
1574
1575
1576
1577
      if (!data && option == 'destroy') return
      if (!data) $this.data('bs.tooltip', (data = new Tooltip(this, options)))
      if (typeof option == 'string') data[option]()
    })
  }
1578

XhmikosR's avatar
XhmikosR committed
1579
  var old = $.fn.tooltip
Mark Otto's avatar
Mark Otto committed
1580

XhmikosR's avatar
XhmikosR committed
1581
1582
  $.fn.tooltip             = Plugin
  $.fn.tooltip.Constructor = Tooltip
1583

1584

XhmikosR's avatar
XhmikosR committed
1585
1586
  // TOOLTIP NO CONFLICT
  // ===================
1587

XhmikosR's avatar
XhmikosR committed
1588
1589
1590
1591
  $.fn.tooltip.noConflict = function () {
    $.fn.tooltip = old
    return this
  }
1592

XhmikosR's avatar
XhmikosR committed
1593
}(jQuery);
1594

1595
/* ========================================================================
Mark Otto's avatar
Mark Otto committed
1596
 * Bootstrap: popover.js v3.2.0
Mark Otto's avatar
Mark Otto committed
1597
 * http://getbootstrap.com/javascript/#popovers
1598
 * ========================================================================
1599
 * Copyright 2011-2014 Twitter, Inc.
1600
 * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
1601
 * ======================================================================== */
1602
1603


XhmikosR's avatar
XhmikosR committed
1604
1605
+function ($) {
  'use strict';
Mark Otto's avatar
grunt    
Mark Otto committed
1606

XhmikosR's avatar
XhmikosR committed
1607
1608
  // POPOVER PUBLIC CLASS DEFINITION
  // ===============================
1609

XhmikosR's avatar
XhmikosR committed
1610
1611
1612
  var Popover = function (element, options) {
    this.init('popover', element, options)
  }
fat's avatar
fat committed
1613

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

Mark Otto's avatar
Mark Otto committed
1616
  Popover.VERSION  = '3.2.0'
1617

XhmikosR's avatar
XhmikosR committed
1618
1619
1620
1621
1622
1623
  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
1624
1625


XhmikosR's avatar
XhmikosR committed
1626
1627
  // NOTE: POPOVER EXTENDS tooltip.js
  // ================================
1628

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

XhmikosR's avatar
XhmikosR committed
1631
  Popover.prototype.constructor = Popover
1632

XhmikosR's avatar
XhmikosR committed
1633
1634
1635
  Popover.prototype.getDefaults = function () {
    return Popover.DEFAULTS
  }
1636

XhmikosR's avatar
XhmikosR committed
1637
1638
1639
1640
  Popover.prototype.setContent = function () {
    var $tip    = this.tip()
    var title   = this.getTitle()
    var content = this.getContent()
1641

XhmikosR's avatar
XhmikosR committed
1642
1643
1644
1645
    $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)
1646

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

XhmikosR's avatar
XhmikosR committed
1649
1650
1651
1652
    // 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()
  }
1653

XhmikosR's avatar
XhmikosR committed
1654
1655
1656
  Popover.prototype.hasContent = function () {
    return this.getTitle() || this.getContent()
  }
1657

XhmikosR's avatar
XhmikosR committed
1658
1659
1660
  Popover.prototype.getContent = function () {
    var $e = this.$element
    var o  = this.options
1661

XhmikosR's avatar
XhmikosR committed
1662
1663
1664
1665
1666
    return $e.attr('data-content')
      || (typeof o.content == 'function' ?
            o.content.call($e[0]) :
            o.content)
  }
fat's avatar
fat committed
1667

XhmikosR's avatar
XhmikosR committed
1668
1669
1670
  Popover.prototype.arrow = function () {
    return (this.$arrow = this.$arrow || this.tip().find('.arrow'))
  }
1671

XhmikosR's avatar
XhmikosR committed
1672
1673
1674
1675
  Popover.prototype.tip = function () {
    if (!this.$tip) this.$tip = $(this.options.template)
    return this.$tip
  }
1676

1677

XhmikosR's avatar
XhmikosR committed
1678
1679
  // POPOVER PLUGIN DEFINITION
  // =========================
1680

XhmikosR's avatar
XhmikosR committed
1681
1682
1683
1684
1685
  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
1686

XhmikosR's avatar
XhmikosR committed
1687
1688
1689
1690
1691
      if (!data && option == 'destroy') return
      if (!data) $this.data('bs.popover', (data = new Popover(this, options)))
      if (typeof option == 'string') data[option]()
    })
  }
1692

XhmikosR's avatar
XhmikosR committed
1693
  var old = $.fn.popover
Mark Otto's avatar
Mark Otto committed
1694

XhmikosR's avatar
XhmikosR committed
1695
1696
  $.fn.popover             = Plugin
  $.fn.popover.Constructor = Popover
fat's avatar
fat committed
1697

1698

XhmikosR's avatar
XhmikosR committed
1699
1700
  // POPOVER NO CONFLICT
  // ===================
1701

XhmikosR's avatar
XhmikosR committed
1702
1703
1704
1705
  $.fn.popover.noConflict = function () {
    $.fn.popover = old
    return this
  }
1706

XhmikosR's avatar
XhmikosR committed
1707
}(jQuery);
1708

1709
/* ========================================================================
Mark Otto's avatar
Mark Otto committed
1710
 * Bootstrap: scrollspy.js v3.2.0
Mark Otto's avatar
Mark Otto committed
1711
 * http://getbootstrap.com/javascript/#scrollspy
1712
 * ========================================================================
1713
 * Copyright 2011-2014 Twitter, Inc.
1714
 * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
1715
 * ======================================================================== */
1716
1717


XhmikosR's avatar
XhmikosR committed
1718
1719
+function ($) {
  'use strict';
1720

XhmikosR's avatar
XhmikosR committed
1721
1722
  // SCROLLSPY CLASS DEFINITION
  // ==========================
1723

XhmikosR's avatar
XhmikosR committed
1724
1725
  function ScrollSpy(element, options) {
    var process  = $.proxy(this.process, this)
1726

XhmikosR's avatar
XhmikosR committed
1727
1728
1729
1730
1731
1732
1733
1734
    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
1735

XhmikosR's avatar
XhmikosR committed
1736
1737
1738
1739
    this.$scrollElement.on('scroll.bs.scrollspy', process)
    this.refresh()
    this.process()
  }
1740

Mark Otto's avatar
Mark Otto committed
1741
  ScrollSpy.VERSION  = '3.2.0'
Mark Otto's avatar
grunt    
Mark Otto committed
1742

XhmikosR's avatar
XhmikosR committed
1743
1744
1745
  ScrollSpy.DEFAULTS = {
    offset: 10
  }
1746

XhmikosR's avatar
XhmikosR committed
1747
1748
1749
  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
1750

XhmikosR's avatar
XhmikosR committed
1751
1752
1753
  ScrollSpy.prototype.refresh = function () {
    var offsetMethod = 'offset'
    var offsetBase   = 0
Mark Otto's avatar
grunt    
Mark Otto committed
1754

XhmikosR's avatar
XhmikosR committed
1755
1756
1757
1758
    if (!$.isWindow(this.$scrollElement[0])) {
      offsetMethod = 'position'
      offsetBase   = this.$scrollElement.scrollTop()
    }
Mark Otto's avatar
grunt    
Mark Otto committed
1759

XhmikosR's avatar
XhmikosR committed
1760
1761
1762
    this.offsets = []
    this.targets = []
    this.scrollHeight = this.getScrollHeight()
fat's avatar
fat committed
1763

XhmikosR's avatar
XhmikosR committed
1764
    var self     = this
XhmikosR's avatar
XhmikosR committed
1765

XhmikosR's avatar
XhmikosR committed
1766
1767
1768
1769
1770
1771
    this.$body
      .find(this.selector)
      .map(function () {
        var $el   = $(this)
        var href  = $el.data('target') || $el.attr('href')
        var $href = /^#./.test(href) && $(href)
1772

XhmikosR's avatar
XhmikosR committed
1773
1774
1775
1776
1777
1778
1779
1780
1781
1782
1783
1784
1785
1786
1787
1788
1789
1790
1791
1792
1793
1794
1795
        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
1796
1797
    }

XhmikosR's avatar
XhmikosR committed
1798
1799
1800
    if (scrollTop >= maxScroll) {
      return activeTarget != (i = targets[targets.length - 1]) && this.activate(i)
    }
1801

XhmikosR's avatar
XhmikosR committed
1802
1803
    if (activeTarget && scrollTop <= offsets[0]) {
      return activeTarget != (i = targets[0]) && this.activate(i)
Chris Rebert's avatar
Chris Rebert committed
1804
    }
1805

XhmikosR's avatar
XhmikosR committed
1806
1807
1808
1809
1810
1811
1812
    for (i = offsets.length; i--;) {
      activeTarget != targets[i]
        && scrollTop >= offsets[i]
        && (!offsets[i + 1] || scrollTop <= offsets[i + 1])
        && this.activate(targets[i])
    }
  }
1813

XhmikosR's avatar
XhmikosR committed
1814
1815
  ScrollSpy.prototype.activate = function (target) {
    this.activeTarget = target
1816

XhmikosR's avatar
XhmikosR committed
1817
1818
1819
    $(this.selector)
      .parentsUntil(this.options.target, '.active')
      .removeClass('active')
1820

XhmikosR's avatar
XhmikosR committed
1821
1822
1823
    var selector = this.selector +
        '[data-target="' + target + '"],' +
        this.selector + '[href="' + target + '"]'
1824

XhmikosR's avatar
XhmikosR committed
1825
1826
1827
    var active = $(selector)
      .parents('li')
      .addClass('active')
1828

XhmikosR's avatar
XhmikosR committed
1829
1830
1831
1832
    if (active.parent('.dropdown-menu').length) {
      active = active
        .closest('li.dropdown')
        .addClass('active')
Chris Rebert's avatar
Chris Rebert committed
1833
    }
1834

XhmikosR's avatar
XhmikosR committed
1835
1836
    active.trigger('activate.bs.scrollspy')
  }
1837
1838


XhmikosR's avatar
XhmikosR committed
1839
1840
  // SCROLLSPY PLUGIN DEFINITION
  // ===========================
1841

XhmikosR's avatar
XhmikosR committed
1842
1843
1844
1845
1846
  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
1847

XhmikosR's avatar
XhmikosR committed
1848
1849
1850
1851
      if (!data) $this.data('bs.scrollspy', (data = new ScrollSpy(this, options)))
      if (typeof option == 'string') data[option]()
    })
  }
1852

XhmikosR's avatar
XhmikosR committed
1853
  var old = $.fn.scrollspy
1854

XhmikosR's avatar
XhmikosR committed
1855
1856
  $.fn.scrollspy             = Plugin
  $.fn.scrollspy.Constructor = ScrollSpy
1857

1858

XhmikosR's avatar
XhmikosR committed
1859
1860
  // SCROLLSPY NO CONFLICT
  // =====================
1861

XhmikosR's avatar
XhmikosR committed
1862
1863
1864
1865
  $.fn.scrollspy.noConflict = function () {
    $.fn.scrollspy = old
    return this
  }
1866

Chris Rebert's avatar
Chris Rebert committed
1867

XhmikosR's avatar
XhmikosR committed
1868
1869
  // SCROLLSPY DATA-API
  // ==================
Chris Rebert's avatar
Chris Rebert committed
1870

XhmikosR's avatar
XhmikosR committed
1871
1872
1873
1874
1875
  $(window).on('load.bs.scrollspy.data-api', function () {
    $('[data-spy="scroll"]').each(function () {
      var $spy = $(this)
      Plugin.call($spy, $spy.data())
    })
1876
  })
1877

XhmikosR's avatar
XhmikosR committed
1878
}(jQuery);
1879

1880
/* ========================================================================
Mark Otto's avatar
Mark Otto committed
1881
 * Bootstrap: tab.js v3.2.0
Mark Otto's avatar
Mark Otto committed
1882
 * http://getbootstrap.com/javascript/#tabs
1883
 * ========================================================================
1884
 * Copyright 2011-2014 Twitter, Inc.
1885
 * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
1886
 * ======================================================================== */
1887

1888

XhmikosR's avatar
XhmikosR committed
1889
1890
+function ($) {
  'use strict';
Mark Otto's avatar
grunt    
Mark Otto committed
1891

XhmikosR's avatar
XhmikosR committed
1892
1893
  // TAB CLASS DEFINITION
  // ====================
1894

XhmikosR's avatar
XhmikosR committed
1895
1896
1897
  var Tab = function (element) {
    this.element = $(element)
  }
1898

Mark Otto's avatar
Mark Otto committed
1899
  Tab.VERSION = '3.2.0'
Mark Otto's avatar
grunt    
Mark Otto committed
1900

1901
1902
  Tab.TRANSITION_DURATION = 150

XhmikosR's avatar
XhmikosR committed
1903
1904
1905
1906
  Tab.prototype.show = function () {
    var $this    = this.element
    var $ul      = $this.closest('ul:not(.dropdown-menu)')
    var selector = $this.data('target')
1907

XhmikosR's avatar
XhmikosR committed
1908
1909
1910
1911
    if (!selector) {
      selector = $this.attr('href')
      selector = selector && selector.replace(/.*(?=#[^\s]*$)/, '') // strip for ie7
    }
1912

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

XhmikosR's avatar
XhmikosR committed
1915
1916
1917
1918
    var previous = $ul.find('.active:last a')[0]
    var e        = $.Event('show.bs.tab', {
      relatedTarget: previous
    })
1919

XhmikosR's avatar
XhmikosR committed
1920
    $this.trigger(e)
1921

XhmikosR's avatar
XhmikosR committed
1922
    if (e.isDefaultPrevented()) return
1923

XhmikosR's avatar
XhmikosR committed
1924
    var $target = $(selector)
1925

XhmikosR's avatar
XhmikosR committed
1926
1927
1928
1929
1930
    this.activate($this.closest('li'), $ul)
    this.activate($target, $target.parent(), function () {
      $this.trigger({
        type: 'shown.bs.tab',
        relatedTarget: previous
1931
      })
XhmikosR's avatar
XhmikosR committed
1932
1933
    })
  }
1934

XhmikosR's avatar
XhmikosR committed
1935
1936
1937
1938
  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
1939
      && (($active.length && $active.hasClass('fade')) || !!container.find('> .fade').length)
1940

XhmikosR's avatar
XhmikosR committed
1941
1942
1943
1944
1945
    function next() {
      $active
        .removeClass('active')
        .find('> .dropdown-menu > .active')
        .removeClass('active')
1946

XhmikosR's avatar
XhmikosR committed
1947
1948
1949
1950
1951
1952
1953
      element.addClass('active')

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

XhmikosR's avatar
XhmikosR committed
1956
1957
1958
      if (element.parent('.dropdown-menu')) {
        element.closest('li.dropdown').addClass('active')
      }
fat's avatar
fat committed
1959

XhmikosR's avatar
XhmikosR committed
1960
      callback && callback()
1961
    }
fat's avatar
fat committed
1962

Mark Otto's avatar
grunt    
Mark Otto committed
1963
    $active.length && transition ?
XhmikosR's avatar
XhmikosR committed
1964
1965
      $active
        .one('bsTransitionEnd', next)
1966
        .emulateTransitionEnd(Tab.TRANSITION_DURATION) :
XhmikosR's avatar
XhmikosR committed
1967
      next()
1968

XhmikosR's avatar
XhmikosR committed
1969
1970
    $active.removeClass('in')
  }
1971
1972


XhmikosR's avatar
XhmikosR committed
1973
1974
  // TAB PLUGIN DEFINITION
  // =====================
fat's avatar
fat committed
1975

XhmikosR's avatar
XhmikosR committed
1976
1977
1978
1979
  function Plugin(option) {
    return this.each(function () {
      var $this = $(this)
      var data  = $this.data('bs.tab')
1980

XhmikosR's avatar
XhmikosR committed
1981
1982
1983
1984
      if (!data) $this.data('bs.tab', (data = new Tab(this)))
      if (typeof option == 'string') data[option]()
    })
  }
Mark Otto's avatar
Mark Otto committed
1985

XhmikosR's avatar
XhmikosR committed
1986
  var old = $.fn.tab
1987

XhmikosR's avatar
XhmikosR committed
1988
1989
  $.fn.tab             = Plugin
  $.fn.tab.Constructor = Tab
1990

1991

XhmikosR's avatar
XhmikosR committed
1992
1993
  // TAB NO CONFLICT
  // ===============
1994

XhmikosR's avatar
XhmikosR committed
1995
1996
1997
1998
  $.fn.tab.noConflict = function () {
    $.fn.tab = old
    return this
  }
1999
2000


For faster browsing, not all history is shown. View entire blame