compromise
Version:
modest natural language processing
40 lines (38 loc) • 933 B
JavaScript
const toText = function (term) {
let pre = term.pre || ''
let post = term.post || ''
return pre + term.text + post
}
const findStarts = function (doc, obj) {
let starts = {}
Object.keys(obj).forEach(reg => {
let m = doc.match(reg)
m.fullPointer.forEach(a => {
starts[a[3]] = { fn: obj[reg], end: a[2] }
})
})
return starts
}
const wrap = function (doc, obj) {
// index ids to highlight
let starts = findStarts(doc, obj)
let text = ''
doc.docs.forEach((terms, n) => {
for (let i = 0; i < terms.length; i += 1) {
let t = terms[i]
// do a span tag
if (starts.hasOwnProperty(t.id)) {
let { fn, end } = starts[t.id]
let m = doc.update([[n, i, end]])
text += terms[i].pre || ''
text += fn(m)
i = end - 1
text += terms[i].post || ''
} else {
text += toText(t)
}
}
})
return text
}
export default wrap