Skip to content

Commit

Permalink
Create direct chat plugin
Browse files Browse the repository at this point in the history
  • Loading branch information
almasaeed2010 committed Mar 4, 2017
1 parent b04a994 commit 2c372a2
Show file tree
Hide file tree
Showing 4 changed files with 141 additions and 2 deletions.
3 changes: 2 additions & 1 deletion Gruntfile.js
Original file line number Diff line number Diff line change
Expand Up @@ -138,7 +138,8 @@ module.exports = function (grunt) { // jshint ignore:line
'build/js/Tree.js',
'build/js/ControlSidebar.js',
'build/js/BoxWidget.js',
'build/js/TodoList.js'
'build/js/TodoList.js',
'build/js/DirectChat.js'
],
dest: 'dist/js/adminlte.js'
}
Expand Down
68 changes: 68 additions & 0 deletions build/js/DirectChat.js
Original file line number Diff line number Diff line change
@@ -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)
70 changes: 70 additions & 0 deletions dist/js/adminlte.js
Original file line number Diff line number Diff line change
Expand Up @@ -923,3 +923,73 @@ throw new Error('AdminLTE requires 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)
Loading

0 comments on commit 2c372a2

Please sign in to comment.