X-Git-Url: http://git.wpitchoune.net/gitweb/?a=blobdiff_plain;f=src%2Fui_tasktree.c;h=8e46c253100fc99fa823dbd872add044106b6a59;hb=8d43529da6a9a3a469b107ab07f52991e9f18e75;hp=c1789f39aeb1049f5806e83e17cfe1b80d36067e;hpb=30a0f69b259de2ebc4b9a69121bda91a6be1e3b5;p=ptask.git diff --git a/src/ui_tasktree.c b/src/ui_tasktree.c index c1789f3..8e46c25 100644 --- a/src/ui_tasktree.c +++ b/src/ui_tasktree.c @@ -16,18 +16,33 @@ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA * 02110-1301 USA */ +#define _XOPEN_SOURCE +#include + +#include +#include + #include #include +#include +#include +#include +#include static GtkTreeView *w_treeview; +static struct task **current_tasks; enum { COL_ID, COL_DESCRIPTION, COL_PROJECT, COL_UUID, - COL_PRIORITY + COL_PRIORITY, + COL_URGENCY, + COL_CREATION_DATE, + COL_DUE, + COL_START }; static int priority_to_int(const char *str) @@ -69,6 +84,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; @@ -112,3 +138,182 @@ void ui_tasktree_save_settings(GSettings *settings) g_settings_set_int(settings, "tasks-sort-col", sort_col_id); g_settings_set_int(settings, "tasks-sort-order", sort_order); } + +const char *ui_tasktree_get_task_uuid() +{ + struct task *t; + + t = ui_tasktree_get_selected_task(); + + if (t) + return t->uuid; + else + return NULL; +} + +struct task *ui_tasktree_get_selected_task() +{ + GtkTreePath *path; + GtkTreeViewColumn *cols; + struct task **tasks_cur, *result; + GtkTreeIter iter; + GtkTreeModel *model; + GValue value = {0,}; + const char *uuid; + + log_fct_enter(); + + result = NULL; + + if (current_tasks) { + gtk_tree_view_get_cursor(w_treeview, &path, &cols); + + if (path) { + model = gtk_tree_view_get_model(w_treeview); + gtk_tree_model_get_iter(model, &iter, path); + gtk_tree_model_get_value(model, + &iter, + COL_UUID, + &value); + + uuid = g_value_get_string(&value); + + for (tasks_cur = current_tasks; *tasks_cur; tasks_cur++) + if (!strcmp((*tasks_cur)->uuid, uuid)) + result = *tasks_cur; + + gtk_tree_path_free(path); + } + } + + log_fct_exit(); + + return result; +} + +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; + char *s; + + current_tasks = tasks; + + model = gtk_tree_view_get_model(GTK_TREE_VIEW(w_treeview)); + gtk_list_store_clear(GTK_LIST_STORE(model)); + + if (current_tasks) { + for (tasks_cur = current_tasks; *tasks_cur; tasks_cur++) { + task = (*tasks_cur); + + if (task->project) + prj = task->project; + else + prj = ""; + + if (prj_filter && strcmp(prj, prj_filter)) + continue; + + gtk_list_store_append(GTK_LIST_STORE(model), &iter); + + gtk_list_store_set(GTK_LIST_STORE(model), + &iter, + COL_ID, + (*tasks_cur)->id, + COL_DESCRIPTION, + (*tasks_cur)->description, + COL_PROJECT, + prj, + COL_UUID, + (*tasks_cur)->uuid, + COL_PRIORITY, + (*tasks_cur)->priority, + COL_URGENCY, + (*tasks_cur)->urgency, + -1); + + if ((*tasks_cur)->start) { + s = tm_to_str((*tasks_cur)->start); + gtk_list_store_set + (GTK_LIST_STORE(model), + &iter, + COL_START, + s, + -1); + free(s); + } + + if ((*tasks_cur)->due) { + s = tm_to_str((*tasks_cur)->due); + gtk_list_store_set + (GTK_LIST_STORE(model), + &iter, + COL_DUE, + s, + -1); + free(s); + } + + if ((*tasks_cur)->entry) { + s = tm_to_str((*tasks_cur)->entry); + gtk_list_store_set + (GTK_LIST_STORE(model), + &iter, + COL_CREATION_DATE, + s, + -1); + free(s); + } + } + } + +} + +void ui_tasktree_update_filter(const char *prj_filter) +{ + ui_tasktree_update(current_tasks, prj_filter); +}