 Chromium Code Reviews
 Chromium Code Reviews 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
    
  
    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| OLD | NEW | 
|---|---|
| 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 Loading... | |
| 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 Loading... | |
| 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 } | 
| OLD | NEW |