src/cm/media/js/lib/yui/yui3-3.15.0/build/substitute/substitute.js
author ymh <ymh.work@gmail.com>
Fri, 14 Mar 2014 13:16:10 +0100
changeset 611 fa66f4bb1563
parent 602 e16a97fb364a
permissions -rw-r--r--
add some more custom config and put every thing in comment in the custom.yaml template
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
602
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
     1
YUI.add('substitute', 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
 * String variable substitution and string formatting.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
     5
 * If included, the substitute method is added to the YUI instance.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
     6
 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
     7
 * @module substitute
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
     8
 * @deprecated
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
    var L = Y.Lang, DUMP = 'dump', SPACE = ' ', LBRACE = '{', RBRACE = '}',
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    12
		savedRegExp =  /(~-(\d+)-~)/g, lBraceRegExp = /\{LBRACE\}/g, rBraceRegExp = /\{RBRACE\}/g,
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
     * The following methods are added to the YUI instance
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    16
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    17
     * <strong>Use `Y.Lang.sub` or `Y.Template` instead.</strong>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    18
     * @class YUI~substitute
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    19
     * @deprecated
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    20
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    21
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    22
/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    23
<strong>Use `Y.Lang.sub` or `Y.Template` instead.</strong>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    24
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    25
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    26
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    27
Does `{placeholder}` substitution on a string.  The object passed as the
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    28
second parameter provides values to replace the `{placeholder}`s.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    29
{placeholder} token names must match property names of the object.  For
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    30
example
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    31
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    32
`var greeting = Y.substitute("Hello, {who}!", { who: "World" });`
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    33
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    34
`{placeholder}` tokens that are undefined on the object map will be left in
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    35
tact (leaving unsightly "{placeholder}"s in the output string).  If your
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    36
replacement strings *should* include curly braces, use `{LBRACE}` and
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    37
`{RBRACE}` in your object map string value.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    38
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    39
If a function is passed as a third argument, it will be called for each
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    40
{placeholder} found.  The {placeholder} name is passed as the first value
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    41
and the value from the object map is passed as the second.  If the
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    42
{placeholder} contains a space, the first token will be used to identify
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    43
the object map property and the remainder will be passed as a third
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    44
argument to the function.  See below for an example.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    45
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    46
If the value in the object map for a given {placeholder} is an object and
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    47
the `dump` module is loaded, the replacement value will be the string
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    48
result of calling `Y.dump(...)` with the object as input.  Include a
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    49
numeric second token in the {placeholder} to configure the depth of the call
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    50
to `Y.dump(...)`, e.g. "{someObject 2}".  See the
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    51
<a href="../classes/YUI.html#method_dump">`dump`</a> method for details.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    52
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    53
    @method substitute
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    54
    @deprecated
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    55
    @param {string} s The string that will be modified.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    56
    @param {object} o An object containing the replacement values.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    57
    @param {function} f An optional function that can be used to
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    58
                        process each match.  It receives the key,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    59
                        value, and any extra metadata included with
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    60
                        the key inside of the braces.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    61
    @param {boolean} recurse if true, the replacement will be recursive,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    62
                        letting you have replacement tokens in replacement text.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    63
                        The default is false.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    64
    @return {string} the substituted string.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    65
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    66
    @example
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    67
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    68
        function getAttrVal(key, value, name) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    69
            // Return a string describing the named attribute and its value if
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    70
            // the first token is @. Otherwise, return the value from the
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    71
            // replacement object.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    72
            if (key === "@") {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    73
                value += name + " Value: " + myObject.get(name);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    74
            }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    75
            return value;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    76
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    77
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    78
        // Assuming myObject.set('foo', 'flowers'),
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    79
        // => "Attr: foo Value: flowers"
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    80
        var attrVal = Y.substitute("{@ foo}", { "@": "Attr: " }, getAttrVal);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    81
    **/
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    82
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    83
    substitute = function(s, o, f, recurse) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    84
        var i, j, k, key, v, meta, saved = [], token, dump,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    85
            lidx = s.length;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    86
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    87
        for (;;) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    88
            i = s.lastIndexOf(LBRACE, lidx);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    89
            if (i < 0) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    90
                break;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    91
            }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    92
            j = s.indexOf(RBRACE, i);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    93
            if (i + 1 >= j) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    94
                break;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    95
            }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    96
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    97
            //Extract key and meta info
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    98
            token = s.substring(i + 1, j);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    99
            key = token;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   100
            meta = null;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   101
            k = key.indexOf(SPACE);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   102
            if (k > -1) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   103
                meta = key.substring(k + 1);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   104
                key = key.substring(0, k);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   105
            }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   106
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   107
            // lookup the value
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   108
            v = o[key];
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   109
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   110
            // if a substitution function was provided, execute it
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   111
            if (f) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   112
                v = f(key, v, meta);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   113
            }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   114
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   115
            if (L.isObject(v)) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   116
                if (!Y.dump) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   117
                    v = v.toString();
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   118
                } else {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   119
                    if (L.isArray(v)) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   120
                        v = Y.dump(v, parseInt(meta, 10));
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   121
                    } else {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   122
                        meta = meta || '';
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   123
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   124
                        // look for the keyword 'dump', if found force obj dump
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   125
                        dump = meta.indexOf(DUMP);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   126
                        if (dump > -1) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   127
                            meta = meta.substring(4);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   128
                        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   129
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   130
                        // use the toString if it is not the Object toString
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   131
                        // and the 'dump' meta info was not found
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   132
                        if (v.toString === Object.prototype.toString ||
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   133
                            dump > -1) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   134
                            v = Y.dump(v, parseInt(meta, 10));
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   135
                        } else {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   136
                            v = v.toString();
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   137
                        }
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
			} else if (L.isUndefined(v)) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   141
                // This {block} has no replace string. Save it for later.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   142
                v = '~-' + saved.length + '-~';
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   143
					saved.push(token);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   144
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   145
                // break;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   146
            }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   147
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   148
            s = s.substring(0, i) + v + s.substring(j + 1);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   149
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   150
			if (!recurse) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   151
				lidx = i - 1;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   152
			}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   153
		}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   154
		// restore saved {block}s and escaped braces
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   155
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   156
		return s
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   157
			.replace(savedRegExp, function (str, p1, p2) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   158
				return LBRACE + saved[parseInt(p2,10)] + RBRACE;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   159
			})
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   160
			.replace(lBraceRegExp, LBRACE)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   161
			.replace(rBraceRegExp, RBRACE)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   162
		;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   163
	};
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   164
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   165
    Y.substitute = substitute;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   166
    L.substitute = substitute;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   167
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   168
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   169
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   170
}, '@VERSION@', {"requires": ["yui-base"], "optional": ["dump"]});