X-Git-Url: https://git.wpitchoune.net/gitweb/?p=ptask.git;a=blobdiff_plain;f=src%2Fui_tasktree.c;h=abec583dd5510932912c0e39ab532e36e4656cfa;hp=4fc7c86966d8ea1ea147eff60734c4afd7701adf;hb=d4052c9bd3a0b2da88c546eefe096f610a34edef;hpb=030fd9f1e29b230410e9fa665bacd5a3c47d590e diff --git a/src/ui_tasktree.c b/src/ui_tasktree.c index 4fc7c86..abec583 100644 --- a/src/ui_tasktree.c +++ b/src/ui_tasktree.c @@ -22,6 +22,7 @@ #include #include +#include #include static GtkTreeView *w_treeview; @@ -32,7 +33,8 @@ enum { COL_DESCRIPTION, COL_PROJECT, COL_UUID, - COL_PRIORITY + COL_PRIORITY, + COL_URGENCY }; static int priority_to_int(const char *str) @@ -74,6 +76,17 @@ static gint priority_cmp(GtkTreeModel *model, return 0; } +int tasktree_cursor_changed_cbk(GtkTreeView *treeview, gpointer data) +{ + log_fct_enter(); + + ui_taskpanel_update(ui_tasktree_get_selected_task()); + + log_fct_exit(); + + return FALSE; +} + void ui_tasktree_init(GtkBuilder *builder) { GtkTreeModel *model; @@ -170,22 +183,59 @@ struct task *ui_tasktree_get_selected_task() return result; } -void ui_tasktree_update(struct task **tasks, - const char *prj_filter, - const char *task_uuid) +void ui_tasktree_set_selected_task(const char *uuid) +{ + GtkTreePath *path; + GtkTreeIter iter; + GtkTreeModel *model; + GValue value = {0,}; + const char *c_uuid; + + log_fct_enter(); + + if (current_tasks) { + model = gtk_tree_view_get_model(w_treeview); + + if (!gtk_tree_model_get_iter_first(model, &iter)) + return ; + + path = NULL; + while (gtk_tree_model_iter_next(model, &iter)) { + gtk_tree_model_get_value(model, + &iter, + COL_UUID, + &value); + c_uuid = g_value_get_string(&value); + + if (!strcmp(uuid, c_uuid)) { + path = gtk_tree_model_get_path(model, &iter); + break; + } + + g_value_unset(&value); + } + + if (!path) + path = gtk_tree_path_new_first(); + gtk_tree_view_set_cursor(w_treeview, path, NULL, FALSE); + } + + log_fct_exit(); +} + + +void ui_tasktree_update(struct task **tasks, const char *prj_filter) { GtkTreeModel *model; struct task **tasks_cur; struct task *task; GtkTreeIter iter; const char *prj; - GtkTreePath *p; current_tasks = tasks; model = gtk_tree_view_get_model(GTK_TREE_VIEW(w_treeview)); gtk_list_store_clear(GTK_LIST_STORE(model)); - p = NULL; if (current_tasks) { for (tasks_cur = current_tasks; *tasks_cur; tasks_cur++) { @@ -209,20 +259,14 @@ void ui_tasktree_update(struct task **tasks, COL_PROJECT, prj, COL_UUID, (*tasks_cur)->uuid, COL_PRIORITY, (*tasks_cur)->priority, + COL_URGENCY, (*tasks_cur)->urgency, -1); - - if (task_uuid && !strcmp(task->uuid, task_uuid)) - p = gtk_tree_model_get_path(model, &iter); } - - if (!p) - p = gtk_tree_path_new_first(); - gtk_tree_view_set_cursor(w_treeview, p, NULL, FALSE); } } void ui_tasktree_update_filter(const char *prj_filter) { - ui_tasktree_update(current_tasks, prj_filter, NULL); + ui_tasktree_update(current_tasks, prj_filter); }