Skip to content

Instantly share code, notes, and snippets.

@dkemper01
Created July 14, 2015 04:04
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save dkemper01/0e8e386ae1bbb658a404 to your computer and use it in GitHub Desktop.
Save dkemper01/0e8e386ae1bbb658a404 to your computer and use it in GitHub Desktop.
The Bootstrap Async Popover Extension
+function ($) {
'use strict'
// EXTENDED POPOVER PUBLIC CLASS DEFINITION
// ===============================
var PopoverAsync = function (element, options) {
this.init('popoverasync', element, options)
}
if (!$.fn.tooltip) throw new Error('PopoverAsync requires tooltip.js')
PopoverAsync.DEFAULTS = $.extend({}, $.fn.tooltip.Constructor.DEFAULTS, {
placement: 'right',
trigger: 'click',
content: '',
template: '<div class="popover"><h3 class="popover-title"></h3><div class="popover-content"></div><div class="arrow"></div></div>'
})
// NOTE: THIS CUSTOM POPOVER EXTENDS tooltip.js
// ================================
PopoverAsync.prototype = $.extend({}, $.fn.tooltip.Constructor.prototype)
PopoverAsync.prototype.constructor = PopoverAsync
PopoverAsync.prototype.getDefaults = function () {
return PopoverAsync.DEFAULTS
}
PopoverAsync.prototype.setContent = function () {
var $tip = this.tip()
var title = this.getTitle()
var content = this.getContent(function (thatRef, fetchedContent) {
$tip.find('.popover-content')[ // we use append for html objects to maintain js events
thatRef.options.html ? (typeof fetchedContent == 'string' ? 'html' : 'append') : 'text'
](fetchedContent)
});
$tip.find('.popover-title')[this.options.html ? 'html' : 'text'](title)
$tip.find('.popover-content')[this.options.html ? 'html' : 'text'](content)
$tip.removeClass('fade top bottom left right in')
// 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()
}
PopoverAsync.prototype.hasContent = function () {
return this.getTitle() || this.getContent()
}
PopoverAsync.prototype.getContent = function (callback) {
var $e = this.$element
var o = this.options
var contentToReturn = ''
if ($e.attr('data-content')) {
contentToReturn = $e.attr('data-content')
}
else if (typeof o.content == 'function') {
o.content.call($e[0], callback, this)
contentToReturn = '<div style="width: 5em; margin-left: auto; margin-right: auto; text-align: center;"><img width="24" height="24" src="" /></div>'
} else {
contentToReturn = o.content
}
return contentToReturn
}
PopoverAsync.prototype.arrow = function () {
return this.$arrow = this.$arrow || this.tip().find('.arrow')
}
PopoverAsync.prototype.tip = function () {
if (!this.$tip) this.$tip = $(this.options.template)
return this.$tip
}
// EXTENDED POPOVER PLUGIN DEFINITION
// =========================
var old = $.fn.popoverasync
$.fn.popoverasync = function (option) {
return this.each(function () {
var $this = $(this)
var data = $this.data('bs.popoverasync')
var options = typeof option == 'object' && option
if (!data && option == 'destroy') return
if (!data) $this.data('bs.popoverasync', (data = new PopoverAsync(this, options)))
if (typeof option == 'string') data[option]()
})
}
$.fn.popoverasync.Constructor = PopoverAsync
// POPOVER NO CONFLICT
// ===================
$.fn.popoverasync.noConflict = function () {
$.fn.popoverasync = old
return this
}
}(jQuery)
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment