mirror of https://github.com/ColorlibHQ/AdminLTE
Create direct chat plugin
parent
b04a99466d
commit
2c372a2ce2
|
@ -138,7 +138,8 @@ module.exports = function (grunt) { // jshint ignore:line
|
||||||
'build/js/Tree.js',
|
'build/js/Tree.js',
|
||||||
'build/js/ControlSidebar.js',
|
'build/js/ControlSidebar.js',
|
||||||
'build/js/BoxWidget.js',
|
'build/js/BoxWidget.js',
|
||||||
'build/js/TodoList.js'
|
'build/js/TodoList.js',
|
||||||
|
'build/js/DirectChat.js'
|
||||||
],
|
],
|
||||||
dest: 'dist/js/adminlte.js'
|
dest: 'dist/js/adminlte.js'
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,68 @@
|
||||||
|
/* DirectChat()
|
||||||
|
* ===============
|
||||||
|
* Toggles the state of the control sidebar
|
||||||
|
*
|
||||||
|
* @Usage: $('#my-chat-box').directChat(options)
|
||||||
|
* or add [data-widget="direct-chat"] to the trigger
|
||||||
|
* Pass any option as data-option="value"
|
||||||
|
*/
|
||||||
|
+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 () {
|
||||||
|
var box = $(this).parents(Selector.box).first();
|
||||||
|
box.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()
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
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)
|
|
@ -923,3 +923,73 @@ throw new Error('AdminLTE requires jQuery')
|
||||||
})
|
})
|
||||||
|
|
||||||
}(jQuery)
|
}(jQuery)
|
||||||
|
|
||||||
|
|
||||||
|
/* DirectChat()
|
||||||
|
* ===============
|
||||||
|
* Toggles the state of the control sidebar
|
||||||
|
*
|
||||||
|
* @Usage: $('#my-chat-box').directChat(options)
|
||||||
|
* or add [data-widget="direct-chat"] to the trigger
|
||||||
|
* Pass any option as data-option="value"
|
||||||
|
*/
|
||||||
|
+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 () {
|
||||||
|
var box = $(this).parents(Selector.box).first();
|
||||||
|
box.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()
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
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)
|
||||||
|
|
File diff suppressed because one or more lines are too long
Loading…
Reference in New Issue