From 7ceeba70872aab6ac66a1043c9f1587b12fc6710 Mon Sep 17 00:00:00 2001 From: "glotov@google.com" Date: Tue, 20 Apr 2010 18:22:12 +0000 Subject: UI Language switch implemented by propagating LocaleChanged() notification to all the views currently active. Before this CL, all views were recreated instead. That was very refactoring-unsafe. Note, this is first part of the change. It prepares overall architecture means and can be committed first. The other part contains implementation details and is here: http://codereview.chromium.org/1551029/show BUG=none TEST=none Review URL: http://codereview.chromium.org/1596023 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@45057 0039d316-1c4b-4281-b951-d872f2087c98 --- chrome/browser/chromeos/login/network_selection_view.cc | 12 ++++++++++-- chrome/browser/chromeos/login/network_selection_view.h | 4 ++++ 2 files changed, 14 insertions(+), 2 deletions(-) (limited to 'chrome') diff --git a/chrome/browser/chromeos/login/network_selection_view.cc b/chrome/browser/chromeos/login/network_selection_view.cc index ed3ff91..baa324e 100644 --- a/chrome/browser/chromeos/login/network_selection_view.cc +++ b/chrome/browser/chromeos/login/network_selection_view.cc @@ -91,14 +91,14 @@ void NetworkSelectionView::Init() { offline_button_ = new views::NativeButton(delegate_, std::wstring()); offline_button_->set_font(button_font); - UpdateLocalizedStrings(); - AddChildView(welcome_label_); AddChildView(select_network_label_); AddChildView(connecting_network_label_); AddChildView(network_combobox_); AddChildView(languages_menubutton_); AddChildView(offline_button_); + + UpdateLocalizedStrings(); } void NetworkSelectionView::UpdateLocalizedStrings() { @@ -116,6 +116,13 @@ void NetworkSelectionView::UpdateLocalizedStrings() { //////////////////////////////////////////////////////////////////////////////// // views::View: implementation: +void NetworkSelectionView::LocaleChanged() { + UpdateLocalizedStrings(); + NetworkModelChanged(); + Layout(); + SchedulePaint(); +} + gfx::Size NetworkSelectionView::GetPreferredSize() { return gfx::Size(width(), height()); } @@ -163,6 +170,7 @@ void NetworkSelectionView::Layout() { // Need to refresh combobox layout explicitly. network_combobox_->Layout(); + offline_button_->Layout(); SchedulePaint(); } diff --git a/chrome/browser/chromeos/login/network_selection_view.h b/chrome/browser/chromeos/login/network_selection_view.h index f8d134f..268453b 100644 --- a/chrome/browser/chromeos/login/network_selection_view.h +++ b/chrome/browser/chromeos/login/network_selection_view.h @@ -51,6 +51,10 @@ class NetworkSelectionView : public views::View { // Shows network connecting status or network selection otherwise. void ShowConnectingStatus(bool connecting, const string16& network_id); + protected: + // Overridden from views::View. + virtual void LocaleChanged(); + private: // Updates text on label with currently connecting network. void UpdateConnectingNetworkLabel(); -- cgit v1.1