Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(942)

Side by Side Diff: chrome/browser/ui/webui/extensions/extensions_ui.cc

Issue 1319163004: [Extensions Page MD] Stub out a materialized extensions page (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Nits Created 5 years, 3 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "chrome/browser/ui/webui/extensions/extensions_ui.h" 5 #include "chrome/browser/ui/webui/extensions/extensions_ui.h"
6 6
7 #include "chrome/browser/profiles/profile.h" 7 #include "chrome/browser/profiles/profile.h"
8 #include "chrome/browser/ui/webui/extensions/extension_loader_handler.h" 8 #include "chrome/browser/ui/webui/extensions/extension_loader_handler.h"
9 #include "chrome/browser/ui/webui/extensions/extension_settings_handler.h" 9 #include "chrome/browser/ui/webui/extensions/extension_settings_handler.h"
10 #include "chrome/browser/ui/webui/extensions/install_extension_handler.h" 10 #include "chrome/browser/ui/webui/extensions/install_extension_handler.h"
11 #include "chrome/browser/ui/webui/metrics_handler.h" 11 #include "chrome/browser/ui/webui/metrics_handler.h"
12 #include "chrome/common/chrome_switches.h"
12 #include "chrome/common/url_constants.h" 13 #include "chrome/common/url_constants.h"
14 #include "chrome/grit/generated_resources.h"
13 #include "content/public/browser/web_ui.h" 15 #include "content/public/browser/web_ui.h"
14 #include "content/public/browser/web_ui_data_source.h" 16 #include "content/public/browser/web_ui_data_source.h"
15 #include "grit/browser_resources.h" 17 #include "grit/browser_resources.h"
16 #include "grit/theme_resources.h" 18 #include "grit/theme_resources.h"
17 #include "ui/base/resource/resource_bundle.h" 19 #include "ui/base/resource/resource_bundle.h"
18 20
19 #if defined(OS_CHROMEOS) 21 #if defined(OS_CHROMEOS)
20 #include "chrome/browser/chromeos/ownership/owner_settings_service_chromeos_fact ory.h" 22 #include "chrome/browser/chromeos/ownership/owner_settings_service_chromeos_fact ory.h"
21 #include "chrome/browser/ui/webui/extensions/chromeos/kiosk_apps_handler.h" 23 #include "chrome/browser/ui/webui/extensions/chromeos/kiosk_apps_handler.h"
22 #endif 24 #endif
23 25
24 namespace extensions { 26 namespace extensions {
25 27
26 namespace { 28 namespace {
27 29
30 content::WebUIDataSource* CreateMdExtensionsSource() {
31 content::WebUIDataSource* source =
32 content::WebUIDataSource::Create(chrome::kChromeUIExtensionsHost);
33
34 source->SetJsonPath("strings.js");
35 source->AddLocalizedString("title",
36 IDS_MANAGE_EXTENSIONS_SETTING_WINDOWS_TITLE);
37 source->AddResourcePath("manager.html", IDR_MD_EXTENSIONS_MANAGER_HTML);
38 source->AddResourcePath("manager.js", IDR_MD_EXTENSIONS_MANAGER_JS);
39 source->AddResourcePath("strings.html", IDR_MD_EXTENSIONS_STRINGS_HTML);
40 source->SetDefaultResource(IDR_MD_EXTENSIONS_EXTENSIONS_HTML);
41
42 return source;
43 }
44
28 content::WebUIDataSource* CreateExtensionsHTMLSource() { 45 content::WebUIDataSource* CreateExtensionsHTMLSource() {
29 content::WebUIDataSource* source = 46 content::WebUIDataSource* source =
30 content::WebUIDataSource::Create(chrome::kChromeUIExtensionsFrameHost); 47 content::WebUIDataSource::Create(chrome::kChromeUIExtensionsFrameHost);
31 48
32 source->SetJsonPath("strings.js"); 49 source->SetJsonPath("strings.js");
33 source->AddResourcePath("extensions.js", IDR_EXTENSIONS_JS); 50 source->AddResourcePath("extensions.js", IDR_EXTENSIONS_JS);
34 source->AddResourcePath("extension_command_list.js", 51 source->AddResourcePath("extension_command_list.js",
35 IDR_EXTENSION_COMMAND_LIST_JS); 52 IDR_EXTENSION_COMMAND_LIST_JS);
36 source->AddResourcePath("extension_list.js", IDR_EXTENSION_LIST_JS); 53 source->AddResourcePath("extension_list.js", IDR_EXTENSION_LIST_JS);
37 source->SetDefaultResource(IDR_EXTENSIONS_HTML); 54 source->SetDefaultResource(IDR_EXTENSIONS_HTML);
38 source->DisableDenyXFrameOptions(); 55 source->DisableDenyXFrameOptions();
39 return source; 56 return source;
40 } 57 }
41 58
42 } // namespace 59 } // namespace
43 60
44 ExtensionsUI::ExtensionsUI(content::WebUI* web_ui) : WebUIController(web_ui) { 61 ExtensionsUI::ExtensionsUI(content::WebUI* web_ui) : WebUIController(web_ui) {
45 Profile* profile = Profile::FromWebUI(web_ui); 62 Profile* profile = Profile::FromWebUI(web_ui);
46 content::WebUIDataSource* source = CreateExtensionsHTMLSource(); 63 content::WebUIDataSource* source = nullptr;
47 64
48 ExtensionSettingsHandler* handler = new ExtensionSettingsHandler(); 65 if (::switches::MdExtensionsEnabled()) {
49 handler->GetLocalizedValues(source); 66 source = CreateMdExtensionsSource();
50 web_ui->AddMessageHandler(handler); 67 } else {
68 source = CreateExtensionsHTMLSource();
51 69
52 ExtensionLoaderHandler* extension_loader_handler = 70 ExtensionSettingsHandler* handler = new ExtensionSettingsHandler();
53 new ExtensionLoaderHandler(profile); 71 handler->GetLocalizedValues(source);
54 extension_loader_handler->GetLocalizedValues(source); 72 web_ui->AddMessageHandler(handler);
55 web_ui->AddMessageHandler(extension_loader_handler);
56 73
57 InstallExtensionHandler* install_extension_handler = 74 ExtensionLoaderHandler* extension_loader_handler =
58 new InstallExtensionHandler(); 75 new ExtensionLoaderHandler(profile);
59 install_extension_handler->GetLocalizedValues(source); 76 extension_loader_handler->GetLocalizedValues(source);
60 web_ui->AddMessageHandler(install_extension_handler); 77 web_ui->AddMessageHandler(extension_loader_handler);
78
79 InstallExtensionHandler* install_extension_handler =
80 new InstallExtensionHandler();
81 install_extension_handler->GetLocalizedValues(source);
82 web_ui->AddMessageHandler(install_extension_handler);
61 83
62 #if defined(OS_CHROMEOS) 84 #if defined(OS_CHROMEOS)
63 chromeos::KioskAppsHandler* kiosk_app_handler = 85 chromeos::KioskAppsHandler* kiosk_app_handler =
64 new chromeos::KioskAppsHandler( 86 new chromeos::KioskAppsHandler(
65 chromeos::OwnerSettingsServiceChromeOSFactory::GetForBrowserContext( 87 chromeos::OwnerSettingsServiceChromeOSFactory::GetForBrowserContext(
66 profile)); 88 profile));
67 kiosk_app_handler->GetLocalizedValues(source); 89 kiosk_app_handler->GetLocalizedValues(source);
68 web_ui->AddMessageHandler(kiosk_app_handler); 90 web_ui->AddMessageHandler(kiosk_app_handler);
69 #endif 91 #endif
70 92
71 web_ui->AddMessageHandler(new MetricsHandler()); 93 web_ui->AddMessageHandler(new MetricsHandler());
72 94
73 // Need to allow <object> elements so that the <extensionoptions> browser 95 // Need to allow <object> elements so that the <extensionoptions> browser
74 // plugin can be loaded within chrome://extensions. 96 // plugin can be loaded within chrome://extensions.
75 source->OverrideContentSecurityPolicyObjectSrc("object-src 'self';"); 97 source->OverrideContentSecurityPolicyObjectSrc("object-src 'self';");
98 }
76 99
77 content::WebUIDataSource::Add(profile, source); 100 content::WebUIDataSource::Add(profile, source);
78 } 101 }
79 102
80 ExtensionsUI::~ExtensionsUI() {} 103 ExtensionsUI::~ExtensionsUI() {}
81 104
82 // static 105 // static
83 base::RefCountedMemory* ExtensionsUI::GetFaviconResourceBytes( 106 base::RefCountedMemory* ExtensionsUI::GetFaviconResourceBytes(
84 ui::ScaleFactor scale_factor) { 107 ui::ScaleFactor scale_factor) {
85 ui::ResourceBundle& rb = ui::ResourceBundle::GetSharedInstance(); 108 ui::ResourceBundle& rb = ui::ResourceBundle::GetSharedInstance();
86 return rb.LoadDataResourceBytesForScale(IDR_EXTENSIONS_FAVICON, scale_factor); 109 return rb.LoadDataResourceBytesForScale(IDR_EXTENSIONS_FAVICON, scale_factor);
87 } 110 }
88 111
89 } // namespace extensions 112 } // namespace extensions
OLDNEW
« no previous file with comments | « chrome/browser/ui/webui/chrome_web_ui_controller_factory.cc ('k') | chrome/common/chrome_switches.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698