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

Side by Side Diff: chrome/browser/accessibility/accessibility_extension_api.cc

Issue 14473011: Adds new experimental accessibility extension api to enable or disable native accessibility. (Closed) Base URL: http://git.chromium.org/chromium/src.git@master
Patch Set: Added new API to enable/disable web accessibility. Created 7 years, 7 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/accessibility/accessibility_extension_api.h" 5 #include "chrome/browser/accessibility/accessibility_extension_api.h"
6 6
7 #include "base/json/json_writer.h" 7 #include "base/json/json_writer.h"
8 #include "base/strings/string_number_conversions.h" 8 #include "base/strings/string_number_conversions.h"
9 #include "base/values.h" 9 #include "base/values.h"
10 #include "chrome/browser/accessibility/accessibility_extension_api_constants.h" 10 #include "chrome/browser/accessibility/accessibility_extension_api_constants.h"
11 #include "chrome/browser/extensions/api/tabs/tabs_constants.h" 11 #include "chrome/browser/extensions/api/tabs/tabs_constants.h"
12 #include "chrome/browser/extensions/event_router.h" 12 #include "chrome/browser/extensions/event_router.h"
13 #include "chrome/browser/extensions/extension_system.h" 13 #include "chrome/browser/extensions/extension_system.h"
14 #include "chrome/browser/extensions/extension_tab_util.h" 14 #include "chrome/browser/extensions/extension_tab_util.h"
15 #include "chrome/browser/infobars/confirm_infobar_delegate.h" 15 #include "chrome/browser/infobars/confirm_infobar_delegate.h"
16 #include "chrome/browser/infobars/infobar_delegate.h" 16 #include "chrome/browser/infobars/infobar_delegate.h"
17 #include "chrome/browser/infobars/infobar_service.h" 17 #include "chrome/browser/infobars/infobar_service.h"
18 #include "chrome/browser/profiles/profile.h" 18 #include "chrome/browser/profiles/profile.h"
19 #include "chrome/common/chrome_notification_types.h" 19 #include "chrome/common/chrome_notification_types.h"
20 #include "content/public/browser/browser_accessibility_state.h"
20 #include "content/public/browser/notification_service.h" 21 #include "content/public/browser/notification_service.h"
21 #include "extensions/common/error_utils.h" 22 #include "extensions/common/error_utils.h"
22 23
23 namespace keys = extension_accessibility_api_constants; 24 namespace keys = extension_accessibility_api_constants;
24 25
25 // Returns the AccessibilityControlInfo serialized into a JSON string, 26 // Returns the AccessibilityControlInfo serialized into a JSON string,
26 // consisting of an array of a single object of type AccessibilityObject, 27 // consisting of an array of a single object of type AccessibilityObject,
27 // as defined in the accessibility extension api's json schema. 28 // as defined in the accessibility extension api's json schema.
28 scoped_ptr<ListValue> ControlInfoToEventArguments( 29 scoped_ptr<ListValue> ControlInfoToEventArguments(
29 const AccessibilityEventInfo* info) { 30 const AccessibilityEventInfo* info) {
(...skipping 142 matching lines...) Expand 10 before | Expand all | Expand 10 after
172 } 173 }
173 174
174 bool AccessibilitySetAccessibilityEnabledFunction::RunImpl() { 175 bool AccessibilitySetAccessibilityEnabledFunction::RunImpl() {
175 bool enabled; 176 bool enabled;
176 EXTENSION_FUNCTION_VALIDATE(args_->GetBoolean(0, &enabled)); 177 EXTENSION_FUNCTION_VALIDATE(args_->GetBoolean(0, &enabled));
177 ExtensionAccessibilityEventRouter::GetInstance() 178 ExtensionAccessibilityEventRouter::GetInstance()
178 ->SetAccessibilityEnabled(enabled); 179 ->SetAccessibilityEnabled(enabled);
179 return true; 180 return true;
180 } 181 }
181 182
183 bool AccessibilitySetWebAccessibilityEnabledFunction::RunImpl() {
184 bool enabled;
185 EXTENSION_FUNCTION_VALIDATE(args_->GetBoolean(0, &enabled));
186 if (enabled) {
dmazzoni 2013/04/30 20:31:58 Shouldn't it call something if you pass false as w
187 content::BrowserAccessibilityState::GetInstance()->
188 OnExtensionWebAccessibilityEnabled();
dmazzoni 2013/04/30 20:31:58 indent 2 more
189 }
190 return true;
191 }
192
182 bool AccessibilityGetFocusedControlFunction::RunImpl() { 193 bool AccessibilityGetFocusedControlFunction::RunImpl() {
183 // Get the serialized dict from the last focused control and return it. 194 // Get the serialized dict from the last focused control and return it.
184 // However, if the dict is empty, that means we haven't seen any focus 195 // However, if the dict is empty, that means we haven't seen any focus
185 // events yet, so return null instead. 196 // events yet, so return null instead.
186 ExtensionAccessibilityEventRouter *accessibility_event_router = 197 ExtensionAccessibilityEventRouter *accessibility_event_router =
187 ExtensionAccessibilityEventRouter::GetInstance(); 198 ExtensionAccessibilityEventRouter::GetInstance();
188 DictionaryValue *last_focused_control_dict = 199 DictionaryValue *last_focused_control_dict =
189 accessibility_event_router->last_focused_control_dict(); 200 accessibility_event_router->last_focused_control_dict();
190 if (last_focused_control_dict->size()) { 201 if (last_focused_control_dict->size()) {
191 SetResult(last_focused_control_dict->DeepCopyWithoutEmptyChildren()); 202 SetResult(last_focused_control_dict->DeepCopyWithoutEmptyChildren());
(...skipping 29 matching lines...) Expand all
221 DictionaryValue* alert_value = new DictionaryValue; 232 DictionaryValue* alert_value = new DictionaryValue;
222 const string16 message_text = confirm_infobar_delegate->GetMessageText(); 233 const string16 message_text = confirm_infobar_delegate->GetMessageText();
223 alert_value->SetString(keys::kMessageKey, message_text); 234 alert_value->SetString(keys::kMessageKey, message_text);
224 alerts_value->Append(alert_value); 235 alerts_value->Append(alert_value);
225 } 236 }
226 } 237 }
227 238
228 SetResult(alerts_value); 239 SetResult(alerts_value);
229 return true; 240 return true;
230 } 241 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698