javascript - Chrome Gmail 扩展程序在某些情况下不起作用。为什么?

标签 javascript google-chrome-extension inbox

我正在开发 Chrome 扩展程序。在 Chrome 中打开本地 PDF 文件时,通过单击扩展程序图标,它会打开一个带有 gmail.com 的新选项卡(和撰写 View ),并将打开的文件附加到新电子邮件中。

使用“普通”Gmail 帐户即可正常工作。问题是,如果我使用带有别名发件人的帐户(例如个人和企业),则附加并不总是发生。有时它会附加文件,有时则不会。如果失败,控制台中会显示以下错误消息:www.inboxsdk.com/build/platform-implementation.js:18 记录错误:错误:无法找到 dropzone

代码有什么问题?

app.js

var content = {
init() {
    //this is gmail page
    InboxSDK.load(2, 'sdk_Add-Attachment_df7347fce8').then((sdk) => {
        chrome.runtime.sendMessage({
            message: "getFile",
        }, (response) => {
            if (response.file != 'No File Found') {
                sdk.Compose.registerComposeViewHandler((composeView) => {
                    chrome.runtime.sendMessage({
                        message: "getFile",
                    }, (response) => {
                        console.log("uploaded file", response.file);
                        if (response.file != 'No File Found') {
                            var fileData = content.base64ToArrayBuffer(response.file);
                            var file = new File([fileData], response.fileName, {
                                type: response.fileType
                            });
                            composeView.attachFiles([file]);
                            chrome.runtime.sendMessage({
                                message: "deleteFile",
                            });
                        }
                    });
                });
                sdk.Compose.openNewComposeView().then((composeView) => {
                    console.log("composeView is", composeView);
                });
            } else {
                console.log("No file to add");
            }
        });
    });
},
base64ToArrayBuffer(base64) {
    var binaryString = window.atob(base64);
    var binaryLen = binaryString.length;
    var bytes = new Uint8Array(binaryLen);
    for (var i = 0; i < binaryLen; i++) {
        var ascii = binaryString.charCodeAt(i);
        bytes[i] = ascii;
    }
    return bytes;
}
};
$(document).ready(() => {
    content.init();
})

背景.js:

chrome.browserAction.onClicked.addListener(function(tab) {
if (tab.url.indexOf("file://") != -1) {
    //this is file page
    localStorage.setItem('FileUrl', tab.url);
    console.log('Saved file to be attached', tab.url);
    window.open('https://mail.google.com');
} else {
    alert("Please open tab with url beginning with file:// and try again.");
}
});

chrome.runtime.onMessage.addListener((request, sender, sendResponse) => {
    if (request.message == "getFile") {
        var request = new XMLHttpRequest();
        var fileUrl = localStorage.getItem('FileUrl');
        if (fileUrl != 'undefined' && fileUrl != null) {
            var fileName = fileUrl.split('/').pop();
            request.open('GET', fileUrl, true);
            request.responseType = 'blob';
            request.onload = function() {
                var reader = new FileReader();
                reader.readAsDataURL(request.response);
                reader.onload = function(e) {
                    console.log('DataURL:', e.target.result);
                    const byteString = atob(e.target.result.split('base64,')[1]);
                    const ab = new ArrayBuffer(byteString.length);
                    const ia = new Uint8Array(ab);
                    for (let i = 0; i < byteString.length; i += 1) {
                        ia[i] = byteString.charCodeAt(i);
                    }
                    const newBlob = new Blob([ab], {
                        type: 'application/pdf'
                    });
                    sendResponse({
                        file: e.target.result.split('base64,')[1],
                        fileName: fileName,
                        fileType: 'application/pdf'
                    });
                };
            };
            request.send();
        } else {
            sendResponse({
                file: 'No File Found'
            });
        }
        return true;
    } else if (request.message == "deleteFile") {
        localStorage.removeItem('FileUrl');
        return true;
    }
});

最佳答案

使用以下代码代替 composeView.attachFiles([file]):

composeView.getBodyElement().focus();
setTimeout(function() {composeView.attachFiles([file])}, 1000);

或者,另一种选择:

composeView.attachInlineFiles([file]);

关于javascript - Chrome Gmail 扩展程序在某些情况下不起作用。为什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58258968/

相关文章:

javascript - NestJS - 如何在主应用程序模块文件中使用 .env 变量进行数据库连接

javascript - PHP脚本获取数组中的数据库值以在下拉列表中查看

javascript - 使用 Javascript 命名空间中的严格模式

javascript - 在 Ruby 注入(inject)的 JavaScript 中转义撇号?

javascript - 如何使用文件系统 API 重命名 Chrome 应用程序中的文件?

javascript - Chrome 扩展程序在特定选项卡上运行该进程

PHP 删除收件箱无法正常工作

javascript - Chrome 扩展 - 修改 Google 日历事件 UI 以通过输入字段接受扩展属性

gmail - 如何使用Google收件箱发送到 "group contact"或通讯组列表

php - 从表中打印记录但不打印重复项