Функция onSend в Microsoft Office не позволяет отправлять почту, если диалог открыт через API displayDialogAsync
Я пытаюсь реализовать функцию "Отправить" в надстройке Outlook. Все предпосылки выполнены. Он работает нормально, как нормальный сценарий, как указано в документации. Но для моего случая это требование:
Если в Body содержится какое-либо "блочное слово", я хочу показать пользователю диалоговое окно (используя displayDialogAsync API) с двумя опциями "Продолжить" и "Отмена". Без диалогового окна позволяет отправлять почту, но с диалоговым окном это не работает.
var mailboxItem;
Office.initialize = function (reason) {
mailboxItem = Office.context.mailbox.item;
}
function validateBody(event) {
mailboxItem.body.getAsync("html", { asyncContext: event },
checkBodyOnlyOnSendCallBack);
}
function checkBodyOnlyOnSendCallBack(bodyAsyncResult) {
var listOfBlockedWords = new Array("blockedword", "blockedword1", "blockedword2");
var wordExpression = listOfBlockedWords.join('|');
// \b to perform a "whole words only" search using a regular expression in the form of \bword\b.
// i to perform case-insensitive search.
var regexCheck = new RegExp('\\b(' + wordExpression + ')\\b', 'i');
var checkBody = regexCheck.test(asyncResult.value);
if (checkBody) {
mailboxItem.notificationMessages.addAsync('NoSend', { type: 'errorMessage', message: 'Blocked words have been found in the body of this email. Please remove them.' });
var dialog;
Office.context.ui.displayDialogAsync(location.origin+'#/urlpath?queryString', {
height: 40,
width: 40,
displayInIframe: true
}, function(asyncResult) {
dialog = asyncResult.value;
//used - Office.context.ui.messageParent() to acces the following block;
dialog.addEventHandler(Office.EventType.DialogMessageReceived, function(args) {
if(args.status){
// Allow send.
bodyAsyncResult.asyncContext.completed({ allowEvent: true });
}else{
// Block send.
bodyAsyncResult.asyncContext.completed({ allowEvent: false });
}
dialog.close();
event.completed();
});
});
}else{
// Allow send.
bodyAsyncResult.asyncContext.completed({ allowEvent: true });
}