#include "launcher-item.h"
#include "sla-list.h"
#include "launchable-item.h"
+#include "settings-dialog.h"
#define SL_APPLET_DBUS_NAME "simple-launcher"
#define SL_APPLET_VERSION "0.0"
}
addItem(myItems, buffer, (p != NULL && (*p == '1' || *p == 'y' || *p == 'Y')));
-
}
delete buffer;
}
int button_no = 0;
- GtkToolbar *toolbar = GTK_TOOLBAR(gtk_toolbar_new());
+ GtkBox *box = GTK_BOX(gtk_hbox_new(true, 1));
for (size_t i = 0 ; i < myItems.size() ; ++i) {
LauncherItem *item = myItems[i];
if (item != NULL && item->isEnabled()) {
- GtkToolItem *button = gtk_tool_button_new(gtk_image_new_from_pixbuf(item->getIcon(SL_APPLET_ICON_SIZE)), NULL);
+ GtkWidget *button = gtk_button_new();
+
+ gtk_container_add(GTK_CONTAINER(button), gtk_image_new_from_pixbuf(item->getIcon(SL_APPLET_ICON_SIZE)));
gtk_object_set_user_data(GTK_OBJECT(button), item);
g_signal_connect(button, "clicked", G_CALLBACK(_button_clicked), this);
- gtk_toolbar_insert(toolbar, button, -1);
+ gtk_box_pack_start(box, GTK_WIDGET(button), false, false, 0);
++button_no;
}
}
- if (button_no) {
- gtk_container_add(GTK_CONTAINER(myWidget), GTK_WIDGET(toolbar));
- if (button_no == 0) {
- gtk_widget_set_size_request(myWidget, SL_APPLET_ICON_SIZE+SL_APPLET_CANVAS_SIZE, SL_APPLET_ICON_SIZE+SL_APPLET_CANVAS_SIZE);
- } else {
- gtk_widget_set_size_request(myWidget, button_no*(SL_APPLET_ICON_SIZE+SL_APPLET_CANVAS_SIZE), SL_APPLET_ICON_SIZE+SL_APPLET_CANVAS_SIZE);
- }
+ gtk_container_add(GTK_CONTAINER(myWidget), GTK_WIDGET(box));
+
+ if (button_no == 0) {
+ gtk_widget_set_size_request(myWidget, SL_APPLET_ICON_SIZE+SL_APPLET_CANVAS_SIZE, SL_APPLET_ICON_SIZE+SL_APPLET_CANVAS_SIZE);
} else {
- gtk_widget_destroy(GTK_WIDGET(toolbar));
+ gtk_widget_set_size_request(myWidget, button_no*(SL_APPLET_ICON_SIZE+SL_APPLET_CANVAS_SIZE), SL_APPLET_ICON_SIZE+SL_APPLET_CANVAS_SIZE);
}
gtk_widget_show_all(myWidget);
}
GtkWidget *SimpleLauncherApplet::settings(GtkWindow *parent) {
- // TODO: in case we want SimpleLauncherApplet to be configurable, this method
- // should return a gtk_menu_item that would be included in home settings
- // menu. Method should make sure that when we activate that item, a
- // corresponding dialog appears.
myParent = parent; // FIXME: Ugly piece of code :(
GtkWidget *menuItem = gtk_menu_item_new_with_label("Launcher settings...");
}
void SimpleLauncherApplet::runDialog() {
- LauncherItems newItems = myItems;
+ // We update the items before using them to avoid a small memory leak
+ // FIXME: deal with the situation in a better way (figure it out first :))
+ updateItems(myItems); // User requested 'settings', let's give her the latest stuff :)
- updateItems(newItems); // User requested 'settings', let's give her the latest stuff :)
-
- SLAList list(SL_APPLET_ICON_SIZE, newItems);
-
- GtkDialog *dialog = GTK_DIALOG(gtk_dialog_new_with_buttons("Launcher Settings", myParent, (GtkDialogFlags)(GTK_DIALOG_MODAL | GTK_DIALOG_DESTROY_WITH_PARENT), "OK", GTK_RESPONSE_OK, "Cancel", GTK_RESPONSE_CANCEL, NULL));
-
- gtk_container_add(GTK_CONTAINER(dialog->vbox), list.getWidget());
-
- gtk_widget_set_size_request(GTK_WIDGET(dialog), 540, 257);
-
- int response = gtk_dialog_run(dialog);
+ LauncherItems newItems = myItems;
- gtk_widget_destroy(GTK_WIDGET(dialog));
+ SettingsDialog dialog(myParent, SL_APPLET_ICON_SIZE, newItems);
- switch (response) {
+ switch (dialog.run()) {
case GTK_RESPONSE_OK:
myItems = newItems;
saveConfig(); // save it immediately!