diff -r 322d0feea350 -r 89ef5ed3c48b src/cm/media/js/lib/yui/yui_3.10.3/build/autocomplete-highlighters/autocomplete-highlighters-debug.js --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/src/cm/media/js/lib/yui/yui_3.10.3/build/autocomplete-highlighters/autocomplete-highlighters-debug.js Tue Jul 16 14:29:46 2013 +0200 @@ -0,0 +1,206 @@ +/* +YUI 3.10.3 (build 2fb5187) +Copyright 2013 Yahoo! Inc. All rights reserved. +Licensed under the BSD License. +http://yuilibrary.com/license/ +*/ + +YUI.add('autocomplete-highlighters', function (Y, NAME) { + +/** +Provides pre-built result highlighters for AutoComplete. + +@module autocomplete +@submodule autocomplete-highlighters +@class AutoCompleteHighlighters +@static +**/ + +var YArray = Y.Array, + Highlight = Y.Highlight, + +Highlighters = Y.mix(Y.namespace('AutoCompleteHighlighters'), { + // -- Public Methods ------------------------------------------------------- + + /** + Highlights any individual query character that occurs anywhere in a result. + Case-insensitive. + + @method charMatch + @param {String} query Query to match + @param {Array} results Results to highlight + @return {Array} Highlighted results + @static + **/ + charMatch: function (query, results, caseSensitive) { + // The caseSensitive parameter is only intended for use by + // charMatchCase(). It's intentionally undocumented. + + var queryChars = YArray.unique((caseSensitive ? query : + query.toLowerCase()).split('')); + + return YArray.map(results, function (result) { + return Highlight.all(result.text, queryChars, { + caseSensitive: caseSensitive + }); + }); + }, + + /** + Case-sensitive version of `charMatch()`. + + @method charMatchCase + @param {String} query Query to match + @param {Array} results Results to highlight + @return {Array} Highlighted results + @static + **/ + charMatchCase: function (query, results) { + return Highlighters.charMatch(query, results, true); + }, + + /** + Highlights the complete query as a phrase anywhere within a result. Case- + insensitive. + + @method phraseMatch + @param {String} query Query to match + @param {Array} results Results to highlight + @return {Array} Highlighted results + @static + **/ + phraseMatch: function (query, results, caseSensitive) { + // The caseSensitive parameter is only intended for use by + // phraseMatchCase(). It's intentionally undocumented. + + return YArray.map(results, function (result) { + return Highlight.all(result.text, [query], { + caseSensitive: caseSensitive + }); + }); + }, + + /** + Case-sensitive version of `phraseMatch()`. + + @method phraseMatchCase + @param {String} query Query to match + @param {Array} results Results to highlight + @return {Array} Highlighted results + @static + **/ + phraseMatchCase: function (query, results) { + return Highlighters.phraseMatch(query, results, true); + }, + + /** + Highlights the complete query as a phrase at the beginning of a result. + Case-insensitive. + + @method startsWith + @param {String} query Query to match + @param {Array} results Results to highlight + @return {Array} Highlighted results + @static + **/ + startsWith: function (query, results, caseSensitive) { + // The caseSensitive parameter is only intended for use by + // startsWithCase(). It's intentionally undocumented. + + return YArray.map(results, function (result) { + return Highlight.all(result.text, [query], { + caseSensitive: caseSensitive, + startsWith : true + }); + }); + }, + + /** + Case-sensitive version of `startsWith()`. + + @method startsWithCase + @param {String} query Query to match + @param {Array} results Results to highlight + @return {Array} Highlighted results + @static + **/ + startsWithCase: function (query, results) { + return Highlighters.startsWith(query, results, true); + }, + + /** + Highlights portions of results in which words from the query match either + whole words or parts of words in the result. Non-word characters like + whitespace and certain punctuation are ignored. Case-insensitive. + + @method subWordMatch + @param {String} query Query to match + @param {Array} results Results to highlight + @return {Array} Highlighted results + @static + **/ + subWordMatch: function (query, results, caseSensitive) { + // The caseSensitive parameter is only intended for use by + // subWordMatchCase(). It's intentionally undocumented. + + var queryWords = Y.Text.WordBreak.getUniqueWords(query, { + ignoreCase: !caseSensitive + }); + + return YArray.map(results, function (result) { + return Highlight.all(result.text, queryWords, { + caseSensitive: caseSensitive + }); + }); + }, + + /** + Case-sensitive version of `subWordMatch()`. + + @method subWordMatchCase + @param {String} query Query to match + @param {Array} results Results to highlight + @return {Array} Highlighted results + @static + **/ + subWordMatchCase: function (query, results) { + return Highlighters.subWordMatch(query, results, true); + }, + + /** + Highlights individual words in results that are also in the query. Non-word + characters like punctuation are ignored. Case-insensitive. + + @method wordMatch + @param {String} query Query to match + @param {Array} results Results to highlight + @return {Array} Highlighted results + @static + **/ + wordMatch: function (query, results, caseSensitive) { + // The caseSensitive parameter is only intended for use by + // wordMatchCase(). It's intentionally undocumented. + + return YArray.map(results, function (result) { + return Highlight.words(result.text, query, { + caseSensitive: caseSensitive + }); + }); + }, + + /** + Case-sensitive version of `wordMatch()`. + + @method wordMatchCase + @param {String} query Query to match + @param {Array} results Results to highlight + @return {Array} Highlighted results + @static + **/ + wordMatchCase: function (query, results) { + return Highlighters.wordMatch(query, results, true); + } +}); + + +}, '3.10.3', {"requires": ["array-extras", "highlight-base"]});