src/cm/media/js/lib/yui/yui3-3.15.0/build/highlight-accentfold/highlight-accentfold.js
author gibus
Mon, 10 Mar 2014 15:19:48 +0100
changeset 602 e16a97fb364a
permissions -rw-r--r--
Use YUI 3.15
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
602
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
     1
YUI.add('highlight-accentfold', function (Y, NAME) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
     2
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
     3
/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
     4
Adds accent-folding highlighters to `Y.Highlight`.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
     5
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
     6
@module highlight
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
     7
@submodule highlight-accentfold
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
     8
**/
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
     9
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    10
/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    11
@class Highlight
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    12
@static
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    13
**/
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    14
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    15
var AccentFold = Y.Text.AccentFold,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    16
    Escape     = Y.Escape,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    17
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    18
    EMPTY_OBJECT = {},
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    19
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    20
Highlight = Y.mix(Y.Highlight, {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    21
    // -- Public Static Methods ------------------------------------------------
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    22
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    23
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    24
    Accent-folding version of `all()`.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    25
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    26
    @method allFold
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    27
    @param {String} haystack String to apply highlighting to.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    28
    @param {String|String[]} needles String or array of strings that should be
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    29
      highlighted.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    30
    @param {Object} [options] Options object.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    31
    @param {Boolean} [options.startsWith=false] If `true`, matches must be
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    32
        anchored to the beginning of the string.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    33
    @return {String} Escaped and highlighted copy of _haystack_.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    34
    @static
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    35
    **/
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    36
    allFold: function (haystack, needles, options) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    37
        var template = Highlight._TEMPLATE,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    38
            results  = [],
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    39
            startPos = 0,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    40
            chunk, i, len, match, result;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    41
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    42
        options = Y.merge({
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    43
            // This tells Highlight.all() not to escape HTML, in order to ensure
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    44
            // usable match offsets. The output of all() is discarded, and we
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    45
            // perform our own escaping before returning the highlighted string.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    46
            escapeHTML: false,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    47
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    48
            // While the highlight regex operates on the accent-folded strings,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    49
            // this replacer will highlight the matched positions in the
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    50
            // original string.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    51
            //
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    52
            // Note: this implementation doesn't handle multi-character folds,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    53
            // like "æ" -> "ae". Doing so correctly would be prohibitively
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    54
            // expensive both in terms of code size and runtime performance, so
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    55
            // I've chosen to take the pragmatic route and just not do it at
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    56
            // all. This is one of many reasons why accent folding is best done
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    57
            // on the server.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    58
            replacer: function (match, p1, foldedNeedle, pos) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    59
                var len;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    60
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    61
                // Ignore matches inside HTML entities.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    62
                if (p1 && !(/\s/).test(foldedNeedle)) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    63
                    return match;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    64
                }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    65
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    66
                len = foldedNeedle.length;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    67
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    68
                results.push([
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    69
                    haystack.substring(startPos, pos), // substring between previous match and this match
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    70
                    haystack.substr(pos, len)          // match to be highlighted
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    71
                ]);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    72
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    73
                startPos = pos + len;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    74
            }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    75
        }, options || EMPTY_OBJECT);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    76
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    77
        // Run the highlighter on the folded strings. We don't care about the
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    78
        // output; our replacer function will build the canonical highlighted
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    79
        // string, with original accented characters.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    80
        Highlight.all(AccentFold.fold(haystack), AccentFold.fold(needles), options);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    81
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    82
        // Tack on the remainder of the haystack that wasn't highlighted, if
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    83
        // any.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    84
        if (startPos < haystack.length) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    85
            results.push([haystack.substr(startPos)]);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    86
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    87
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    88
        // Highlight and escape the string.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    89
        for (i = 0, len = results.length; i < len; ++i) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    90
            chunk = Escape.html(results[i][0]);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    91
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    92
            if ((match = results[i][1])) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    93
                chunk += template.replace(/\{s\}/g, Escape.html(match));
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    94
            }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    95
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    96
            results[i] = chunk;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    97
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    98
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    99
        return results.join('');
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   100
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   101
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   102
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   103
    Accent-folding version of `start()`.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   104
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   105
    @method startFold
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   106
    @param {String} haystack String to apply highlighting to.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   107
    @param {String|String[]} needles String or array of strings that should be
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   108
      highlighted.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   109
    @return {String} Escaped and highlighted copy of _haystack_.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   110
    @static
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   111
    **/
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   112
    startFold: function (haystack, needles) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   113
        return Highlight.allFold(haystack, needles, {startsWith: true});
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   114
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   115
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   116
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   117
    Accent-folding version of `words()`.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   118
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   119
    @method wordsFold
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   120
    @param {String} haystack String to apply highlighting to.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   121
    @param {String|String[]} needles String or array of strings containing words
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   122
      that should be highlighted. If a string is passed, it will be split
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   123
      into words; if an array is passed, it is assumed to have already been
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   124
      split.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   125
    @return {String} Escaped and highlighted copy of _haystack_.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   126
    @static
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   127
    **/
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   128
    wordsFold: function (haystack, needles) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   129
        var template = Highlight._TEMPLATE;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   130
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   131
        return Highlight.words(haystack, AccentFold.fold(needles), {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   132
            mapper: function (word, needles) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   133
                if (needles.hasOwnProperty(AccentFold.fold(word))) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   134
                    return template.replace(/\{s\}/g, Escape.html(word));
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   135
                }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   136
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   137
                return Escape.html(word);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   138
            }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   139
        });
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   140
    }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   141
});
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   142
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   143
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   144
}, '@VERSION@', {"requires": ["highlight-base", "text-accentfold"]});