2020-11-19 10:24:58 +01:00
|
|
|
import mustache from "mustache"
|
|
|
|
|
|
|
|
// this is a much more liberal version of mustache's escape function
|
|
|
|
// ...just ignoring < and > to prevent tags from user input
|
|
|
|
// original version here https://github.com/janl/mustache.js/blob/4b7908f5c9fec469a11cfaed2f2bed23c84e1c5c/mustache.js#L78
|
|
|
|
const entityMap = {
|
|
|
|
"<": "<",
|
|
|
|
">": ">",
|
|
|
|
}
|
|
|
|
mustache.escape = text => {
|
2020-11-24 12:13:26 +01:00
|
|
|
if (text == null || typeof text !== "string") {
|
|
|
|
return text
|
|
|
|
}
|
2020-11-19 10:24:58 +01:00
|
|
|
return text.replace(/[<>]/g, function fromEntityMap(s) {
|
|
|
|
return entityMap[s] || s
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
// Regex to test inputs with to see if they are likely candidates for mustache
|
|
|
|
const looksLikeMustache = /{{.*}}/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Enriches a given input with a row from the database.
|
|
|
|
*/
|
2020-11-20 10:50:10 +01:00
|
|
|
export const enrichDataBinding = (input, context) => {
|
2020-11-19 10:24:58 +01:00
|
|
|
// Only accept string inputs
|
|
|
|
if (!input || typeof input !== "string") {
|
|
|
|
return input
|
|
|
|
}
|
|
|
|
// Do a fast regex check if this looks like a mustache string
|
|
|
|
if (!looksLikeMustache.test(input)) {
|
|
|
|
return input
|
|
|
|
}
|
|
|
|
return mustache.render(input, context)
|
|
|
|
}
|
2020-11-25 10:50:51 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Enriches each prop in a props object
|
|
|
|
*/
|
|
|
|
export const enrichDataBindings = (props, context) => {
|
|
|
|
let enrichedProps = {}
|
|
|
|
Object.entries(props).forEach(([key, value]) => {
|
|
|
|
enrichedProps[key] = enrichDataBinding(value, context)
|
|
|
|
})
|
|
|
|
return enrichedProps
|
|
|
|
}
|