From f38cd5c0e1a3423274f3dae1043966cf923befdc Mon Sep 17 00:00:00 2001 From: Vinicius Depizzol Date: Fri, 15 Jul 2011 14:50:59 -0300 Subject: [PATCH] merged loopj's public methods support --- demo.html | 30 ++++++++++++++++ src/jquery.tokeninput.js | 74 ++++++++++++++++++++++++++++++++++++---- 2 files changed, 97 insertions(+), 7 deletions(-) diff --git a/demo.html b/demo.html index d392c055..c7cd77c7 100644 --- a/demo.html +++ b/demo.html @@ -287,5 +287,35 @@

Using local data with parseName function and searchColumns se }); + +

Using the add, remove and clear Methods

+
+ Add Token | Remove Token | Clear Tokens
+ + + +
diff --git a/src/jquery.tokeninput.js b/src/jquery.tokeninput.js index a4344178..09b182ec 100644 --- a/src/jquery.tokeninput.js +++ b/src/jquery.tokeninput.js @@ -103,13 +103,37 @@ var KEY = { COMMA: 188 }; -// Expose the .tokenInput function to jQuery as a plugin -$.fn.tokenInput = function (url_or_data_or_function, options) { - var settings = $.extend({}, DEFAULT_SETTINGS, options || {}); +// Additional public (exposed) methods +var methods = { + init: function(url_or_data_or_function, options) { + var settings = $.extend({}, DEFAULT_SETTINGS, options || {}); + + return this.each(function () { + $(this).data("tokenInputObject", new $.TokenList(this, url_or_data_or_function, settings)); + }); + }, + clear: function() { + this.data("tokenInputObject").clear(); + return this; + }, + add: function(item) { + this.data("tokenInputObject").add(item); + return this; + }, + remove: function(item) { + this.data("tokenInputObject").remove(item); + return this; + } +} - return this.each(function () { - new $.TokenList(this, url_or_data_or_function, settings); - }); +// Expose the .tokenInput function to jQuery as a plugin +$.fn.tokenInput = function (method) { + // Method calling and initialization logic + if(methods[method]) { + return methods[method].apply(this, Array.prototype.slice.call(arguments, 1)); + } else { + return methods.init.apply(this, arguments); + } }; @@ -459,6 +483,39 @@ $.TokenList = function (input, url_or_data_or_function, settings) { hide_dropdown(); } } + + + // + // Public functions + // + + this.clear = function() { + token_list.children("li").each(function() { + if ($(this).children("input").length === 0) { + delete_token($(this)); + } + }); + } + + this.add = function(item) { + add_token(item); + } + + this.remove = function(item) { + token_list.children("li[data-uniqueid]").each(function() { + var currToken = $(this).data("tokeninput"); + var match = true; + for (var prop in item) { + if (item[prop] !== currToken[prop]) { + match = false; + break; + } + } + if (match) { + delete_token($(this)); + } + }); + } @@ -538,11 +595,14 @@ $.TokenList = function (input, url_or_data_or_function, settings) { // Add a token to the token list based on user input function add_token (item) { + if(typeof(item) === "string") { var li_data = {name: item}; - } else { + } else if(item[0]) { var li_data = $.data(item.get(0), "tokeninput"); + } else { + var li_data = item; } if(!li_data) {