- 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();
-
- 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;
- }
-}
-
-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);
-
- gtk_entry_set_text(w_description, task->description);
- gtk_widget_set_sensitive(GTK_WIDGET(w_description), 1);
-
- 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");
- }