[baobab/import-export: 3/5] Reimplement toolbar using GdMainToolbar
- From: Stefano Facchini <sfacchini src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [baobab/import-export: 3/5] Reimplement toolbar using GdMainToolbar
- Date: Sun, 9 Sep 2012 12:14:31 +0000 (UTC)
commit 18d80e685b012271999d11bebb2cfeee52df1669
Author: Stefano Facchini <stefano facchini gmail com>
Date: Sat Sep 8 00:06:27 2012 +0200
Reimplement toolbar using GdMainToolbar
libgd | 2 +-
src/baobab-main-window.ui | 151 ++++++++++++++-------------------------------
src/baobab-window.vala | 54 +++++++++-------
3 files changed, 77 insertions(+), 130 deletions(-)
---
diff --git a/libgd b/libgd
index 0ce531c..43ace41 160000
--- a/libgd
+++ b/libgd
@@ -1 +1 @@
-Subproject commit 0ce531c94dd59d00e51bc3d5ed94af6d4d143783
+Subproject commit 43ace412caeb5025d423c48869438c2587990e21
diff --git a/src/baobab-main-window.ui b/src/baobab-main-window.ui
index f1376a9..250895a 100644
--- a/src/baobab-main-window.ui
+++ b/src/baobab-main-window.ui
@@ -1,122 +1,63 @@
<?xml version="1.0" encoding="UTF-8"?>
<interface>
<!-- interface-requires gtk+ 3.0 -->
+ <object class="GtkButtonBox" id="scan-button-box">
+ <property name="visible">True</property>
+ <property name="orientation">horizontal</property>
+ <style>
+ <class name="linked"/>
+ </style>
+ <child>
+ <object class="GtkButton" id="scan-folder-button">
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <property name="has_tooltip">True</property>
+ <property name="tooltip_markup" translatable="yes">Scan a folder</property>
+ <property name="tooltip_text" translatable="yes">Scan a folder</property>
+ <property name="use_action_appearance">False</property>
+ <property name="action_name">win.scan-folder</property>
+ <property name="label" translatable="yes">Scan Folder</property>
+ <property name="use_underline">True</property>
+ </object>
+ </child>
+ <child>
+ <object class="GtkButton" id="scan-remote-button">
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <property name="has_tooltip">True</property>
+ <property name="tooltip_markup" translatable="yes">Scan a remote folder</property>
+ <property name="tooltip_text" translatable="yes">Scan a remote folder</property>
+ <property name="use_action_appearance">False</property>
+ <property name="action_name">win.scan-remote</property>
+ <property name="label" translatable="yes">Scan Remote Folder</property>
+ <property name="use_underline">True</property>
+ </object>
+ </child>
+ </object>
<object class="GtkGrid" id="window-contents">
<property name="visible">True</property>
<property name="orientation">vertical</property>
<child>
- <object class="GtkToolbar" id="toolbar">
+ <object class="GdMainToolbar" id="home-toolbar">
<property name="visible">True</property>
<property name="can_focus">False</property>
- <property name="show_arrow">False</property>
+ <property name="vexpand">False</property>
<style>
+ <class name="menubar"/>
<class name="baobab-toolbar"/>
+ </style>
+ </object>
+ </child>
+ <child>
+ <object class="GdMainToolbar" id="result-toolbar">
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <property name="vexpand">False</property>
+ <style>
+ <class name="menubar"/>
<class name="baobab-toolbar"/>
</style>
- <child>
- <object class="GtkToolItem" id="home-page-toolitem">
- <property name="visible">True</property>
- <child>
- <object class="GtkButtonBox" id="scan-buttonbox">
- <property name="visible">True</property>
- <property name="layout_style">start</property>
- <style>
- <class name="linked"/>
- </style>
- <child>
- <object class="GtkButton" id="scan-folder-button">
- <property name="visible">True</property>
- <property name="can_focus">False</property>
- <property name="has_tooltip">True</property>
- <property name="tooltip_markup" translatable="yes">Scan a folder</property>
- <property name="tooltip_text" translatable="yes">Scan a folder</property>
- <property name="use_action_appearance">False</property>
- <property name="action_name">win.scan-folder</property>
- <property name="label" translatable="yes">Scan Folder</property>
- <property name="use_underline">True</property>
- <!--<property name="stock_id">gtk-directory</property>-->
- </object>
- </child>
- <child>
- <object class="GtkButton" id="scan-remote-button">
- <property name="visible">True</property>
- <property name="can_focus">False</property>
- <property name="has_tooltip">True</property>
- <property name="tooltip_markup" translatable="yes">Scan a remote folder</property>
- <property name="tooltip_text" translatable="yes">Scan a remote folder</property>
- <property name="use_action_appearance">False</property>
- <property name="action_name">win.scan-remote</property>
- <property name="label" translatable="yes">Scan Remote Folder</property>
- <property name="use_underline">True</property>
- <!--<property name="stock_id">gtk-network</property>-->
- </object>
- </child>
- </object>
- </child>
- </object>
- </child>
- <child>
- <object class="GtkToolButton" id="show-home-page-button">
- <property name="visible">True</property>
- <property name="can_focus">False</property>
- <property name="has_tooltip">True</property>
- <property name="tooltip_markup" translatable="yes">Show all locations</property>
- <property name="tooltip_text" translatable="yes">Show all locations</property>
- <property name="use_action_appearance">False</property>
- <property name="action_name">win.show-home-page</property>
- <property name="icon_name">go-previous-symbolic</property>
- </object>
- <packing>
- <property name="expand">False</property>
- <property name="homogeneous">True</property>
- </packing>
- </child>
- <child>
- <object class="GtkToolItem" id="toolbar-label-toolitem">
- <property name="visible">True</property>
- <property name="hexpand">True</property>
- <child>
- <object class="GtkLabel" id="toolbar-label">
- <property name="visible">True</property>
- <property name="can_focus">False</property>
- <property name="label"></property>
- <property name="selectable">True</property>
- <property name="halign">GTK_ALIGN_CENTER</property>
- <property name="ellipsize">end</property>
- <property name="single_line_mode">True</property>
- <attributes>
- <attribute name="weight" value="bold"/>
- </attributes>
- </object>
- </child>
- </object>
- <packing>
- <property name="expand">True</property>
- </packing>
- </child>
- <child>
- <object class="GtkToolButton" id="rescan-button">
- <property name="visible">True</property>
- <property name="can_focus">False</property>
- <property name="has_tooltip">True</property>
- <property name="tooltip_markup" translatable="yes">Reload</property>
- <property name="tooltip_text" translatable="yes">Reload</property>
- <property name="use_action_appearance">False</property>
- <property name="action_name">win.reload</property>
- <property name="icon_name">view-refresh-symbolic</property>
- </object>
- <packing>
- <property name="expand">False</property>
- <property name="homogeneous">True</property>
- </packing>
- </child>
</object>
- <packing>
- <property name="left_attach">0</property>
- <property name="top_attach">0</property>
- <property name="width">1</property>
- <property name="height">1</property>
- </packing>
</child>
<child>
<object class="GtkInfoBar" id="infobar">
diff --git a/src/baobab-window.vala b/src/baobab-window.vala
index 4157503..8a4cc0a 100644
--- a/src/baobab-window.vala
+++ b/src/baobab-window.vala
@@ -25,12 +25,11 @@ namespace Baobab {
public class Window : Gtk.ApplicationWindow {
Settings ui_settings;
Gtk.Notebook main_notebook;
- Gtk.Toolbar toolbar;
+ Gd.MainToolbar home_toolbar;
+ Gd.MainToolbar result_toolbar;
Gtk.Button scan_remote;
- Gtk.ToolItem toolbar_home_toolitem;
- Gtk.ToolButton toolbar_show_home_page;
- Gtk.Label toolbar_label;
- Gtk.ToolButton toolbar_rescan;
+ Gtk.Button stop_button;
+ Gtk.Button show_home_page_button;
Gtk.InfoBar infobar;
Gtk.Label infobar_primary;
Gtk.Label infobar_secondary;
@@ -117,12 +116,6 @@ namespace Baobab {
// Cache some objects from the builder.
main_notebook = builder.get_object ("main-notebook") as Gtk.Notebook;
- toolbar = builder.get_object ("toolbar") as Gtk.Toolbar;
- scan_remote = builder.get_object ("scan-remote-button") as Gtk.Button;
- toolbar_home_toolitem = builder.get_object ("home-page-toolitem") as Gtk.ToolItem;
- toolbar_show_home_page = builder.get_object ("show-home-page-button") as Gtk.ToolButton;
- toolbar_label = builder.get_object ("toolbar-label") as Gtk.Label;
- toolbar_rescan = builder.get_object ("rescan-button") as Gtk.ToolButton;
infobar = builder.get_object ("infobar") as Gtk.InfoBar;
infobar_primary = builder.get_object ("infobar-primary-label") as Gtk.Label;
infobar_secondary = builder.get_object ("infobar-secondary-label") as Gtk.Label;
@@ -134,6 +127,25 @@ namespace Baobab {
treemap_chart = builder.get_object ("treemap-chart") as Chart;
spinner = builder.get_object ("spinner") as Gtk.Spinner;
+ // Home page toolbar
+ var toolbar = builder.get_object ("home-toolbar") as Gd.MainToolbar;
+ home_toolbar = toolbar;
+ var button_box = builder.get_object ("scan-button-box") as Gtk.ButtonBox;
+ scan_remote = builder.get_object ("scan-remote-button") as Gtk.Button;
+ toolbar.add_widget (button_box, true);
+ toolbar.show_all ();
+
+ // Result page toolbar
+ toolbar = builder.get_object ("result-toolbar") as Gd.MainToolbar;
+ result_toolbar = toolbar;
+ show_home_page_button = toolbar.add_button ("go-previous-symbolic", null, true) as Gtk.Button;
+ show_home_page_button.action_name = "win.show-home-page";
+ stop_button = toolbar.add_button ("process-stop-symbolic", null, true) as Gtk.Button;
+ stop_button.action_name = "win.show-home-page";
+ var button = toolbar.add_button ("view-refresh-symbolic", null, false) as Gtk.Button;
+ button.action_name = "win.reload";
+ toolbar.show_all ();
+
location_list.set_adjustment (location_scroll.get_vadjustment ());
location_list.set_action (on_scan_location_activate);
location_list.update ();
@@ -145,9 +157,6 @@ namespace Baobab {
var infobar_close_button = builder.get_object ("infobar-close-button") as Gtk.Button;
infobar_close_button.clicked.connect (() => { clear_message (); });
- // To make it draggable like a primary toolbar
- toolbar.get_style_context ().add_class (Gtk.STYLE_CLASS_MENUBAR);
-
ui_settings = Application.get_ui_settings ();
lookup_action ("active-chart").change_state (ui_settings.get_value ("active-chart"));
@@ -461,8 +470,8 @@ namespace Baobab {
(lookup_action ("active-chart") as SimpleAction).set_enabled (false);
chart_notebook.page = ChartPage.SPINNER;
spinner.start ();
- toolbar_show_home_page.icon_name = "process-stop-symbolic";
- toolbar_show_home_page.tooltip_markup = _("Cancel");
+ show_home_page_button.hide ();
+ stop_button.show ();
} else {
enable_drop ();
rings_chart.thaw_updates ();
@@ -470,8 +479,8 @@ namespace Baobab {
(lookup_action ("active-chart") as SimpleAction).set_enabled (true);
spinner.stop ();
lookup_action ("active-chart").change_state (ui_settings.get_value ("active-chart"));
- toolbar_show_home_page.icon_name = "go-previous-symbolic";
- toolbar_show_home_page.tooltip_markup = _("Show all locations");
+ show_home_page_button.show ();
+ stop_button.hide ();
}
var window = get_window ();
@@ -486,19 +495,16 @@ namespace Baobab {
}
void set_ui_state (UIPage page, bool busy) {
- toolbar_home_toolitem.visible = (page == UIPage.HOME);
- toolbar_show_home_page.visible = (page == UIPage.RESULT);
- toolbar_label.visible = (page == UIPage.RESULT);
- toolbar_rescan.visible = (page == UIPage.RESULT);
+ home_toolbar.visible = (page == UIPage.HOME);
+ result_toolbar.visible = (page == UIPage.RESULT);
set_busy (busy);
if (page == UIPage.HOME) {
- toolbar_label.set_text ("");
var action = lookup_action ("reload") as SimpleAction;
action.set_enabled (false);
} else {
- toolbar_label.set_text (active_location.name);
+ result_toolbar.set_labels (active_location.name, null);
}
main_notebook.page = page;
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]