mirror of
https://github.com/ether/etherpad-lite.git
synced 2025-01-19 14:13:34 +01:00
ImportHtml: In-line an unnecessary function
This commit is contained in:
parent
afdb01681a
commit
50dce085c2
1 changed files with 14 additions and 18 deletions
|
@ -66,8 +66,11 @@ exports.setPadHTML = async (pad, html) => {
|
||||||
apiLogger.debug(newText);
|
apiLogger.debug(newText);
|
||||||
const newAttribs = `${result.lineAttribs.join('|1+1')}|1+1`;
|
const newAttribs = `${result.lineAttribs.join('|1+1')}|1+1`;
|
||||||
|
|
||||||
const eachAttribRun = (attribs, func /* (startInNewText, endInNewText, attribs)*/) => {
|
// create a new changeset with a helper builder object
|
||||||
const attribsIter = Changeset.opIterator(attribs);
|
const builder = Changeset.builder(1);
|
||||||
|
|
||||||
|
// assemble each line into the builder
|
||||||
|
const attribsIter = Changeset.opIterator(newAttribs);
|
||||||
let textIndex = 0;
|
let textIndex = 0;
|
||||||
const newTextStart = 0;
|
const newTextStart = 0;
|
||||||
const newTextEnd = newText.length;
|
const newTextEnd = newText.length;
|
||||||
|
@ -75,19 +78,12 @@ exports.setPadHTML = async (pad, html) => {
|
||||||
const op = attribsIter.next();
|
const op = attribsIter.next();
|
||||||
const nextIndex = textIndex + op.chars;
|
const nextIndex = textIndex + op.chars;
|
||||||
if (!(nextIndex <= newTextStart || textIndex >= newTextEnd)) {
|
if (!(nextIndex <= newTextStart || textIndex >= newTextEnd)) {
|
||||||
func(Math.max(newTextStart, textIndex), Math.min(newTextEnd, nextIndex), op.attribs);
|
const start = Math.max(newTextStart, textIndex);
|
||||||
|
const end = Math.min(newTextEnd, nextIndex);
|
||||||
|
builder.insert(newText.substring(start, end), op.attribs);
|
||||||
}
|
}
|
||||||
textIndex = nextIndex;
|
textIndex = nextIndex;
|
||||||
}
|
}
|
||||||
};
|
|
||||||
|
|
||||||
// create a new changeset with a helper builder object
|
|
||||||
const builder = Changeset.builder(1);
|
|
||||||
|
|
||||||
// assemble each line into the builder
|
|
||||||
eachAttribRun(newAttribs, (start, end, attribs) => {
|
|
||||||
builder.insert(newText.substring(start, end), attribs);
|
|
||||||
});
|
|
||||||
|
|
||||||
// the changeset is ready!
|
// the changeset is ready!
|
||||||
const theChangeset = builder.toString();
|
const theChangeset = builder.toString();
|
||||||
|
|
Loading…
Reference in a new issue