OLD | NEW |
1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 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/chromeos/arc/arc_settings_bridge_impl.h" | 5 #include "chrome/browser/chromeos/arc/arc_settings_bridge.h" |
6 | 6 |
7 #include <algorithm> | 7 #include <algorithm> |
8 | 8 |
9 #include "base/json/json_writer.h" | 9 #include "base/json/json_writer.h" |
10 #include "base/prefs/pref_service.h" | 10 #include "base/prefs/pref_service.h" |
11 #include "base/strings/stringprintf.h" | 11 #include "base/strings/stringprintf.h" |
12 #include "chrome/browser/profiles/profile_manager.h" | 12 #include "chrome/browser/profiles/profile_manager.h" |
13 #include "chrome/common/pref_names.h" | 13 #include "chrome/common/pref_names.h" |
14 #include "components/arc/common/settings.mojom.h" | 14 #include "components/arc/common/settings.mojom.h" |
15 | 15 |
(...skipping 21 matching lines...) Expand all Loading... |
37 android_scale = kAndroidFontScaleLarge; | 37 android_scale = kAndroidFontScaleLarge; |
38 } else if (max_chrome_size >= kChromeFontSizeNormal) { | 38 } else if (max_chrome_size >= kChromeFontSizeNormal) { |
39 android_scale = kAndroidFontScaleNormal; | 39 android_scale = kAndroidFontScaleNormal; |
40 } | 40 } |
41 | 41 |
42 return android_scale; | 42 return android_scale; |
43 } | 43 } |
44 | 44 |
45 } // namespace fontsizes | 45 } // namespace fontsizes |
46 | 46 |
47 ArcSettingsBridgeImpl::~ArcSettingsBridgeImpl() { | 47 ArcSettingsBridge::ArcSettingsBridge(ArcBridgeService* arc_bridge_service) |
48 ArcBridgeService* bridge_service = ArcBridgeService::Get(); | 48 : arc_bridge_service_(arc_bridge_service) { |
49 DCHECK(bridge_service); | 49 DCHECK(arc_bridge_service_); |
50 bridge_service->RemoveObserver(this); | 50 arc_bridge_service_->AddObserver(this); |
| 51 |
| 52 // If SettingsInstance was ready before we AddObserver(), we won't get |
| 53 // OnSettingsInstanceReady events. For such case, we have to call it |
| 54 // explicitly. |
| 55 if (arc_bridge_service_->settings_instance()) |
| 56 OnSettingsInstanceReady(); |
51 } | 57 } |
52 | 58 |
53 void ArcSettingsBridgeImpl::StartObservingBridgeServiceChanges() { | 59 ArcSettingsBridge::~ArcSettingsBridge() { |
54 ArcBridgeService* bridge_service = ArcBridgeService::Get(); | 60 arc_bridge_service_->RemoveObserver(this); |
55 DCHECK(bridge_service); | |
56 bridge_service->AddObserver(this); | |
57 } | 61 } |
58 | 62 |
59 void ArcSettingsBridgeImpl::StartObservingSettingsChanges() { | 63 void ArcSettingsBridge::StartObservingSettingsChanges() { |
60 Profile* profile = ProfileManager::GetActiveUserProfile(); | 64 Profile* profile = ProfileManager::GetActiveUserProfile(); |
61 registrar_.Init(profile->GetPrefs()); | 65 registrar_.Init(profile->GetPrefs()); |
62 | 66 |
63 AddPrefToObserve(prefs::kWebKitDefaultFixedFontSize); | 67 AddPrefToObserve(prefs::kWebKitDefaultFixedFontSize); |
64 AddPrefToObserve(prefs::kWebKitDefaultFontSize); | 68 AddPrefToObserve(prefs::kWebKitDefaultFontSize); |
65 AddPrefToObserve(prefs::kWebKitMinimumFontSize); | 69 AddPrefToObserve(prefs::kWebKitMinimumFontSize); |
66 AddPrefToObserve(prefs::kAccessibilitySpokenFeedbackEnabled); | 70 AddPrefToObserve(prefs::kAccessibilitySpokenFeedbackEnabled); |
67 | 71 |
68 TimezoneSettings::GetInstance()->AddObserver(this); | 72 TimezoneSettings::GetInstance()->AddObserver(this); |
69 } | 73 } |
70 | 74 |
71 void ArcSettingsBridgeImpl::SyncAllPrefs() const { | 75 void ArcSettingsBridge::SyncAllPrefs() const { |
72 SyncFontSize(); | 76 SyncFontSize(); |
73 SyncLocale(); | 77 SyncLocale(); |
74 SyncSpokenFeedbackEnabled(); | 78 SyncSpokenFeedbackEnabled(); |
75 SyncTimeZone(); | 79 SyncTimeZone(); |
76 } | 80 } |
77 | 81 |
78 void ArcSettingsBridgeImpl::StopObservingSettingsChanges() { | 82 void ArcSettingsBridge::StopObservingSettingsChanges() { |
79 registrar_.RemoveAll(); | 83 registrar_.RemoveAll(); |
80 | 84 |
81 TimezoneSettings::GetInstance()->RemoveObserver(this); | 85 TimezoneSettings::GetInstance()->RemoveObserver(this); |
82 } | 86 } |
83 | 87 |
84 void ArcSettingsBridgeImpl::AddPrefToObserve(const std::string& pref_name) { | 88 void ArcSettingsBridge::AddPrefToObserve(const std::string& pref_name) { |
85 registrar_.Add(pref_name, base::Bind(&ArcSettingsBridgeImpl::OnPrefChanged, | 89 registrar_.Add(pref_name, base::Bind(&ArcSettingsBridge::OnPrefChanged, |
86 base::Unretained(this))); | 90 base::Unretained(this))); |
87 } | 91 } |
88 | 92 |
89 void ArcSettingsBridgeImpl::OnPrefChanged(const std::string& pref_name) const { | 93 void ArcSettingsBridge::OnPrefChanged(const std::string& pref_name) const { |
90 if (pref_name == prefs::kAccessibilitySpokenFeedbackEnabled) { | 94 if (pref_name == prefs::kAccessibilitySpokenFeedbackEnabled) { |
91 SyncSpokenFeedbackEnabled(); | 95 SyncSpokenFeedbackEnabled(); |
92 } else if (pref_name == prefs::kWebKitDefaultFixedFontSize || | 96 } else if (pref_name == prefs::kWebKitDefaultFixedFontSize || |
93 pref_name == prefs::kWebKitDefaultFontSize || | 97 pref_name == prefs::kWebKitDefaultFontSize || |
94 pref_name == prefs::kWebKitMinimumFontSize) { | 98 pref_name == prefs::kWebKitMinimumFontSize) { |
95 SyncFontSize(); | 99 SyncFontSize(); |
96 } else { | 100 } else { |
97 LOG(ERROR) << "Unknown pref changed."; | 101 LOG(ERROR) << "Unknown pref changed."; |
98 } | 102 } |
99 } | 103 } |
100 | 104 |
101 void ArcSettingsBridgeImpl::OnStateChanged(ArcBridgeService::State state) { | 105 void ArcSettingsBridge::OnStateChanged(ArcBridgeService::State state) { |
102 // ArcBridgeService::State::READY is emitted before ArcSettings app is ready | 106 // ArcBridgeService::State::READY is emitted before ArcSettings app is ready |
103 // to send broadcasts. Instead we wait for the SettingsInstance to be ready. | 107 // to send broadcasts. Instead we wait for the SettingsInstance to be ready. |
104 if (state == ArcBridgeService::State::STOPPING) { | 108 if (state == ArcBridgeService::State::STOPPING) { |
105 StopObservingSettingsChanges(); | 109 StopObservingSettingsChanges(); |
106 } | 110 } |
107 } | 111 } |
108 | 112 |
109 void ArcSettingsBridgeImpl::OnSettingsInstanceReady() { | 113 void ArcSettingsBridge::OnSettingsInstanceReady() { |
110 StartObservingSettingsChanges(); | 114 StartObservingSettingsChanges(); |
111 SyncAllPrefs(); | 115 SyncAllPrefs(); |
112 } | 116 } |
113 | 117 |
114 void ArcSettingsBridgeImpl::TimezoneChanged(const icu::TimeZone& timezone) { | 118 void ArcSettingsBridge::TimezoneChanged(const icu::TimeZone& timezone) { |
115 SyncTimeZone(); | 119 SyncTimeZone(); |
116 } | 120 } |
117 | 121 |
118 int ArcSettingsBridgeImpl::GetIntegerPref(const std::string& pref_name) const { | 122 int ArcSettingsBridge::GetIntegerPref(const std::string& pref_name) const { |
119 const PrefService::Preference* pref = | 123 const PrefService::Preference* pref = |
120 registrar_.prefs()->FindPreference(pref_name); | 124 registrar_.prefs()->FindPreference(pref_name); |
121 DCHECK(pref); | 125 DCHECK(pref); |
122 int val = -1; | 126 int val = -1; |
123 bool value_exists = pref->GetValue()->GetAsInteger(&val); | 127 bool value_exists = pref->GetValue()->GetAsInteger(&val); |
124 DCHECK(value_exists); | 128 DCHECK(value_exists); |
125 return val; | 129 return val; |
126 } | 130 } |
127 | 131 |
128 void ArcSettingsBridgeImpl::SyncFontSize() const { | 132 void ArcSettingsBridge::SyncFontSize() const { |
129 int default_size = GetIntegerPref(prefs::kWebKitDefaultFontSize); | 133 int default_size = GetIntegerPref(prefs::kWebKitDefaultFontSize); |
130 int default_fixed_size = GetIntegerPref(prefs::kWebKitDefaultFixedFontSize); | 134 int default_fixed_size = GetIntegerPref(prefs::kWebKitDefaultFixedFontSize); |
131 int minimum_size = GetIntegerPref(prefs::kWebKitMinimumFontSize); | 135 int minimum_size = GetIntegerPref(prefs::kWebKitMinimumFontSize); |
132 | 136 |
133 double android_scale = fontsizes::ConvertFontSizeChromeToAndroid( | 137 double android_scale = fontsizes::ConvertFontSizeChromeToAndroid( |
134 default_size, default_fixed_size, minimum_size); | 138 default_size, default_fixed_size, minimum_size); |
135 | 139 |
136 base::DictionaryValue extras; | 140 base::DictionaryValue extras; |
137 extras.SetDouble("scale", android_scale); | 141 extras.SetDouble("scale", android_scale); |
138 SendSettingsBroadcast("org.chromium.arc.settings.SET_FONT_SCALE", extras); | 142 SendSettingsBroadcast("org.chromium.arc.settings.SET_FONT_SCALE", extras); |
139 } | 143 } |
140 | 144 |
141 void ArcSettingsBridgeImpl::SyncSpokenFeedbackEnabled() const { | 145 void ArcSettingsBridge::SyncSpokenFeedbackEnabled() const { |
142 const PrefService::Preference* pref = registrar_.prefs()->FindPreference( | 146 const PrefService::Preference* pref = registrar_.prefs()->FindPreference( |
143 prefs::kAccessibilitySpokenFeedbackEnabled); | 147 prefs::kAccessibilitySpokenFeedbackEnabled); |
144 DCHECK(pref); | 148 DCHECK(pref); |
145 bool enabled = false; | 149 bool enabled = false; |
146 bool value_exists = pref->GetValue()->GetAsBoolean(&enabled); | 150 bool value_exists = pref->GetValue()->GetAsBoolean(&enabled); |
147 DCHECK(value_exists); | 151 DCHECK(value_exists); |
148 base::DictionaryValue extras; | 152 base::DictionaryValue extras; |
149 extras.SetBoolean("enabled", enabled); | 153 extras.SetBoolean("enabled", enabled); |
150 SendSettingsBroadcast("org.chromium.arc.settings.SET_SPOKEN_FEEDBACK_ENABLED", | 154 SendSettingsBroadcast("org.chromium.arc.settings.SET_SPOKEN_FEEDBACK_ENABLED", |
151 extras); | 155 extras); |
152 } | 156 } |
153 | 157 |
154 void ArcSettingsBridgeImpl::SyncLocale() const { | 158 void ArcSettingsBridge::SyncLocale() const { |
155 const PrefService::Preference* pref = | 159 const PrefService::Preference* pref = |
156 registrar_.prefs()->FindPreference(prefs::kApplicationLocale); | 160 registrar_.prefs()->FindPreference(prefs::kApplicationLocale); |
157 DCHECK(pref); | 161 DCHECK(pref); |
158 std::string locale; | 162 std::string locale; |
159 bool value_exists = pref->GetValue()->GetAsString(&locale); | 163 bool value_exists = pref->GetValue()->GetAsString(&locale); |
160 DCHECK(value_exists); | 164 DCHECK(value_exists); |
161 base::DictionaryValue extras; | 165 base::DictionaryValue extras; |
162 extras.SetString("locale", locale); | 166 extras.SetString("locale", locale); |
163 SendSettingsBroadcast("org.chromium.arc.settings.SET_LOCALE", extras); | 167 SendSettingsBroadcast("org.chromium.arc.settings.SET_LOCALE", extras); |
164 } | 168 } |
165 | 169 |
166 void ArcSettingsBridgeImpl::SyncTimeZone() const { | 170 void ArcSettingsBridge::SyncTimeZone() const { |
167 TimezoneSettings* timezone_settings = TimezoneSettings::GetInstance(); | 171 TimezoneSettings* timezone_settings = TimezoneSettings::GetInstance(); |
168 base::string16 timezoneID = timezone_settings->GetCurrentTimezoneID(); | 172 base::string16 timezoneID = timezone_settings->GetCurrentTimezoneID(); |
169 base::DictionaryValue extras; | 173 base::DictionaryValue extras; |
170 extras.SetString("olsonTimeZone", timezoneID); | 174 extras.SetString("olsonTimeZone", timezoneID); |
171 SendSettingsBroadcast("org.chromium.arc.settings.SET_TIME_ZONE", extras); | 175 SendSettingsBroadcast("org.chromium.arc.settings.SET_TIME_ZONE", extras); |
172 } | 176 } |
173 | 177 |
174 void ArcSettingsBridgeImpl::SendSettingsBroadcast( | 178 void ArcSettingsBridge::SendSettingsBroadcast( |
175 const std::string& action, | 179 const std::string& action, |
176 const base::DictionaryValue& extras) const { | 180 const base::DictionaryValue& extras) const { |
177 ArcBridgeService* bridge_service = ArcBridgeService::Get(); | 181 SettingsInstance* settings_instance = |
178 if (!bridge_service || | 182 arc_bridge_service_->settings_instance(); |
179 bridge_service->state() != ArcBridgeService::State::READY) { | 183 if (!settings_instance) { |
180 LOG(ERROR) << "Bridge service is not ready."; | 184 LOG(ERROR) << "Bridge service is not ready."; |
181 return; | 185 return; |
182 } | 186 } |
183 | 187 |
184 std::string extras_json; | 188 std::string extras_json; |
185 bool write_success = base::JSONWriter::Write(extras, &extras_json); | 189 bool write_success = base::JSONWriter::Write(extras, &extras_json); |
186 DCHECK(write_success); | 190 DCHECK(write_success); |
187 bridge_service->settings_instance()->SendBroadcast( | 191 settings_instance->SendBroadcast(action, "org.chromium.arc.settings", |
188 action, "org.chromium.arc.settings", | 192 "org.chromium.arc.settings.SettingsReceiver", |
189 "org.chromium.arc.settings.SettingsReceiver", extras_json); | 193 extras_json); |
190 } | 194 } |
191 | 195 |
192 } // namespace arc | 196 } // namespace arc |
OLD | NEW |