diff options
Diffstat (limited to 'module/web/static/js/libs')
| -rwxr-xr-x[-rw-r--r--] | module/web/static/js/libs/select2-3.3.2.js (renamed from module/web/static/js/libs/select2-3.3.1.js) | 199 | 
1 files changed, 137 insertions, 62 deletions
| diff --git a/module/web/static/js/libs/select2-3.3.1.js b/module/web/static/js/libs/select2-3.3.2.js index 8be2c7e9f..093d7fbd7 100644..100755 --- a/module/web/static/js/libs/select2-3.3.1.js +++ b/module/web/static/js/libs/select2-3.3.2.js @@ -1,7 +1,7 @@  /*  Copyright 2012 Igor Vaynberg -Version: 3.3.1 Timestamp: Wed Feb 20 09:57:22 PST 2013 +Version: 3.3.2 Timestamp: Mon Mar 25 12:14:18 PDT 2013  This software is licensed under the Apache License, Version 2.0 (the "Apache License") or the GNU  General Public License version 2 (the "GPL License"). You may choose either license to govern your @@ -118,8 +118,8 @@ the specific language governing permissions and limitations under the Apache Lic          if (a === b) return true;          if (a === undefined || b === undefined) return false;          if (a === null || b === null) return false; -        if (a.constructor === String) return a === b+''; -        if (b.constructor === String) return b === a+''; +        if (a.constructor === String) return a+'' === b+''; // IE requires a+'' instead of just a +        if (b.constructor === String) return b+'' === a+''; // IE requires b+'' instead of just b          return false;      } @@ -229,20 +229,22 @@ the specific language governing permissions and limitations under the Apache Lic              $el.focus(); -            /* after the focus is set move the caret to the end, necessary when we val() -                just before setting focus */ -            if(el.setSelectionRange) -            { -                el.setSelectionRange(pos, pos); -            } -            else if (el.createTextRange) { -                range = el.createTextRange(); -                range.collapse(true); -                range.moveEnd('character', pos); -                range.moveStart('character', pos); -                range.select(); -            } +            /* make sure el received focus so we do not error out when trying to manipulate the caret. +                sometimes modals or others listeners may steal it after its set */ +            if ($el.is(":visible") && el === document.activeElement) { +                /* after the focus is set move the caret to the end, necessary when we val() +                    just before setting focus */ +                if(el.setSelectionRange) +                { +                    el.setSelectionRange(pos, pos); +                } +                else if (el.createTextRange) { +                    range = el.createTextRange(); +                    range.collapse(false); +                    range.select(); +                } +            }          }, 0);      } @@ -282,7 +284,8 @@ the specific language governing permissions and limitations under the Apache Lic          var classes, replacements = [], adapted;          classes = dest.attr("class"); -        if (typeof classes === "string") { +        if (classes) { +            classes = '' + classes; // for IE which returns object              $(classes.split(" ")).each2(function() {                  if (this.indexOf("select2-") === 0) {                      replacements.push(this); @@ -290,11 +293,12 @@ the specific language governing permissions and limitations under the Apache Lic              });          }          classes = src.attr("class"); -        if (typeof classes === "string") { +        if (classes) { +            classes = '' + classes; // for IE which returns object              $(classes.split(" ")).each2(function() {                  if (this.indexOf("select2-") !== 0) {                      adapted = adapter(this); -                    if (typeof adapted === "string" && adapted.length > 0) { +                    if (adapted) {                          replacements.push(this);                      }                  } @@ -790,7 +794,7 @@ the specific language governing permissions and limitations under the Apache Lic                  if ("tags" in opts) {                      throw "tags specified as both an attribute 'data-select2-tags' and in options of Select2 " + opts.element.attr("id");                  } -                opts.tags=opts.element.attr("data-select2-tags"); +                opts.tags=opts.element.data("select2Tags");              }              if (select) { @@ -1119,9 +1123,7 @@ the specific language governing permissions and limitations under the Apache Lic              this.dropdown.attr("id", "select2-drop");              // show the elements -            mask.css({ -                width: document.documentElement.scrollWidth, -                height: document.documentElement.scrollHeight}); +            mask.css(_makeMaskCss());              mask.show();              this.dropdown.show();              this.positionDropdown(); @@ -1134,14 +1136,19 @@ the specific language governing permissions and limitations under the Apache Lic              var that = this;              this.container.parents().add(window).each(function () {                  $(this).bind(resize+" "+scroll+" "+orient, function (e) { -                    $("#select2-drop-mask").css({ -                        width:document.documentElement.scrollWidth, -                        height:document.documentElement.scrollHeight}); +                    $("#select2-drop-mask").css(_makeMaskCss());                      that.positionDropdown();                  });              });              this.focusSearch(); + +            function _makeMaskCss() { +                return { +                    width  : Math.max(document.documentElement.scrollWidth,  $(window).width()), +                    height : Math.max(document.documentElement.scrollHeight, $(window).height()) +                } +            }          },          // abstract @@ -1164,7 +1171,7 @@ the specific language governing permissions and limitations under the Apache Lic              this.container.removeClass("select2-dropdown-open");              this.results.empty();              this.clearSearch(); - +            this.search.removeClass("select2-active");              this.opts.element.trigger($.Event("close"));          }, @@ -1315,6 +1322,7 @@ the specific language governing permissions and limitations under the Apache Lic                      self.opts.populateResults.call(this, results, data.results, {term: term, page: page, context:context}); +                    self.postprocessResults(data, false, false);                      if (data.more===true) {                          more.detach().appendTo(results).text(self.opts.formatLoadMore(page+1)); @@ -1341,15 +1349,25 @@ the specific language governing permissions and limitations under the Apache Lic           */          // abstract          updateResults: function (initial) { -            var search = this.search, results = this.results, opts = this.opts, data, self=this, input; +            var search = this.search, +                results = this.results, +                opts = this.opts, +                data, +                self = this, +                input, +                term = search.val(), +                lastTerm=$.data(this.container, "select2-last-term"); + +            // prevent duplicate queries against the same term +            if (initial !== true && lastTerm && equal(term, lastTerm)) return; + +            $.data(this.container, "select2-last-term", term);              // if the search is currently hidden we do not alter the results              if (initial !== true && (this.showSearchInput === false || !this.opened())) {                  return;              } -            search.addClass("select2-active"); -              function postRender() {                  results.scrollTop(0);                  search.removeClass("select2-active"); @@ -1378,9 +1396,6 @@ the specific language governing permissions and limitations under the Apache Lic                  }                  return;              } -            else if (opts.formatSearching() && initial===true) { -                render("<li class='select2-searching'>" + opts.formatSearching() + "</li>"); -            }              if (opts.maximumInputLength && search.val().length > opts.maximumInputLength) {                  if (checkFormatter(opts.formatInputTooLong, "formatInputTooLong")) { @@ -1391,6 +1406,12 @@ the specific language governing permissions and limitations under the Apache Lic                  return;              } +            if (opts.formatSearching && this.findHighlightableChoices().length === 0) { +                render("<li class='select2-searching'>" + opts.formatSearching() + "</li>"); +            } + +            search.addClass("select2-active"); +              // give the tokenizer a chance to pre-process the input              input = this.tokenize();              if (input != undefined && input != null) { @@ -1409,7 +1430,10 @@ the specific language governing permissions and limitations under the Apache Lic                  var def; // default choice                  // ignore a response if the select2 has been closed before it was received -                if (!this.opened()) return; +                if (!this.opened()) { +                    this.search.removeClass("select2-active"); +                    return; +                }                  // save context, if any                  this.context = (data.context===undefined) ? null : data.context; @@ -1442,6 +1466,8 @@ the specific language governing permissions and limitations under the Apache Lic                  this.postprocessResults(data, initial);                  postRender(); + +                this.opts.element.trigger({ type: "loaded", data:data });              })});          }, @@ -1635,6 +1661,11 @@ the specific language governing permissions and limitations under the Apache Lic              this.focusser = container.find(".select2-focusser"); +            // rewrite labels from original element to focusser +            this.focusser.attr("id", "s2id_autogen"+nextUid()); +            $("label[for='" + this.opts.element.attr("id") + "']") +                .attr('for', this.focusser.attr('id')); +              this.search.bind("keydown", this.bind(function (e) {                  if (!this.enabled) return; @@ -1662,6 +1693,16 @@ the specific language governing permissions and limitations under the Apache Lic                  }              })); +            this.search.bind("blur", this.bind(function(e) { +                // a workaround for chrome to keep the search field focussed when the scroll bar is used to scroll the dropdown. +                // without this the search field loses focus which is annoying +                if (document.activeElement === this.body().get(0)) { +                    window.setTimeout(this.bind(function() { +                        this.search.focus(); +                    }), 0); +                } +            })); +              this.focusser.bind("keydown", this.bind(function (e) {                  if (!this.enabled) return; @@ -1747,15 +1788,19 @@ the specific language governing permissions and limitations under the Apache Lic          },          // single -        clear: function() { +        clear: function(triggerChange) {              var data=this.selection.data("select2-data"); -            this.opts.element.val(""); -            this.selection.find("span").empty(); -            this.selection.removeData("select2-data"); -            this.setPlaceholder(); +            if (data) { // guard against queued quick consecutive clicks +                this.opts.element.val(""); +                this.selection.find("span").empty(); +                this.selection.removeData("select2-data"); +                this.setPlaceholder(); -            this.opts.element.trigger({ type: "removed", val: this.id(data), choice: data }); -            this.triggerChange({removed:data}); +                if (triggerChange !== false){ +                    this.opts.element.trigger({ type: "removed", val: this.id(data), choice: data }); +                    this.triggerChange({removed:data}); +                } +            }          },          /** @@ -1795,13 +1840,18 @@ the specific language governing permissions and limitations under the Apache Lic                  // install default initSelection when applied to hidden input and data is local                  opts.initSelection = opts.initSelection || function (element, callback) {                      var id = element.val(); -                    //search in data by id +                    //search in data by id, storing the actual matching item +                    var match = null;                      opts.query({                          matcher: function(term, text, el){ -                            return equal(id, opts.id(el)); +                            var is_match = equal(id, opts.id(el)); +                            if (is_match) { +                                match = el; +                            } +                            return is_match;                          }, -                        callback: !$.isFunction(callback) ? $.noop : function(filtered) { -                            callback(filtered.results.length ? filtered.results[0] : null); +                        callback: !$.isFunction(callback) ? $.noop : function() { +                            callback(match);                          }                      });                  }; @@ -1840,7 +1890,7 @@ the specific language governing permissions and limitations under the Apache Lic          },          // single -        postprocessResults: function (data, initial) { +        postprocessResults: function (data, initial, noHighlightUpdate) {              var selected = 0, self = this, showSearchInput = true;              // find the selected element in the result list @@ -1853,8 +1903,9 @@ the specific language governing permissions and limitations under the Apache Lic              });              // and highlight it - -            this.highlight(selected); +            if (noHighlightUpdate !== false) { +                this.highlight(selected); +            }              // hide the search box if this is the first we got the results and there are a few of them @@ -1930,7 +1981,7 @@ the specific language governing permissions and limitations under the Apache Lic                  this.select                      .val(val)                      .find(":selected").each2(function (i, elm) { -                        data = {id: elm.attr("value"), text: elm.text()}; +                        data = {id: elm.attr("value"), text: elm.text(), element: elm.get(0)};                          return false;                      });                  this.updateSelection(data); @@ -1944,7 +1995,7 @@ the specific language governing permissions and limitations under the Apache Lic                  }                  // val is an id. !val is true for [undefined,null,'',0] - 0 is legal                  if (!val && val !== 0) { -                    this.clear(); +                    this.clear(triggerChange);                      if (triggerChange) {                          this.triggerChange();                      } @@ -2028,15 +2079,20 @@ the specific language governing permissions and limitations under the Apache Lic                  // install default initSelection when applied to hidden input and data is local                  opts.initSelection = opts.initSelection || function (element, callback) {                      var ids = splitVal(element.val(), opts.separator); -                    //search in data by array of ids +                    //search in data by array of ids, storing matching items in a list +                    var matches = [];                      opts.query({                          matcher: function(term, text, el){ -                            return $.grep(ids, function(id) { +                            var is_match = $.grep(ids, function(id) {                                  return equal(id, opts.id(el));                              }).length; +                            if (is_match) { +                                matches.push(el); +                            } +                            return is_match;                          }, -                        callback: !$.isFunction(callback) ? $.noop : function(filtered) { -                            callback(filtered.results); +                        callback: !$.isFunction(callback) ? $.noop : function() { +                            callback(matches);                          }                      });                  }; @@ -2053,6 +2109,11 @@ the specific language governing permissions and limitations under the Apache Lic              this.searchContainer = this.container.find(".select2-search-field");              this.selection = selection = this.container.find(selector); +            // rewrite labels from original element to focusser +            this.search.attr("id", "s2id_autogen"+nextUid()); +            $("label[for='" + this.opts.element.attr("id") + "']") +                .attr('for', this.search.attr('id')); +              this.search.bind("input paste", this.bind(function() {                  if (!this.enabled) return;                  if (!this.opened()) { @@ -2121,6 +2182,12 @@ the specific language governing permissions and limitations under the Apache Lic                      // prevent the page from scrolling                      killEvent(e);                  } + +                if (e.which === KEY.ENTER) { +                    // prevent form from being submitted +                    killEvent(e); +                } +              }));              this.search.bind("keyup", this.bind(this.resizeSearch)); @@ -2204,7 +2271,8 @@ the specific language governing permissions and limitations under the Apache Lic              if (placeholder !== undefined  && this.getVal().length === 0 && this.search.hasClass("select2-focused") === false) {                  this.search.val(placeholder).addClass("select2-default");                  // stretch the search box to full width of the container so as much of the placeholder is visible as possible -                this.resizeSearch(); +                // we could call this.resizeSearch(), but we do not because that requires a sizer and we do not want to create one so early because of a firefox bug, see #944 +                this.search.width(this.getMaxSearchWidth());              } else {                  this.search.val("").width(10);              } @@ -2219,10 +2287,11 @@ the specific language governing permissions and limitations under the Apache Lic          // multi          opening: function () { +            this.clearPlaceholder(); // should be done before super so placeholder is not used to search +            this.resizeSearch(); +              this.parent.opening.apply(this, arguments); -            this.clearPlaceholder(); -			this.resizeSearch();              this.focusSearch();              this.opts.element.trigger($.Event("open")); @@ -2238,7 +2307,7 @@ the specific language governing permissions and limitations under the Apache Lic          focus: function () {              this.close();              this.search.focus(); -            this.opts.element.triggerHandler("focus"); +            //this.opts.element.triggerHandler("focus");          },          // multi @@ -2266,6 +2335,7 @@ the specific language governing permissions and limitations under the Apache Lic              self.postprocessResults();          }, +        // multi          tokenize: function() {              var input = this.search.val();              input = this.opts.tokenizer(input, this.data(), this.bind(this.onSelect), this.opts); @@ -2293,7 +2363,7 @@ the specific language governing permissions and limitations under the Apache Lic                  if (this.countSelectableResults()>0) {                      this.search.width(10);                      this.resizeSearch(); -                    if (this.val().length >= this.getMaximumSelectionSize()) { +                    if (this.getMaximumSelectionSize() > 0 && this.val().length >= this.getMaximumSelectionSize()) {                          // if we reached max selection size repaint the results so choices                          // are replaced with the max selection reached message                          this.updateResults(true); @@ -2432,6 +2502,11 @@ the specific language governing permissions and limitations under the Apache Lic          },          // multi +        getMaxSearchWidth: function() { +            return this.selection.width() - getSideBorderPadding(this.search); +        }, + +        // multi          resizeSearch: function () {              var minimumWidth, left, maxWidth, containerLeft, searchWidth,              	sideBorderPadding = getSideBorderPadding(this.search); @@ -2656,7 +2731,7 @@ the specific language governing permissions and limitations under the Apache Lic          formatResultCssClass: function(data) {return undefined;},          formatNoMatches: function () { return "No matches found"; },          formatInputTooShort: function (input, min) { var n = min - input.length; return "Please enter " + n + " more character" + (n == 1? "" : "s"); }, -        formatInputTooLong: function (input, max) { var n = input.length - max; return "Please enter " + n + " less character" + (n == 1? "" : "s"); }, +        formatInputTooLong: function (input, max) { var n = input.length - max; return "Please delete " + n + " character" + (n == 1? "" : "s"); },          formatSelectionTooBig: function (limit) { return "You can only select " + limit + " item" + (limit == 1 ? "" : "s"); },          formatLoadMore: function (pageNumber) { return "Loading more results..."; },          formatSearching: function () { return "Searching..."; }, @@ -2666,7 +2741,7 @@ the specific language governing permissions and limitations under the Apache Lic          maximumSelectionSize: 0,          id: function (e) { return e.id; },          matcher: function(term, text) { -            return text.toUpperCase().indexOf(term.toUpperCase()) >= 0; +            return (''+text).toUpperCase().indexOf((''+term).toUpperCase()) >= 0;          },          separator: ",",          tokenSeparators: [], @@ -2682,7 +2757,7 @@ the specific language governing permissions and limitations under the Apache Lic                  "/": '/'              }; -            return String(markup).replace(/[&<>"'/\\]/g, function (match) { +            return String(markup).replace(/[&<>"'\/\\]/g, function (match) {                      return replace_map[match[0]];              });          }, | 
