GeneralException для insertContentControl () - PullRequest
0 голосов
/ 29 апреля 2020

У меня проблемы с insertContentControl() для некоторых (но не для большинства) диапазонов, возвращаемых search().

По сути, я ищу различные термины, а затем для каждой находки пытаюсь создать элемент управления контентом. В основном это работает, однако время от времени я получаю GeneralException, которое выглядит так:

{code: "GeneralException", message: "Sorry, something went wrong. Check the OfficeExtension.Error.debugInfo for more information. ", errorLocation: "Range.insertContentControl", statement: "var insertContentControl=v.insertContentControl();", toString: ƒ, …}
code: "GeneralException"
errorLocation: "Range.insertContentControl"
fullStatements: (7) ["var v=context.root._getObjectByReferenceId("{4a645…31b06a1e8cb}{205}") /* originally getItem(28) */;", "var insertContentControl=v.insertContentControl();", "// Instantiate {insertContentControl}", "insertContentControl.title="TypeOne";", "insertContentControl.color="yellow", "insertContentControl.tag="someTag";", "insertContentControl.appearance="Tags";"]
message: "Sorry, something went wrong. Check the OfficeExtension.Error.debugInfo for more information. "
statement: "var insertContentControl=v.insertContentControl();"
surroundingStatements: Array(9)
0: "var v=context.root._getObjectByReferenceId("{4a64573e-3807-4278-a22d-131b06a1e8cb}{205}") /* originally getItem(...) */;"
1: "// >>>>>"
2: "var insertContentControl=v.insertContentControl();"
3: "// <<<<<"
4: "// Instantiate {insertContentControl}"
5: "insertContentControl.title=...;"
6: "insertContentControl.color=...;"
7: "insertContentControl.tag=...;"
8: "insertContentControl.appearance=...;"
lastIndex: (...)
lastItem: (...)
length: 9

Вот упрощенная версия моего кода:

//This object may contain thousands of terms across multiple entity types
let entities = {
    EntityType1:{
            Term1: [],
            Term2: []
    }
}

await Word.run(async (context) => {    

    // search for terms
    for(let entityKey in entities) {    
        let terms = entities[entityKey]
        for(let termKey in terms){

            let searchResults = context.document.body.search(termKey, {matchWholeWord:true, matchCase: true});
            searchResults.load(["text", "parentContentControlOrNullObject"]);

            _.extend(terms[termKey], ({"searchHits": searchResults}))
        }
    }

    await context.sync()

    //add content controls for each found term

    for(let entityKey in entities) {    
        let terms = entities[entityKey]

        for(let termKey in terms){
            let term = terms[termKey];
            let searchHits = term.searchHits.items;

            for (const hit of searchHits) {

                //this always works
                //hit.font.highlightColor = EntityColors[entityKey]

                try {
                    let cc:Word.ContentControl = hit.parentContentControlOrNullObject

                    if(cc.isNullObject || cc.tag != appId){
                        cc = hit.insertContentControl()
                    }

                    cc.title = entityKey
                    cc.color = "yellow"
                    cc.tag = "someTag"
                    cc.appearance = "Tags"

                    //NB. this is here only for debugging - it really slows everything down
                    await context.sync()  

                } catch (error) {
                    if (error instanceof OfficeExtension.Error) {
                        console.log(error.debugInfo)
                        console.log(error.innerError)
                    }
                }
            }
        }
    }

    await context.sync()

})

Я внимательно изучил документ oo xml чтобы увидеть, было ли что-то общее с ошибочными диапазонами, но я не вижу ничего очевидного.

Я в основном тестирую на Word Online, но на рабочем столе Word, похоже, та же проблема.

Я просто не могу найти причину этого. Что еще я могу сделать, чтобы найти root проблемы?

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...