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

Side by Side Diff: chrome/browser/views/importing_progress_view.cc

Issue 9471: Adds import/export of bookmarks to bookmarks.html file.... (Closed) Base URL: svn://chrome-svn/chrome/trunk/src/
Patch Set: '' Created 12 years, 1 month 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
« no previous file with comments | « chrome/browser/views/importing_progress_view.h ('k') | chrome/browser/views/shell_dialogs.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright (c) 2006-2008 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2006-2008 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/views/importing_progress_view.h" 5 #include "chrome/browser/views/importing_progress_view.h"
6 6
7 #include "chrome/app/locales/locale_settings.h" 7 #include "chrome/app/locales/locale_settings.h"
8 #include "chrome/browser/views/standard_layout.h" 8 #include "chrome/browser/views/standard_layout.h"
9 #include "chrome/common/l10n_util.h" 9 #include "chrome/common/l10n_util.h"
10 #include "chrome/views/grid_layout.h" 10 #include "chrome/views/grid_layout.h"
11 #include "chrome/views/label.h" 11 #include "chrome/views/label.h"
12 #include "chrome/views/throbber.h" 12 #include "chrome/views/throbber.h"
13 #include "chrome/views/window.h" 13 #include "chrome/views/window.h"
14 14
15 #include "chromium_strings.h" 15 #include "chromium_strings.h"
16 #include "generated_resources.h" 16 #include "generated_resources.h"
17 17
18 //////////////////////////////////////////////////////////////////////////////// 18 ////////////////////////////////////////////////////////////////////////////////
19 // ImportingProgressView, public: 19 // ImportingProgressView, public:
20 20
21 ImportingProgressView::ImportingProgressView(const std::wstring& source_name, 21 ImportingProgressView::ImportingProgressView(const std::wstring& source_name,
22 int16 items, 22 int16 items,
23 ImporterHost* coordinator, 23 ImporterHost* coordinator,
24 ImportObserver* observer, 24 ImportObserver* observer,
25 HWND parent_window) 25 HWND parent_window,
26 bool bookmarks_import)
26 : state_bookmarks_(new views::CheckmarkThrobber), 27 : state_bookmarks_(new views::CheckmarkThrobber),
27 state_searches_(new views::CheckmarkThrobber), 28 state_searches_(new views::CheckmarkThrobber),
28 state_passwords_(new views::CheckmarkThrobber), 29 state_passwords_(new views::CheckmarkThrobber),
29 state_history_(new views::CheckmarkThrobber), 30 state_history_(new views::CheckmarkThrobber),
30 state_cookies_(new views::CheckmarkThrobber), 31 state_cookies_(new views::CheckmarkThrobber),
31 label_info_(new views::Label(l10n_util::GetStringF(
32 IDS_IMPORT_PROGRESS_INFO, source_name))),
33 label_bookmarks_(new views::Label( 32 label_bookmarks_(new views::Label(
34 l10n_util::GetString(IDS_IMPORT_PROGRESS_STATUS_BOOKMARKS))), 33 l10n_util::GetString(IDS_IMPORT_PROGRESS_STATUS_BOOKMARKS))),
35 label_searches_(new views::Label( 34 label_searches_(new views::Label(
36 l10n_util::GetString(IDS_IMPORT_PROGRESS_STATUS_SEARCH))), 35 l10n_util::GetString(IDS_IMPORT_PROGRESS_STATUS_SEARCH))),
37 label_passwords_(new views::Label( 36 label_passwords_(new views::Label(
38 l10n_util::GetString(IDS_IMPORT_PROGRESS_STATUS_PASSWORDS))), 37 l10n_util::GetString(IDS_IMPORT_PROGRESS_STATUS_PASSWORDS))),
39 label_history_(new views::Label( 38 label_history_(new views::Label(
40 l10n_util::GetString(IDS_IMPORT_PROGRESS_STATUS_HISTORY))), 39 l10n_util::GetString(IDS_IMPORT_PROGRESS_STATUS_HISTORY))),
41 label_cookies_(new views::Label( 40 label_cookies_(new views::Label(
42 l10n_util::GetString(IDS_IMPORT_PROGRESS_STATUS_COOKIES))), 41 l10n_util::GetString(IDS_IMPORT_PROGRESS_STATUS_COOKIES))),
43 parent_window_(parent_window), 42 parent_window_(parent_window),
44 coordinator_(coordinator), 43 coordinator_(coordinator),
45 import_observer_(observer), 44 import_observer_(observer),
46 items_(items), 45 items_(items),
47 importing_(true) { 46 importing_(true),
47 bookmarks_import_(bookmarks_import) {
48 std::wstring info_text = bookmarks_import ?
49 l10n_util::GetString(IDS_IMPORT_BOOKMARKS) :
50 l10n_util::GetStringF(IDS_IMPORT_PROGRESS_INFO, source_name);
51 label_info_ = new views::Label(info_text);
48 coordinator_->SetObserver(this); 52 coordinator_->SetObserver(this);
49 label_info_->SetMultiLine(true); 53 label_info_->SetMultiLine(true);
50 label_info_->SetHorizontalAlignment(views::Label::ALIGN_LEFT); 54 label_info_->SetHorizontalAlignment(views::Label::ALIGN_LEFT);
51 label_bookmarks_->SetHorizontalAlignment(views::Label::ALIGN_LEFT); 55 label_bookmarks_->SetHorizontalAlignment(views::Label::ALIGN_LEFT);
52 label_searches_->SetHorizontalAlignment(views::Label::ALIGN_LEFT); 56 label_searches_->SetHorizontalAlignment(views::Label::ALIGN_LEFT);
53 label_passwords_->SetHorizontalAlignment(views::Label::ALIGN_LEFT); 57 label_passwords_->SetHorizontalAlignment(views::Label::ALIGN_LEFT);
54 label_history_->SetHorizontalAlignment(views::Label::ALIGN_LEFT); 58 label_history_->SetHorizontalAlignment(views::Label::ALIGN_LEFT);
55 label_cookies_->SetHorizontalAlignment(views::Label::ALIGN_LEFT); 59 label_cookies_->SetHorizontalAlignment(views::Label::ALIGN_LEFT);
56 60
57 // These are scoped pointers, so we don't need the parent to delete them. 61 // These are scoped pointers, so we don't need the parent to delete them.
(...skipping 13 matching lines...) Expand all
71 RemoveChildView(state_bookmarks_.get()); 75 RemoveChildView(state_bookmarks_.get());
72 RemoveChildView(state_searches_.get()); 76 RemoveChildView(state_searches_.get());
73 RemoveChildView(state_passwords_.get()); 77 RemoveChildView(state_passwords_.get());
74 RemoveChildView(state_history_.get()); 78 RemoveChildView(state_history_.get());
75 RemoveChildView(state_cookies_.get()); 79 RemoveChildView(state_cookies_.get());
76 RemoveChildView(label_bookmarks_.get()); 80 RemoveChildView(label_bookmarks_.get());
77 RemoveChildView(label_searches_.get()); 81 RemoveChildView(label_searches_.get());
78 RemoveChildView(label_passwords_.get()); 82 RemoveChildView(label_passwords_.get());
79 RemoveChildView(label_history_.get()); 83 RemoveChildView(label_history_.get());
80 RemoveChildView(label_cookies_.get()); 84 RemoveChildView(label_cookies_.get());
85
86 if (importing_) {
87 // We're being deleted while importing, clean up state so that the importer
88 // doesn't have a reference to us and cancel the import. We can get here
89 // if our parent window is closed, which closes our window and deletes us.
90 importing_ = false;
91 coordinator_->SetObserver(NULL);
92 coordinator_->Cancel();
93 if (import_observer_)
94 import_observer_->ImportComplete();
95 }
81 } 96 }
82 97
83 //////////////////////////////////////////////////////////////////////////////// 98 ////////////////////////////////////////////////////////////////////////////////
84 // ImportingProgressView, ImporterObserver implementation: 99 // ImportingProgressView, ImporterObserver implementation:
85 100
86 void ImportingProgressView::ImportItemStarted(ImportItem item) { 101 void ImportingProgressView::ImportItemStarted(ImportItem item) {
87 DCHECK(items_ & item); 102 DCHECK(items_ & item);
88 switch (item) { 103 switch (item) {
89 case FAVORITES: 104 case FAVORITES:
90 state_bookmarks_->Start(); 105 state_bookmarks_->Start();
(...skipping 119 matching lines...) Expand 10 before | Expand all | Expand 10 after
210 using views::GridLayout; 225 using views::GridLayout;
211 using views::ColumnSet; 226 using views::ColumnSet;
212 227
213 GridLayout* layout = CreatePanelGridLayout(this); 228 GridLayout* layout = CreatePanelGridLayout(this);
214 SetLayoutManager(layout); 229 SetLayoutManager(layout);
215 230
216 gfx::Size ps = state_history_->GetPreferredSize(); 231 gfx::Size ps = state_history_->GetPreferredSize();
217 232
218 const int single_column_view_set_id = 0; 233 const int single_column_view_set_id = 0;
219 ColumnSet* column_set = layout->AddColumnSet(single_column_view_set_id); 234 ColumnSet* column_set = layout->AddColumnSet(single_column_view_set_id);
235 if (bookmarks_import_) {
236 column_set->AddColumn(GridLayout::CENTER, GridLayout::CENTER, 0,
237 GridLayout::FIXED, ps.width(), 0);
238 column_set->AddPaddingColumn(0, kRelatedControlHorizontalSpacing);
239 }
220 column_set->AddColumn(GridLayout::FILL, GridLayout::FILL, 1, 240 column_set->AddColumn(GridLayout::FILL, GridLayout::FILL, 1,
221 GridLayout::USE_PREF, 0, 0); 241 GridLayout::USE_PREF, 0, 0);
222 const int double_column_view_set_id = 1; 242 const int double_column_view_set_id = 1;
223 column_set = layout->AddColumnSet(double_column_view_set_id); 243 column_set = layout->AddColumnSet(double_column_view_set_id);
224 column_set->AddPaddingColumn(0, kUnrelatedControlLargeHorizontalSpacing); 244 column_set->AddPaddingColumn(0, kUnrelatedControlLargeHorizontalSpacing);
225 column_set->AddColumn(GridLayout::CENTER, GridLayout::CENTER, 0, 245 column_set->AddColumn(GridLayout::CENTER, GridLayout::CENTER, 0,
226 GridLayout::FIXED, ps.width(), 0); 246 GridLayout::FIXED, ps.width(), 0);
227 column_set->AddPaddingColumn(0, kRelatedControlHorizontalSpacing); 247 column_set->AddPaddingColumn(0, kRelatedControlHorizontalSpacing);
228 column_set->AddColumn(GridLayout::LEADING, GridLayout::CENTER, 1, 248 column_set->AddColumn(GridLayout::LEADING, GridLayout::CENTER, 1,
229 GridLayout::USE_PREF, 0, 0); 249 GridLayout::USE_PREF, 0, 0);
230 column_set->AddPaddingColumn(0, kUnrelatedControlLargeHorizontalSpacing); 250 column_set->AddPaddingColumn(0, kUnrelatedControlLargeHorizontalSpacing);
231 251
232 layout->StartRow(0, single_column_view_set_id); 252 layout->StartRow(0, single_column_view_set_id);
253 if (bookmarks_import_)
254 layout->AddView(state_bookmarks_.get());
233 layout->AddView(label_info_); 255 layout->AddView(label_info_);
234 layout->AddPaddingRow(0, kUnrelatedControlVerticalSpacing); 256 layout->AddPaddingRow(0, kUnrelatedControlVerticalSpacing);
235 257
236 if (items_ & FAVORITES) { 258 if (items_ & FAVORITES && !bookmarks_import_) {
237 layout->StartRow(0, double_column_view_set_id); 259 layout->StartRow(0, double_column_view_set_id);
238 layout->AddView(state_bookmarks_.get()); 260 layout->AddView(state_bookmarks_.get());
239 layout->AddView(label_bookmarks_.get()); 261 layout->AddView(label_bookmarks_.get());
240 layout->AddPaddingRow(0, kRelatedControlVerticalSpacing); 262 layout->AddPaddingRow(0, kRelatedControlVerticalSpacing);
241 } 263 }
242 if (items_ & SEARCH_ENGINES) { 264 if (items_ & SEARCH_ENGINES) {
243 layout->StartRow(0, double_column_view_set_id); 265 layout->StartRow(0, double_column_view_set_id);
244 layout->AddView(state_searches_.get()); 266 layout->AddView(state_searches_.get());
245 layout->AddView(label_searches_.get()); 267 layout->AddView(label_searches_.get());
246 layout->AddPaddingRow(0, kRelatedControlVerticalSpacing); 268 layout->AddPaddingRow(0, kRelatedControlVerticalSpacing);
(...skipping 23 matching lines...) Expand all
270 292
271 void StartImportingWithUI(HWND parent_window, 293 void StartImportingWithUI(HWND parent_window,
272 int16 items, 294 int16 items,
273 ImporterHost* coordinator, 295 ImporterHost* coordinator,
274 const ProfileInfo& source_profile, 296 const ProfileInfo& source_profile,
275 Profile* target_profile, 297 Profile* target_profile,
276 ImportObserver* observer, 298 ImportObserver* observer,
277 bool first_run) { 299 bool first_run) {
278 DCHECK(items != 0); 300 DCHECK(items != 0);
279 ImportingProgressView* v = new ImportingProgressView( 301 ImportingProgressView* v = new ImportingProgressView(
280 source_profile.description, items, coordinator, observer, parent_window); 302 source_profile.description, items, coordinator, observer, parent_window,
303 source_profile.browser_type == BOOKMARKS_HTML);
281 views::Window* window = 304 views::Window* window =
282 views::Window::CreateChromeWindow(parent_window, gfx::Rect(), v); 305 views::Window::CreateChromeWindow(parent_window, gfx::Rect(), v);
283 306
284 // In headless mode it means that we don't show the progress window, but it 307 // In headless mode it means that we don't show the progress window, but it
285 // still need it to exist. No user interaction will be required. 308 // still need it to exist. No user interaction will be required.
286 if (!coordinator->is_headless()) 309 if (!coordinator->is_headless())
287 window->Show(); 310 window->Show();
288 311
289 coordinator->StartImportSettings(source_profile, items, 312 coordinator->StartImportSettings(source_profile, items,
290 new ProfileWriter(target_profile), 313 new ProfileWriter(target_profile),
291 first_run); 314 first_run);
292 } 315 }
293 316
OLDNEW
« no previous file with comments | « chrome/browser/views/importing_progress_view.h ('k') | chrome/browser/views/shell_dialogs.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698