1
0
mirror of synced 2024-11-26 06:46:04 +03:00

Create locked items that can't be removed.

This patch creates multi select items that can't be removed.
This commit is contained in:
Todd Rafferty 2012-10-16 14:33:35 -03:00
parent 6e3b7097a3
commit 43939f08a4

View File

@ -1838,7 +1838,7 @@ the specific language governing permissions and limitations under the Apache Lic
return;
}
choices = selection.find(".select2-search-choice");
choices = selection.find(".select2-search-choice:not(.select2-locked)");
if (choices.length > 0) {
choices.last().addClass("select2-search-choice-focus");
}
@ -2069,13 +2069,18 @@ the specific language governing permissions and limitations under the Apache Lic
this.focusSearch();
},
// multi
addSelectedChoice: function (data) {
var choice=$(
var enableChoice = !data.disabled,
enabledItem = $(
"<li class='select2-search-choice'>" +
" <div></div>" +
" <a href='javascript:void(0)' onclick='return false;' class='select2-search-choice-close' tabindex='-1'></a>" +
" <a href='#' onclick='return false;' class='select2-search-choice-close' tabindex='-1'></a>" +
"</li>"),
disabledItem = $(
"<li class='select2-search-choice select2-locked'>" +
"<div></div>" +
"</li>");
var choice = enableChoice ? enabledItem : disabledItem,
id = this.id(data),
val = this.getVal(),
formatted;
@ -2084,6 +2089,8 @@ the specific language governing permissions and limitations under the Apache Lic
if (formatted != undefined) {
choice.find("div").replaceWith("<div>"+this.opts.escapeMarkup(formatted)+"</div>");
}
if(enableChoice){
choice.find(".select2-search-choice-close")
.bind("mousedown", killEvent)
.bind("click dblclick", this.bind(function (e) {
@ -2101,6 +2108,7 @@ the specific language governing permissions and limitations under the Apache Lic
this.container.addClass("select2-container-active");
this.dropdown.addClass("select2-drop-active");
}));
}
choice.data("select2-data", data);
choice.insertBefore(this.searchContainer);