You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
50 lines
1.4 KiB
50 lines
1.4 KiB
/** |
|
* @fileoverview Interpolate keys from an object into a string with {{ }} markers. |
|
* @author Jed Fox |
|
*/ |
|
|
|
"use strict"; |
|
|
|
//------------------------------------------------------------------------------ |
|
// Public Interface |
|
//------------------------------------------------------------------------------ |
|
|
|
/** |
|
* Returns a global expression matching placeholders in messages. |
|
* @returns {RegExp} Global regular expression matching placeholders |
|
*/ |
|
function getPlaceholderMatcher() { |
|
return /\{\{([^{}]+?)\}\}/gu; |
|
} |
|
|
|
/** |
|
* Replaces {{ placeholders }} in the message with the provided data. |
|
* Does not replace placeholders not available in the data. |
|
* @param {string} text Original message with potential placeholders |
|
* @param {Record<string, string>} data Map of placeholder name to its value |
|
* @returns {string} Message with replaced placeholders |
|
*/ |
|
function interpolate(text, data) { |
|
if (!data) { |
|
return text; |
|
} |
|
|
|
const matcher = getPlaceholderMatcher(); |
|
|
|
// Substitution content for any {{ }} markers. |
|
return text.replace(matcher, (fullMatch, termWithWhitespace) => { |
|
const term = termWithWhitespace.trim(); |
|
|
|
if (term in data) { |
|
return data[term]; |
|
} |
|
|
|
// Preserve old behavior: If parameter name not provided, don't replace it. |
|
return fullMatch; |
|
}); |
|
} |
|
|
|
module.exports = { |
|
getPlaceholderMatcher, |
|
interpolate |
|
};
|
|
|