Version 3.18.1
Show:

File: substitute/js/substitute.js

            /**
             * String variable substitution and string formatting.
             * If included, the substitute method is added to the YUI instance.
             *
             * @module substitute
             * @deprecated
             */
            
                var L = Y.Lang, DUMP = 'dump', SPACE = ' ', LBRACE = '{', RBRACE = '}',
            		savedRegExp =  /(~-(\d+)-~)/g, lBraceRegExp = /\{LBRACE\}/g, rBraceRegExp = /\{RBRACE\}/g,
            
                /**
                 * The following methods are added to the YUI instance
                 *
                 * <strong>Use `Y.Lang.sub` or `Y.Template` instead.</strong>
                 * @class YUI~substitute
                 * @deprecated
                 */
            
            /**
            <strong>Use `Y.Lang.sub` or `Y.Template` instead.</strong>
            
            
            
            Does `{placeholder}` substitution on a string.  The object passed as the
            second parameter provides values to replace the `{placeholder}`s.
            {placeholder} token names must match property names of the object.  For
            example
            
            `var greeting = Y.substitute("Hello, {who}!", { who: "World" });`
            
            `{placeholder}` tokens that are undefined on the object map will be left in
            tact (leaving unsightly "{placeholder}"s in the output string).  If your
            replacement strings *should* include curly braces, use `{LBRACE}` and
            `{RBRACE}` in your object map string value.
            
            If a function is passed as a third argument, it will be called for each
            {placeholder} found.  The {placeholder} name is passed as the first value
            and the value from the object map is passed as the second.  If the
            {placeholder} contains a space, the first token will be used to identify
            the object map property and the remainder will be passed as a third
            argument to the function.  See below for an example.
            
            If the value in the object map for a given {placeholder} is an object and
            the `dump` module is loaded, the replacement value will be the string
            result of calling `Y.dump(...)` with the object as input.  Include a
            numeric second token in the {placeholder} to configure the depth of the call
            to `Y.dump(...)`, e.g. "{someObject 2}".  See the
            <a href="../classes/YUI.html#method_dump">`dump`</a> method for details.
            
                @method substitute
                @deprecated
                @param {string} s The string that will be modified.
                @param {object} o An object containing the replacement values.
                @param {function} f An optional function that can be used to
                                    process each match.  It receives the key,
                                    value, and any extra metadata included with
                                    the key inside of the braces.
                @param {boolean} recurse if true, the replacement will be recursive,
                                    letting you have replacement tokens in replacement text.
                                    The default is false.
                @return {string} the substituted string.
            
                @example
            
                    function getAttrVal(key, value, name) {
                        // Return a string describing the named attribute and its value if
                        // the first token is @. Otherwise, return the value from the
                        // replacement object.
                        if (key === "@") {
                            value += name + " Value: " + myObject.get(name);
                        }
                        return value;
                    }
            
                    // Assuming myObject.set('foo', 'flowers'),
                    // => "Attr: foo Value: flowers"
                    var attrVal = Y.substitute("{@ foo}", { "@": "Attr: " }, getAttrVal);
                **/
            
                substitute = function(s, o, f, recurse) {
                    var i, j, k, key, v, meta, saved = [], token, dump,
                        lidx = s.length;
            
                    for (;;) {
                        i = s.lastIndexOf(LBRACE, lidx);
                        if (i < 0) {
                            break;
                        }
                        j = s.indexOf(RBRACE, i);
                        if (i + 1 >= j) {
                            break;
                        }
            
                        //Extract key and meta info
                        token = s.substring(i + 1, j);
                        key = token;
                        meta = null;
                        k = key.indexOf(SPACE);
                        if (k > -1) {
                            meta = key.substring(k + 1);
                            key = key.substring(0, k);
                        }
            
                        // lookup the value
                        v = o[key];
            
                        // if a substitution function was provided, execute it
                        if (f) {
                            v = f(key, v, meta);
                        }
            
                        if (L.isObject(v)) {
                            if (!Y.dump) {
                                v = v.toString();
                            } else {
                                if (L.isArray(v)) {
                                    v = Y.dump(v, parseInt(meta, 10));
                                } else {
                                    meta = meta || '';
            
                                    // look for the keyword 'dump', if found force obj dump
                                    dump = meta.indexOf(DUMP);
                                    if (dump > -1) {
                                        meta = meta.substring(4);
                                    }
            
                                    // use the toString if it is not the Object toString
                                    // and the 'dump' meta info was not found
                                    if (v.toString === Object.prototype.toString ||
                                        dump > -1) {
                                        v = Y.dump(v, parseInt(meta, 10));
                                    } else {
                                        v = v.toString();
                                    }
                                }
                            }
            			} else if (L.isUndefined(v)) {
                            // This {block} has no replace string. Save it for later.
                            v = '~-' + saved.length + '-~';
            					saved.push(token);
            
                            // break;
                        }
            
                        s = s.substring(0, i) + v + s.substring(j + 1);
            
            			if (!recurse) {
            				lidx = i - 1;
            			}
            		}
            		// restore saved {block}s and escaped braces
            
            		return s
            			.replace(savedRegExp, function (str, p1, p2) {
            				return LBRACE + saved[parseInt(p2,10)] + RBRACE;
            			})
            			.replace(lBraceRegExp, LBRACE)
            			.replace(rBraceRegExp, RBRACE)
            		;
            	};
            
                Y.substitute = substitute;
                L.substitute = substitute;