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

Side by Side Diff: chrome/browser/chromeos/ui/idle_logout_dialog_view.cc

Issue 9701084: Integrate Kiosk Mode with enterprise policies. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: yacf Created 8 years, 9 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 | Annotate | Revision Log
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/chromeos/ui/idle_logout_dialog_view.h" 5 #include "chrome/browser/chromeos/ui/idle_logout_dialog_view.h"
6 6
7 #include "base/bind.h" 7 #include "base/bind.h"
8 #include "base/bind_helpers.h" 8 #include "base/bind_helpers.h"
9 #include "base/time.h" 9 #include "base/time.h"
10 #include "base/string_number_conversions.h" 10 #include "base/string_number_conversions.h"
11 #include "chrome/browser/chromeos/kiosk_mode/kiosk_mode_helper.h" 11 #include "chrome/browser/chromeos/kiosk_mode/kiosk_mode_settings.h"
12 #include "chrome/browser/ui/browser_list.h" 12 #include "chrome/browser/ui/browser_list.h"
13 #include "grit/browser_resources.h" 13 #include "grit/browser_resources.h"
14 #include "grit/generated_resources.h" 14 #include "grit/generated_resources.h"
15 #include "ui/base/l10n/l10n_util.h" 15 #include "ui/base/l10n/l10n_util.h"
16 #include "ui/base/resource/resource_bundle.h" 16 #include "ui/base/resource/resource_bundle.h"
17 #include "ui/views/controls/label.h" 17 #include "ui/views/controls/label.h"
18 #include "ui/views/layout/grid_layout.h" 18 #include "ui/views/layout/grid_layout.h"
19 #include "ui/views/layout/layout_constants.h" 19 #include "ui/views/layout/layout_constants.h"
20 #include "ui/views/widget/widget.h" 20 #include "ui/views/widget/widget.h"
21 21
(...skipping 51 matching lines...) Expand 10 before | Expand all | Expand 10 after
73 // closed by any other way than CloseIdleLogoutDialog, we check if our 73 // closed by any other way than CloseIdleLogoutDialog, we check if our
74 // 'closed' state is set - if not, then we set it and set g_instance to null, 74 // 'closed' state is set - if not, then we set it and set g_instance to null,
75 // since that means that CloseIdleLogoutDialog was never called. 75 // since that means that CloseIdleLogoutDialog was never called.
76 if (!this->is_closed()) { 76 if (!this->is_closed()) {
77 g_instance->set_closed(); 77 g_instance->set_closed();
78 g_instance = NULL; 78 g_instance = NULL;
79 } 79 }
80 80
81 // CallInit succeeded (or was never called) hence it didn't free 81 // CallInit succeeded (or was never called) hence it didn't free
82 // this pointer, free it here. 82 // this pointer, free it here.
83 if (chromeos::KioskModeHelper::Get()->is_initialized()) 83 if (chromeos::KioskModeSettings::Get()->is_initialized())
84 delete instance_holder_; 84 delete instance_holder_;
85 85
86 delete this; 86 delete this;
87 } 87 }
88 88
89 //////////////////////////////////////////////////////////////////////////////// 89 ////////////////////////////////////////////////////////////////////////////////
90 // IdleLogoutDialog private methods 90 // IdleLogoutDialog private methods
91 IdleLogoutDialogView::IdleLogoutDialogView() : restart_label_(NULL), 91 IdleLogoutDialogView::IdleLogoutDialogView() : restart_label_(NULL),
92 warning_label_(NULL) { 92 warning_label_(NULL) {
93 instance_holder_ = new IdleLogoutDialogView*(this); 93 instance_holder_ = new IdleLogoutDialogView*(this);
94 } 94 }
95 95
96 IdleLogoutDialogView::~IdleLogoutDialogView() { 96 IdleLogoutDialogView::~IdleLogoutDialogView() {
97 } 97 }
98 98
99 // static 99 // static
100 void IdleLogoutDialogView::CallInit(IdleLogoutDialogView** instance_holder) { 100 void IdleLogoutDialogView::CallInit(IdleLogoutDialogView** instance_holder) {
101 if (*instance_holder) 101 if (*instance_holder)
102 (*instance_holder)->Init(); 102 (*instance_holder)->Init();
103 else 103 else
104 // Our class is gone, free the holder memory. 104 // Our class is gone, free the holder memory.
105 delete instance_holder; 105 delete instance_holder;
106 } 106 }
107 107
108 void IdleLogoutDialogView::Init() { 108 void IdleLogoutDialogView::Init() {
109 if (!chromeos::KioskModeHelper::Get()->is_initialized()) { 109 if (!chromeos::KioskModeSettings::Get()->is_initialized()) {
110 chromeos::KioskModeHelper::Get()->Initialize( 110 chromeos::KioskModeSettings::Get()->Initialize(
111 base::Bind(&IdleLogoutDialogView::CallInit, instance_holder_)); 111 base::Bind(&IdleLogoutDialogView::CallInit, instance_holder_));
112 return; 112 return;
113 } 113 }
114 114
115 ui::ResourceBundle& rb = ui::ResourceBundle::GetSharedInstance(); 115 ui::ResourceBundle& rb = ui::ResourceBundle::GetSharedInstance();
116 116
117 warning_label_ = new views::Label( 117 warning_label_ = new views::Label(
118 l10n_util::GetStringUTF16(IDS_IDLE_LOGOUT_WARNING)); 118 l10n_util::GetStringUTF16(IDS_IDLE_LOGOUT_WARNING));
119 warning_label_->SetHorizontalAlignment(views::Label::ALIGN_LEFT); 119 warning_label_->SetHorizontalAlignment(views::Label::ALIGN_LEFT);
120 warning_label_->SetMultiLine(true); 120 warning_label_->SetMultiLine(true);
(...skipping 12 matching lines...) Expand all
133 views::GridLayout::USE_PREF, 0, 0); 133 views::GridLayout::USE_PREF, 0, 0);
134 layout->StartRow(0, 0); 134 layout->StartRow(0, 0);
135 layout->AddView(warning_label_); 135 layout->AddView(warning_label_);
136 layout->AddPaddingRow(0, views::kUnrelatedControlVerticalSpacing); 136 layout->AddPaddingRow(0, views::kUnrelatedControlVerticalSpacing);
137 layout->StartRow(0, 0); 137 layout->StartRow(0, 0);
138 layout->AddView(restart_label_); 138 layout->AddView(restart_label_);
139 } 139 }
140 140
141 void IdleLogoutDialogView::Show() { 141 void IdleLogoutDialogView::Show() {
142 // Setup the countdown label before showing. 142 // Setup the countdown label before showing.
143 countdown_end_time_ = base::Time::Now() + base::TimeDelta::FromSeconds( 143 countdown_end_time_ = base::Time::Now() +
144 chromeos::KioskModeHelper::Get()->GetIdleLogoutWarningTimeout()); 144 chromeos::KioskModeSettings::Get()->GetIdleLogoutWarningDuration();
145 UpdateCountdownTimer(); 145 UpdateCountdownTimer();
146 146
147 views::Widget::CreateWindow(this); 147 views::Widget::CreateWindow(this);
148 GetWidget()->SetAlwaysOnTop(true); 148 GetWidget()->SetAlwaysOnTop(true);
149 GetWidget()->Show(); 149 GetWidget()->Show();
150 150
151 // Update countdown every 1 second. 151 // Update countdown every 1 second.
152 timer_.Start(FROM_HERE, 152 timer_.Start(FROM_HERE,
153 base::TimeDelta::FromSeconds(kCountdownUpdateInterval), 153 base::TimeDelta::FromSeconds(kCountdownUpdateInterval),
154 this, 154 this,
(...skipping 22 matching lines...) Expand all
177 IDS_IDLE_LOGOUT_WARNING_RESTART_1S)); 177 IDS_IDLE_LOGOUT_WARNING_RESTART_1S));
178 } else { 178 } else {
179 // Set the label - the logout probably won't be instant. 179 // Set the label - the logout probably won't be instant.
180 restart_label_->SetText(l10n_util::GetStringUTF16( 180 restart_label_->SetText(l10n_util::GetStringUTF16(
181 IDS_IDLE_LOGOUT_WARNING_RESTART_NOW)); 181 IDS_IDLE_LOGOUT_WARNING_RESTART_NOW));
182 182
183 // Logout the current user. 183 // Logout the current user.
184 BrowserList::AttemptUserExit(); 184 BrowserList::AttemptUserExit();
185 } 185 }
186 } 186 }
OLDNEW
« no previous file with comments | « chrome/browser/chromeos/stub_cros_settings_provider.cc ('k') | chrome/browser/chromeos/ui/screensaver_extension_dialog.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698