123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566 |
- /* 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);
|