зеркало из https://github.com/electron/electron.git
create webui message handler
This commit is contained in:
Родитель
8a2b9c893e
Коммит
a2db14476a
|
@ -4,6 +4,8 @@
|
|||
|
||||
#include "atom/browser/atom_web_ui_controller_factory.h"
|
||||
|
||||
#include "atom/browser/ui/webui/pdf_viewer_handler.h"
|
||||
#include "base/memory/ptr_util.h"
|
||||
#include "base/strings/string_util.h"
|
||||
#include "base/strings/string_split.h"
|
||||
#include "content/public/browser/render_view_host.h"
|
||||
|
@ -107,29 +109,17 @@ class PdfViewerUI : public content::WebUIController {
|
|||
content::WebUI* web_ui,
|
||||
const std::string& stream_url,
|
||||
const std::string& original_url)
|
||||
: content::WebUIController(web_ui),
|
||||
stream_url_(stream_url),
|
||||
original_url_(original_url) {
|
||||
web_ui->RegisterMessageCallback(
|
||||
"initialize",
|
||||
base::Bind(&PdfViewerUI::OnInitialize, base::Unretained(this)));
|
||||
: content::WebUIController(web_ui) {
|
||||
web_ui->AddMessageHandler(new PdfViewerHandler(stream_url, original_url));
|
||||
content::URLDataSource::Add(browser_context, new BundledDataSource);
|
||||
}
|
||||
|
||||
// content::WebUIController implementation.
|
||||
void RenderViewCreated(content::RenderViewHost* rvh) override {
|
||||
rvh->AllowBindings(content::BINDINGS_POLICY_WEB_UI);
|
||||
}
|
||||
|
||||
void OnInitialize(const base::ListValue* args) {
|
||||
web_ui()->CallJavascriptFunctionUnsafe("main",
|
||||
base::StringValue(original_url_),
|
||||
base::StringValue(original_url_));
|
||||
}
|
||||
|
||||
private:
|
||||
std::string stream_url_;
|
||||
std::string original_url_;
|
||||
|
||||
DISALLOW_COPY_AND_ASSIGN(PdfViewerUI);
|
||||
};
|
||||
}
|
||||
|
|
|
@ -19,6 +19,7 @@ class AtomWebUIControllerFactory : public content::WebUIControllerFactory {
|
|||
AtomWebUIControllerFactory();
|
||||
virtual ~AtomWebUIControllerFactory();
|
||||
|
||||
// content::WebUIControllerFactory:
|
||||
content::WebUI::TypeID GetWebUIType(content::BrowserContext* browser_context,
|
||||
const GURL& url) const override;
|
||||
bool UseWebUIForURL(content::BrowserContext* browser_context,
|
||||
|
|
Двоичные данные
atom/browser/resources/pdf_viewer/ods-cpp.pdf
Двоичные данные
atom/browser/resources/pdf_viewer/ods-cpp.pdf
Двоичный файл не отображается.
|
@ -0,0 +1,51 @@
|
|||
// Copyright (c) 2017 GitHub, Inc.
|
||||
// Use of this source code is governed by the MIT license that can be
|
||||
// found in the LICENSE file.
|
||||
|
||||
#include "atom/browser/ui/webui/pdf_viewer_handler.h"
|
||||
|
||||
#include "base/bind.h"
|
||||
#include "base/bind_helpers.h"
|
||||
#include "base/values.h"
|
||||
#include "content/public/browser/web_contents.h"
|
||||
#include "content/public/browser/web_ui.h"
|
||||
|
||||
namespace atom {
|
||||
|
||||
PdfViewerHandler::PdfViewerHandler(const std::string& stream_url,
|
||||
const std::string& original_url)
|
||||
: stream_url_(stream_url), original_url_(original_url) {}
|
||||
|
||||
PdfViewerHandler::~PdfViewerHandler() {}
|
||||
|
||||
void PdfViewerHandler::RegisterMessages() {
|
||||
web_ui()->RegisterMessageCallback(
|
||||
"initialize",
|
||||
base::Bind(&PdfViewerHandler::Initialize, base::Unretained(this)));
|
||||
web_ui()->RegisterMessageCallback(
|
||||
"getTabId",
|
||||
base::Bind(&PdfViewerHandler::GetTabId, base::Unretained(this)));
|
||||
}
|
||||
|
||||
void PdfViewerHandler::Initialize(const base::ListValue* args) {
|
||||
AllowJavascript();
|
||||
|
||||
CHECK_EQ(1U, args->GetSize());
|
||||
const base::Value* callback_id;
|
||||
CHECK(args->Get(0, &callback_id));
|
||||
std::unique_ptr<base::DictionaryValue> stream_info(new base::DictionaryValue);
|
||||
stream_info->SetString("streamURL", stream_url_);
|
||||
stream_info->SetString("originalURL", original_url_);
|
||||
ResolveJavascriptCallback(*callback_id, *stream_info);
|
||||
}
|
||||
|
||||
void PdfViewerHandler::GetTabId(const base::ListValue* args) {
|
||||
if (!IsJavascriptAllowed())
|
||||
return;
|
||||
CHECK_EQ(1U, args->GetSize());
|
||||
const base::Value* callback_id;
|
||||
CHECK(args->Get(0, &callback_id));
|
||||
ResolveJavascriptCallback(*callback_id, base::FundamentalValue(-1));
|
||||
}
|
||||
|
||||
} // namespace atom
|
|
@ -0,0 +1,41 @@
|
|||
// Copyright (c) 2017 GitHub, Inc.
|
||||
// Use of this source code is governed by the MIT license that can be
|
||||
// found in the LICENSE file.
|
||||
|
||||
#ifndef ATOM_BROWSER_UI_WEBUI_PDF_VIEWER_HANDLER_H_
|
||||
#define ATOM_BROWSER_UI_WEBUI_PDF_VIEWER_HANDLER_H_
|
||||
|
||||
#include <string>
|
||||
|
||||
#include "base/compiler_specific.h"
|
||||
#include "base/macros.h"
|
||||
#include "content/public/browser/web_ui_message_handler.h"
|
||||
|
||||
namespace base {
|
||||
class ListValue;
|
||||
}
|
||||
|
||||
namespace atom {
|
||||
|
||||
class PdfViewerHandler : public content::WebUIMessageHandler {
|
||||
public:
|
||||
PdfViewerHandler(const std::string& stream_url,
|
||||
const std::string& original_url);
|
||||
~PdfViewerHandler() override;
|
||||
|
||||
// WebUIMessageHandler implementation.
|
||||
void RegisterMessages() override;
|
||||
|
||||
private:
|
||||
void Initialize(const base::ListValue* args);
|
||||
void GetTabId(const base::ListValue* args);
|
||||
|
||||
std::string stream_url_;
|
||||
std::string original_url_;
|
||||
|
||||
DISALLOW_COPY_AND_ASSIGN(PdfViewerHandler);
|
||||
};
|
||||
|
||||
} // namespace atom
|
||||
|
||||
#endif // ATOM_BROWSER_UI_WEBUI_PDF_VIEWER_HANDLER_H_
|
|
@ -329,6 +329,8 @@
|
|||
'atom/browser/ui/views/submenu_button.h',
|
||||
'atom/browser/ui/views/win_frame_view.cc',
|
||||
'atom/browser/ui/views/win_frame_view.h',
|
||||
'atom/browser/ui/webui/pdf_viewer_handler.cc',
|
||||
'atom/browser/ui/webui/pdf_viewer_handler.h',
|
||||
'atom/browser/ui/win/atom_desktop_native_widget_aura.cc',
|
||||
'atom/browser/ui/win/atom_desktop_native_widget_aura.h',
|
||||
'atom/browser/ui/win/atom_desktop_window_tree_host_win.cc',
|
||||
|
@ -622,7 +624,6 @@
|
|||
'chromium_src/net/test/embedded_test_server/tcp_listen_socket.h',
|
||||
'<@(native_mate_files)',
|
||||
'<(SHARED_INTERMEDIATE_DIR)/atom_natives.h',
|
||||
'<(SHARED_INTERMEDIATE_DIR)/grit/pdf_viewer_resources.h',
|
||||
'<(SHARED_INTERMEDIATE_DIR)/grit/pdf_viewer_resources_map.cc',
|
||||
'<(SHARED_INTERMEDIATE_DIR)/grit/pdf_viewer_resources_map.h',
|
||||
],
|
||||
|
|
|
@ -76,7 +76,7 @@ if (window.location.protocol === 'chrome-devtools:') {
|
|||
// Override some inspector APIs.
|
||||
require('./inspector')
|
||||
nodeIntegration = 'true'
|
||||
} else if (window.location.protocol === 'chrome-extension:' || window.location.protocol === 'chrome:') {
|
||||
} else if (window.location.protocol === 'chrome-extension:') {
|
||||
// Add implementations of chrome API.
|
||||
require('./chrome-api').injectTo(window.location.hostname, isBackgroundPage, window)
|
||||
nodeIntegration = 'false'
|
||||
|
|
Загрузка…
Ссылка в новой задаче