bootstrap-popover.js 1.91 KB
Newer Older
Jacob Thornton's avatar
Jacob Thornton committed
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
 /* EXTENDS BOOTSTRAP-TWIPSY.js
    =========================== */

(function( $ ) {

 /* POPOVER PUBLIC CLASS DEFINITION
  * ============================== */

  var Popover = function ( element, options ) {
    this.$element = $(element)
    this.options = options
    this.enabled = true
  }

  Popover.prototype = $.extend({}, $.fn.twipsy.Twipsy.prototype, {

    setContent: function () {
      var $tip = this.tip()
      $tip.find('.title')[this.options.html ? 'html' : 'text'](this.getTitle())
      $tip.find('.content p')[this.options.html ? 'html' : 'text'](this.getContent())
      $tip[0].className = 'popover'
    }

  , fixTitle: function () {}

  , getTitle: function () {
      var title
      if (typeof this.options.title == 'string') {
29
        title = this.$element.attr('data-title') || this.options.title
Jacob Thornton's avatar
Jacob Thornton committed
30
31
32
33
34
35
36
37
38
      } else if (typeof this.options.title == 'function') {
        title = this.options.title.call(this.$element[0])
      }
      return title
    }

  , getContent: function () {content
      var content
      if (typeof this.options.content == 'string') {
39
        content = this.$element.attr('data-content') || this.options.content
Jacob Thornton's avatar
Jacob Thornton committed
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
      } else if (typeof this.options.content == 'function') {
        content = this.options.content.call(this.$element[0])
      }
      return content
    }

  , tip: function() {
      if (!this.$tip) {
        this.$tip = $('<div class="popover" />')
          .html('<div class="arrow"></div><div class="inner"><h3 class="title"></h3><div class="content"><p></p></div></div>')
      }
      return this.$tip
    }

  })


 /* POPOVER PLUGIN DEFINITION
  * ======================= */

  $.fn.popover = function (options) {
    if (typeof options == 'object') options = $.extend({}, $.fn.popover.defaults, options)
    $.fn.twipsy.initWith.call(this, options, Popover)
  }

  $.fn.popover.defaults = $.extend({}, $.fn.twipsy.defaults, { content: '', placement: 'right'})

})( jQuery || ender )