X-Git-Url: https://git.wpitchoune.net/gitweb/?a=blobdiff_plain;f=src%2Fui.c;h=2cc8107e83abb66812bf1ab8fb31ee24bd7cbfaf;hb=d90d80c49709335e9101657d1a82cdd964e14c40;hp=4eeb4f293223686eeac29fc7fc819ff68c530c96;hpb=70cd5dc1dcd5c75c98494807f5e4775260212ff6;p=ptask.git diff --git a/src/ui.c b/src/ui.c index 4eeb4f2..2cc8107 100644 --- a/src/ui.c +++ b/src/ui.c @@ -16,14 +16,24 @@ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA * 02110-1301 USA */ +#include + +#include + +#include #include +#include #include #include #include +#include #include static GtkComboBox *w_status; +static GtkWindow *window; +static GtkPaned *vpaned; +static GtkPaned *hpaned; int newtask_clicked_cbk(GtkButton *btn, gpointer data) { @@ -32,21 +42,27 @@ int newtask_clicked_cbk(GtkButton *btn, gpointer data) return FALSE; } -static void save_settings(GtkWindow *window, GSettings *settings) +static void save_settings(GtkWindow *window) { - int w, h, x, y; + int w, h, x, y, pos; gtk_window_get_size(window, &w, &h); gtk_window_get_position(window, &x, &y); - log_debug("save_settings(): x=%d, y=%d, w=%d, h=%d", x, y, w, h); + log_fct("x=%d, y=%d, w=%d, h=%d", x, y, w, h); + + settings_set_int(SETTINGS_KEY_WINDOW_WIDTH, w); + settings_set_int(SETTINGS_KEY_WINDOW_HEIGHT, h); + settings_set_int(SETTINGS_KEY_WINDOW_X, x); + settings_set_int(SETTINGS_KEY_WINDOW_Y, y); + + pos = gtk_paned_get_position(vpaned); + settings_set_int(SETTINGS_KEY_SPLITER_VERTICAL_POS, pos); - g_settings_set_int(settings, "window-width", w); - g_settings_set_int(settings, "window-height", h); - g_settings_set_int(settings, "window-x", x); - g_settings_set_int(settings, "window-y", y); + pos = gtk_paned_get_position(hpaned); + settings_set_int(SETTINGS_KEY_SPLITER_HORIZONTAL_POS, pos); - ui_tasktree_save_settings(settings); + ui_tasktree_save_settings(); g_settings_sync(); } @@ -60,13 +76,18 @@ int refresh_clicked_cbk(GtkButton *btn, gpointer data) } +static void ui_quit() +{ + save_settings(window); + gtk_widget_destroy(GTK_WIDGET(window)); + gtk_main_quit(); +} + static gboolean delete_event_cbk(GtkWidget *w, GdkEvent *evt, gpointer data) { log_fct_enter(); - save_settings(GTK_WINDOW(w), (GSettings *)data); - gtk_widget_destroy(w); - gtk_main_quit(); + ui_quit(); log_fct_exit(); @@ -75,16 +96,18 @@ static gboolean delete_event_cbk(GtkWidget *w, GdkEvent *evt, gpointer data) static int status_changed_cbk(GtkComboBox *w, gpointer data) { - log_debug("status_changed_cbk"); + log_fct_enter(); + refresh(); + log_fct_exit(); + return FALSE; } -GtkWindow *create_window(GtkBuilder *builder, GSettings *settings) +GtkWindow *create_window(GtkBuilder *builder) { - GtkWindow *window; - int x, y, w, h; + int x, y, w, h, pos; window = GTK_WINDOW(gtk_builder_get_object(builder, "window")); @@ -93,21 +116,30 @@ GtkWindow *create_window(GtkBuilder *builder, GSettings *settings) "changed", (GCallback)status_changed_cbk, NULL); - w = g_settings_get_int(settings, "window-width"); - h = g_settings_get_int(settings, "window-height"); + w = settings_get_int(SETTINGS_KEY_WINDOW_WIDTH); + h = settings_get_int(SETTINGS_KEY_WINDOW_HEIGHT); gtk_window_set_default_size(window, w, h); - x = g_settings_get_int(settings, "window-x"); - y = g_settings_get_int(settings, "window-y"); + x = settings_get_int(SETTINGS_KEY_WINDOW_X); + y = settings_get_int(SETTINGS_KEY_WINDOW_Y); gtk_window_move(window, x, y); + vpaned = GTK_PANED(gtk_builder_get_object(builder, "vpaned")); + pos = settings_get_int(SETTINGS_KEY_SPLITER_VERTICAL_POS); + gtk_paned_set_position(vpaned, pos); + + hpaned = GTK_PANED(gtk_builder_get_object(builder, "hpaned")); + pos = settings_get_int(SETTINGS_KEY_SPLITER_HORIZONTAL_POS); + gtk_paned_set_position(hpaned, pos); + g_signal_connect(window, "delete_event", - G_CALLBACK(delete_event_cbk), settings); + G_CALLBACK(delete_event_cbk), NULL); + ui_taskpanel_init(builder); ui_tasktree_init(builder); ui_projecttree_init(builder); - ui_tasktree_load_settings(settings); + ui_tasktree_load_settings(); return window; } @@ -125,3 +157,77 @@ const char *ui_get_status_filter() return status; } + +void quit_activate_cbk(GtkWidget *menu_item, gpointer data) +{ + log_fct_enter(); + ui_quit(); + log_fct_exit(); +} + +void preferences_activate_cbk(GtkWidget *menu_item, gpointer data) +{ + gint result; + static GtkDialog *diag; + GtkBuilder *builder; + GtkFileChooser *w_dir; + char *dir; + const char *sdir; + + builder = gtk_builder_new(); + gtk_builder_add_from_file + (builder, + PACKAGE_DATA_DIR G_DIR_SEPARATOR_S "ptask.glade", + NULL); + diag = GTK_DIALOG(gtk_builder_get_object(builder, "diag_preferences")); + gtk_builder_connect_signals(builder, NULL); + + w_dir = GTK_FILE_CHOOSER(gtk_builder_get_object(builder, + "dir_chooser")); + + sdir = settings_get_notes_dir(); + if (sdir && *sdir) + gtk_file_chooser_set_filename(w_dir, sdir); + + result = gtk_dialog_run(diag); + + if (result) { + log_debug("preferences_activate_cbk(): accept"); + dir = gtk_file_chooser_get_filename(w_dir); + + if (dir) { + log_debug("preferences_activate_cbk(): path=%s", dir); + settings_set_notes_dir(dir); + free(dir); + } + + refresh(); + } else { + log_debug("preferences_activate_cbk(): cancel"); + } + + g_object_unref(G_OBJECT(builder)); + + gtk_widget_destroy(GTK_WIDGET(diag)); +} + +void about_activate_cbk(GtkWidget *menu_item, gpointer data) +{ + log_fct_enter(); + + gtk_show_about_dialog + (NULL, + "comments", + _("ptask is a GTK+ task management application"), + "copyright", + _("Copyright(c) 2010-2013\njeanfi@gmail.com"), + "logo-icon-name", "ptask", + "program-name", "ptask", + "title", _("About ptask"), + "version", VERSION, + "website", PACKAGE_URL, + "website-label", _("ptask Homepage"), + NULL); + + log_fct_exit(); +}