mirror of https://github.com/ColorlibHQ/AdminLTE
67 lines
1.4 KiB
JavaScript
67 lines
1.4 KiB
JavaScript
/* DirectChat()
|
|
* ===============
|
|
* Toggles the state of the control sidebar
|
|
*
|
|
* @Usage: $('#my-chat-box').directChat()
|
|
* or add [data-widget="direct-chat"] to the trigger
|
|
*/
|
|
+function ($) {
|
|
'use strict'
|
|
|
|
var DataKey = 'lte.directchat'
|
|
|
|
var Selector = {
|
|
data: '[data-widget="chat-pane-toggle"]',
|
|
box : '.direct-chat'
|
|
}
|
|
|
|
var ClassName = {
|
|
open: 'direct-chat-contacts-open'
|
|
}
|
|
|
|
// DirectChat Class Definition
|
|
// ===========================
|
|
var DirectChat = function (element) {
|
|
this.element = element
|
|
}
|
|
|
|
DirectChat.prototype.toggle = function ($trigger) {
|
|
$trigger.parents(Selector.box).first().toggleClass(ClassName.open)
|
|
}
|
|
|
|
// Plugin Definition
|
|
// =================
|
|
function Plugin(option) {
|
|
return this.each(function () {
|
|
var $this = $(this)
|
|
var data = $this.data(DataKey)
|
|
|
|
if (!data) {
|
|
$this.data(DataKey, (data = new DirectChat($this)))
|
|
}
|
|
|
|
if (typeof option == 'string') data.toggle($this)
|
|
})
|
|
}
|
|
|
|
var old = $.fn.directChat
|
|
|
|
$.fn.directChat = Plugin
|
|
$.fn.directChat.Constructor = DirectChat
|
|
|
|
// No Conflict Mode
|
|
// ================
|
|
$.fn.directChat.noConflict = function () {
|
|
$.fn.directChat = old
|
|
return this
|
|
}
|
|
|
|
// DirectChat Data API
|
|
// ===================
|
|
$(document).on('click', Selector.data, function (event) {
|
|
if (event) event.preventDefault()
|
|
Plugin.call($(this), 'toggle')
|
|
})
|
|
|
|
}(jQuery)
|