diff options
author | estade@chromium.org <estade@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-03-26 18:50:51 +0000 |
---|---|---|
committer | estade@chromium.org <estade@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-03-26 18:50:51 +0000 |
commit | 5228d56c2b19231923504dfbcd306f0c93058fca (patch) | |
tree | 5aaca6e85c369a7c8ae75e6f3ec6bd3695ae9613 /chrome/browser/gtk/download_item_gtk.cc | |
parent | 1676374870966b50e20d7097881e49c084a7caf5 (diff) | |
download | chromium_src-5228d56c2b19231923504dfbcd306f0c93058fca.zip chromium_src-5228d56c2b19231923504dfbcd306f0c93058fca.tar.gz chromium_src-5228d56c2b19231923504dfbcd306f0c93058fca.tar.bz2 |
Linux download shelf:
- Show status text.
- Pack new items on the left.
Review URL: http://codereview.chromium.org/53084
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@12582 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome/browser/gtk/download_item_gtk.cc')
-rw-r--r-- | chrome/browser/gtk/download_item_gtk.cc | 25 |
1 files changed, 23 insertions, 2 deletions
diff --git a/chrome/browser/gtk/download_item_gtk.cc b/chrome/browser/gtk/download_item_gtk.cc index ded475c..941afd0 100644 --- a/chrome/browser/gtk/download_item_gtk.cc +++ b/chrome/browser/gtk/download_item_gtk.cc @@ -5,6 +5,7 @@ #include "chrome/browser/gtk/download_item_gtk.h" #include "base/basictypes.h" +#include "base/string_util.h" #include "chrome/browser/download/download_item_model.h" #include "chrome/browser/download/download_manager.h" #include "chrome/browser/download/download_shelf.h" @@ -129,9 +130,18 @@ DownloadItemGtk::DownloadItemGtk(BaseDownloadItemModel* download_model, GTK_WIDGET_UNSET_FLAGS(body_, GTK_CAN_FOCUS); // TODO(estade): gtk_label_new() expects UTF8, but FilePath may have a // different encoding on linux. - GtkWidget* label = gtk_label_new( + GtkWidget* name_label = gtk_label_new( download_model->download()->GetFileName().value().c_str()); - gtk_container_add(GTK_CONTAINER(body_), label); + gtk_misc_set_alignment(GTK_MISC(name_label), 0, 0); + status_label_ = + gtk_label_new(WideToUTF8(download_model->GetStatusText()).c_str()); + gtk_misc_set_alignment(GTK_MISC(status_label_), 0, 0); + + // Stack the labels on top of one another. + GtkWidget* text_stack = gtk_vbox_new(FALSE, 0); + gtk_box_pack_start(GTK_BOX(text_stack), name_label, FALSE, FALSE, 0); + gtk_box_pack_start(GTK_BOX(text_stack), status_label_, FALSE, FALSE, 0); + gtk_container_add(GTK_CONTAINER(body_), text_stack); menu_button_ = gtk_button_new(); gtk_widget_set_app_paintable(menu_button_, TRUE); @@ -148,12 +158,23 @@ DownloadItemGtk::DownloadItemGtk(BaseDownloadItemModel* download_model, gtk_box_pack_start(GTK_BOX(hbox_), body_, FALSE, FALSE, 0); gtk_box_pack_start(GTK_BOX(hbox_), menu_button_, FALSE, FALSE, 0); gtk_box_pack_start(GTK_BOX(parent_shelf), hbox_, FALSE, FALSE, 0); + // Insert as the leftmost item. + gtk_box_reorder_child(GTK_BOX(parent_shelf), hbox_, 1); gtk_widget_show_all(hbox_); + + download_model_->download()->AddObserver(this); } DownloadItemGtk::~DownloadItemGtk() { } +void DownloadItemGtk::OnDownloadUpdated(DownloadItem* download) { + DCHECK_EQ(download, download_model_->download()); + + gtk_label_set_text(GTK_LABEL(status_label_), + WideToUTF8(download_model_->GetStatusText()).c_str()); +} + // static void DownloadItemGtk::InitNineBoxes() { if (body_nine_box_normal_) |