removed building of a test application for target 'all'
[simple-launcher] / settings-dialog.cc
index 3af780e..c691019 100644 (file)
@@ -20,6 +20,7 @@
 #include <gtk/gtksizegroup.h>
 #include <gtk/gtknotebook.h>
 #include <gtk/gtklabel.h>
+#include <gtk/gtkcheckbutton.h>
 
 #include "settings-dialog.h"
 
@@ -33,7 +34,7 @@ inline void addPage(GtkNotebook *notebook, const std::string& name, GtkWidget *w
   gtk_notebook_append_page(notebook, widget, label);
 }
 
-inline GtkWidget *packItTogether(GtkSizeGroup *group, const std::string& name, GtkWidget *content) {
+inline GtkWidget *packItTogether(GtkBox *parent, GtkSizeGroup *group, const std::string& name, GtkWidget *content) {
   GtkWidget *box = gtk_hbox_new(false, 0);
   GtkWidget *label = gtk_label_new(name.c_str());
 
@@ -41,6 +42,8 @@ inline GtkWidget *packItTogether(GtkSizeGroup *group, const std::string& name, G
   gtk_box_pack_start(GTK_BOX(box), label, true, true, 0);
   gtk_box_pack_start(GTK_BOX(box), content, true, true, 0);
 
+  gtk_box_pack_start(parent, box, false, false, 0);
+
   return box;
 }
 
@@ -49,25 +52,30 @@ inline GtkWidget *createUIPage() {
   GtkWidget *vbox = gtk_vbox_new(true, 0);
 
   // packItTogether(group, "Button Size:", <small/big>);
-  // packItTogether(group, "Transparent background:", [ ]);
-  // packItTogether(group, "Show Infobanner:", [ ]);
+  packItTogether(GTK_BOX(vbox), group, "Transparent background:", gtk_check_button_new());
+  packItTogether(GTK_BOX(vbox), group, "Show Infobanner:", gtk_check_button_new());
 
   g_object_unref(G_OBJECT(group));
 
   return vbox;
 }
 
-SettingsDialog::SettingsDialog(GtkWindow *parent, LauncherItems& items) : myList(SL_APPLET_SETTINGS_ICON_SIZE, items) {
+SettingsDialog::SettingsDialog(GtkWindow *parent, LauncherItems& items, GConfBooleanOption& transparent, GConfIntegerOption& icon_size, GConfIntegerOption& canvas_size):
+  myList(SL_APPLET_SETTINGS_ICON_SIZE, items),
+  myTransparent(transparent, "Transparent background:"), myIconSize(icon_size, "Icon Size:"), myCanvasSize(canvas_size, "Canvas Size:") {
   myDialog = GTK_DIALOG(gtk_dialog_new_with_buttons("Launcher Settings", parent, (GtkDialogFlags)(GTK_DIALOG_MODAL | GTK_DIALOG_DESTROY_WITH_PARENT), "OK", GTK_RESPONSE_OK, "Cancel", GTK_RESPONSE_CANCEL, NULL));
 
   GtkNotebook *notebook = GTK_NOTEBOOK(gtk_notebook_new());
 
   gtk_container_add(GTK_CONTAINER(myDialog->vbox), GTK_WIDGET(notebook));
 
-  // addPage(notebook, "UI", createUIPage());
+  addPage(notebook, "UI", createUIPage());
   addPage(notebook, "Items", myList.getWidget());
 
-  gtk_widget_set_size_request(GTK_WIDGET(myDialog), 540, 257);
+  gtk_widget_set_size_request(GTK_WIDGET(myDialog), 540, 324);
+
+  gtk_widget_show_all(GTK_WIDGET(notebook));
+  gtk_notebook_set_current_page(notebook, 0);
 }
 
 SettingsDialog::~SettingsDialog() {
@@ -80,4 +88,10 @@ gint SettingsDialog::run() {
   return gtk_dialog_run(myDialog);
 }
 
+void SettingsDialog::updateValues() {
+  myTransparent.updateValue();
+  myIconSize.updateValue();
+  myCanvasSize.updateValue();
+}
+
 // vim:ts=2:sw=2:et