#include <json/json.h>
#include <glib/gi18n.h>
-#include <gtk/gtk.h>
#include <config.h>
-#include "log.h"
-#include "note.h"
-#include "tw.h"
+#include <log.h>
+#include <note.h>
+#include <tw.h>
+#include <ui.h>
+#include <ui_projecttree.h>
+#include <ui_taskpanel.h>
+#include <ui_tasktree.h>
static const char *program_name;
static struct task **tasks;
-static GtkTextView *w_note;
-static GtkEntry *w_description;
-static GtkEntry *w_project;
static GtkTreeView *w_treeview;
-static GtkWidget *w_tasksave_btn;
-static GtkWidget *w_taskdone_btn;
-static GtkComboBox *w_status;
-static GtkComboBox *w_priority;
+static GSettings *settings;
enum {
COL_ID,
printf(_("%s home page: <%s>\n"), PACKAGE_NAME, PACKAGE_URL);
}
-static struct task *get_selected_task(GtkTreeView *treeview)
+void refresh()
{
- GtkTreePath *path;
- GtkTreeViewColumn *cols;
- struct task **tasks_cur;
- GtkTreeIter iter;
- GtkTreeModel *model;
- GValue value = {0,};
- const char *uuid;
-
- log_debug("get_selected_task");
-
- gtk_tree_view_get_cursor(treeview, &path, &cols);
-
- if (path) {
- model = gtk_tree_view_get_model(GTK_TREE_VIEW(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 = tasks; *tasks_cur; tasks_cur++)
- if (!strcmp((*tasks_cur)->uuid, uuid))
- return *tasks_cur;
-
- gtk_tree_path_free(path);
- }
-
- return NULL;
-}
-
-static void clear_task_panel()
-{
- GtkTextBuffer *buf;
-
- gtk_widget_set_sensitive(w_tasksave_btn, 0);
- gtk_widget_set_sensitive(w_taskdone_btn, 0);
-
- buf = gtk_text_view_get_buffer(w_note);
- gtk_text_buffer_set_text(buf, "", 0);
- gtk_widget_set_sensitive(GTK_WIDGET(w_note), 0);
-
- gtk_entry_set_text(w_description, "");
- gtk_widget_set_sensitive(GTK_WIDGET(w_description), 0);
-
- gtk_entry_set_text(w_project, "");
- gtk_widget_set_sensitive(GTK_WIDGET(w_project), 0);
+ GtkWidget *dialog;
+ const char *current_prj, *current_uuid;
+ struct task **old_tasks;
- gtk_combo_box_set_active(w_priority, 0);
- gtk_widget_set_sensitive(GTK_WIDGET(w_priority), 0);
-}
+ log_fct_enter();
+ ui_taskpanel_update(NULL);
-static void refresh()
-{
- GtkWidget *dialog;
- GtkTreeModel *model;
- struct task **tasks_cur;
- struct task *task;
- int i;
- GtkTreeIter iter;
- int status;
- const char *project;
-
- log_debug("refresh");
- clear_task_panel();
-
- status = gtk_combo_box_get_active(w_status);
- log_debug("status: %d", status);
-
- if (tasks)
- tw_task_list_free(tasks);
-
- switch (status) {
- case 0:
- tasks = tw_get_all_tasks("pending");
- break;
- case 1:
- tasks = tw_get_all_tasks("completed");
- break;
- default:
- tasks = tw_get_all_tasks("pending");
+ if (tasks) {
+ old_tasks = tasks;
+ current_prj = ui_projecttree_get_project();
+ current_uuid = ui_tasktree_get_task_uuid();
+ ui_tasktree_update(NULL, NULL);
+ } else {
+ old_tasks = NULL;
+ current_prj = NULL;
+ current_uuid = NULL;
}
- model = gtk_tree_view_get_model(GTK_TREE_VIEW(w_treeview));
- gtk_list_store_clear(GTK_LIST_STORE(model));
+ tasks = tw_get_all_tasks(ui_get_status_filter());
if (tasks) {
- for (tasks_cur = tasks, i = 0; *tasks_cur; tasks_cur++, i++) {
- task = (*tasks_cur);
-
- gtk_list_store_append(GTK_LIST_STORE(model), &iter);
-
- if (task->project)
- project = task->project;
- else
- project = "";
-
- gtk_list_store_set(GTK_LIST_STORE(model),
- &iter,
- COL_ID, (*tasks_cur)->id,
- COL_DESCRIPTION,
- (*tasks_cur)->description,
- COL_PROJECT, project,
- COL_UUID, (*tasks_cur)->uuid,
- COL_PRIORITY, (*tasks_cur)->priority,
- -1);
- }
+ ui_projecttree_update(tasks);
+ ui_tasktree_update(tasks, current_prj);
+ if (current_uuid)
+ ui_tasktree_set_selected_task(current_uuid);
} else {
dialog = gtk_message_dialog_new(NULL,
GTK_DIALOG_DESTROY_WITH_PARENT,
GTK_BUTTONS_CLOSE,
_("Error loading tasks, verify "
"that a supported version of "
- "taskwarrior is installed "
- "and its configuration file "
- "exist."
- ));
+ "taskwarrior is installed "));
gtk_dialog_run(GTK_DIALOG(dialog));
gtk_widget_destroy(dialog);
}
- log_debug("refresh done");
-}
-
-int taskdone_clicked_cbk(GtkButton *btn, gpointer data)
-{
- struct task *task;
-
- task = get_selected_task(GTK_TREE_VIEW(w_treeview));
- tw_done(task->uuid);
- refresh();
-
- return FALSE;
-}
-
-static int tasksave_clicked_cbk(GtkButton *btn, gpointer data)
-{
- struct task *task;
- GtkTextBuffer *buf;
- char *txt, *pri;
- GtkTextIter sIter, eIter;
- const char *ctxt;
- int priority;
-
- task = get_selected_task(GTK_TREE_VIEW(w_treeview));
-
- log_debug("tasksave_clicked_cbk %d", task->id);
-
- buf = gtk_text_view_get_buffer(w_note);
-
- gtk_text_buffer_get_iter_at_offset(buf, &sIter, 0);
- gtk_text_buffer_get_iter_at_offset(buf, &eIter, -1);
- txt = gtk_text_buffer_get_text(buf, &sIter, &eIter, TRUE);
-
- log_debug("note=%s", txt);
-
- if (!task->note || strcmp(txt, task->note))
- note_put(task->uuid, txt);
-
- ctxt = gtk_entry_get_text(w_description);
- if (!task->description || strcmp(ctxt, task->description))
- tw_modify_description(task->uuid, ctxt);
-
- ctxt = gtk_entry_get_text(w_project);
- if (!task->project || strcmp(ctxt, task->project))
- tw_modify_project(task->uuid, ctxt);
-
- priority = gtk_combo_box_get_active(w_priority);
- log_debug("priority: %d", priority);
-
- switch (priority) {
- case 3:
- pri = "H";
- break;
- case 2:
- pri = "M";
- break;
- case 1:
- pri = "L";
- break;
- default:
- pri = "";
- }
-
- if (strcmp(task->priority, pri))
- tw_modify_priority(task->uuid, pri);
-
- refresh();
-
- return FALSE;
-}
-int refresh_clicked_cbk(GtkButton *btn, gpointer data)
-{
- log_debug("refresh_clicked_cbk");
- refresh();
+ if (old_tasks)
+ tw_task_list_free(old_tasks);
- return FALSE;
-}
-
-static gboolean delete_event_cbk(GtkWidget *w, GdkEvent *evt, gpointer data)
-{
- gtk_widget_destroy(w);
- gtk_main_quit();
-
- return FALSE;
-}
-
-
-int newtask_clicked_cbk(GtkButton *btn, gpointer data)
-{
- gint result;
- static GtkDialog *diag;
- GtkBuilder *builder;
- GtkEntry *entry;
- const char *ctxt;
-
- log_debug("newtask_clicked_cbk");
-
- 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_tasknew"));
- gtk_builder_connect_signals(builder, NULL);
-
- result = gtk_dialog_run(diag);
-
- if (result == GTK_RESPONSE_ACCEPT) {
- log_debug("ok");
- entry = GTK_ENTRY(gtk_builder_get_object
- (builder, "diag_tasknew_description"));
- ctxt = gtk_entry_get_text(entry);
-
- log_debug("%s", ctxt);
-
- tw_add(ctxt);
- refresh();
- } else {
- log_debug("cancel");
- }
-
- g_object_unref(G_OBJECT(builder));
-
- gtk_widget_destroy(GTK_WIDGET(diag));
-
- return FALSE;
-}
-
-static int status_changed_cbk(GtkComboBox *w, gpointer data)
-{
- log_debug("status_changed_cbk");
- refresh();
-
- return FALSE;
-}
-
-static int priority_to_int(const char *str)
-{
- switch (*str) {
- case 'H':
- return 3;
- case 'M':
- return 2;
- case 'L':
- return 1;
- default:
- return 0;
- }
+ log_fct_exit();
}
static int cursor_changed_cbk(GtkTreeView *treeview, gpointer data)
{
- struct task *task;
- GtkTextBuffer *buf;
- int priority;
-
- log_debug("cursor_changed_cbk");
-
- task = get_selected_task(treeview);
-
- if (task) {
-
- buf = gtk_text_view_get_buffer(w_note);
- if (task->note)
- gtk_text_buffer_set_text(buf,
- task->note,
- strlen(task->note));
- else
- gtk_text_buffer_set_text(buf, "", 0);
- gtk_widget_set_sensitive(GTK_WIDGET(w_note), 1);
+ log_fct_enter();
- gtk_entry_set_text(w_description, task->description);
- gtk_widget_set_sensitive(GTK_WIDGET(w_description), 1);
+ ui_taskpanel_update(ui_tasktree_get_selected_task());
- if (task->project)
- gtk_entry_set_text(w_project, task->project);
- else
- gtk_entry_set_text(w_project, "");
- gtk_widget_set_sensitive(GTK_WIDGET(w_project), 1);
-
- gtk_widget_set_sensitive(w_tasksave_btn, 1);
- gtk_widget_set_sensitive(w_taskdone_btn, 1);
-
- gtk_widget_set_sensitive(GTK_WIDGET(w_priority), 1);
- priority = priority_to_int(task->priority);
- gtk_combo_box_set_active(w_priority, priority);
- } else {
- log_debug("clear task widgets");
- clear_task_panel();
- log_debug("clear task widgets done");
- }
+ log_fct_exit();
return FALSE;
}
-static gint priority_cmp(GtkTreeModel *model,
- GtkTreeIter *a,
- GtkTreeIter *b,
- gpointer user_data)
-{
- GValue v1 = {0,}, v2 = {0,};
- const char *str1, *str2;
- int i1, i2;
-
- gtk_tree_model_get_value(model, a, COL_PRIORITY, &v1);
- str1 = g_value_get_string(&v1);
- i1 = priority_to_int(str1);
-
- gtk_tree_model_get_value(model, b, COL_PRIORITY, &v2);
- str2 = g_value_get_string(&v2);
- i2 = priority_to_int(str2);
-
- if (i1 < i2)
- return -1;
- else if (i1 > i2)
- return 1;
- else
- return 0;
-}
-
static void log_init()
{
char *home, *path, *dir;
int main(int argc, char **argv)
{
- GtkWidget *window, *btn;
+ GtkWindow *window;
GtkBuilder *builder;
- GtkTreeModel *model;
int optc, cmdok, opti;
program_name = argv[0];
log_init();
gtk_init(NULL, NULL);
+
+ settings = g_settings_new("ptask");
+
builder = gtk_builder_new();
gtk_builder_add_from_file
(builder,
PACKAGE_DATA_DIR G_DIR_SEPARATOR_S "ptask.glade",
NULL);
- window = GTK_WIDGET(gtk_builder_get_object(builder, "window"));
-
- g_signal_connect(window, "delete_event",
- G_CALLBACK(delete_event_cbk), NULL);
-
- w_treeview = GTK_TREE_VIEW(gtk_builder_get_object(builder, "treeview"));
- model = gtk_tree_view_get_model(GTK_TREE_VIEW(w_treeview));
- gtk_tree_sortable_set_sort_func(GTK_TREE_SORTABLE(model),
- COL_PRIORITY,
- priority_cmp,
- NULL,
- NULL);
-
- w_note = GTK_TEXT_VIEW(gtk_builder_get_object(builder, "tasknote"));
+ window = create_window(builder, settings);
- w_description = GTK_ENTRY(gtk_builder_get_object(builder,
- "taskdescription"));
- w_project = GTK_ENTRY(gtk_builder_get_object(builder, "taskproject"));
- w_status = GTK_COMBO_BOX(gtk_builder_get_object(builder, "status"));
- w_priority = GTK_COMBO_BOX(gtk_builder_get_object(builder,
- "taskpriority"));
+ ui_taskpanel_init(builder);
+ ui_tasktree_init(builder);
+ ui_projecttree_init(builder);
- refresh();
+ w_treeview = GTK_TREE_VIEW(gtk_builder_get_object(builder, "tasktree"));
gtk_builder_connect_signals(builder, NULL);
g_signal_connect(w_treeview,
"cursor-changed", (GCallback)cursor_changed_cbk,
tasks);
- g_signal_connect(w_status,
- "changed", (GCallback)status_changed_cbk,
- tasks);
-
- btn = GTK_WIDGET(gtk_builder_get_object(builder, "tasksave"));
- g_signal_connect(btn,
- "clicked", (GCallback)tasksave_clicked_cbk, tasks);
- gtk_widget_set_sensitive(btn, 0);
- w_tasksave_btn = btn;
-
- w_taskdone_btn = GTK_WIDGET(gtk_builder_get_object(builder,
- "taskdone"));
- gtk_widget_set_sensitive(w_taskdone_btn, 0);
g_object_unref(G_OBJECT(builder));
- gtk_widget_show_all(window);
+ refresh();
+
+ gtk_widget_show_all(GTK_WIDGET(window));
gtk_main();