aboutsummaryrefslogtreecommitdiffstats
path: root/calendar/gui/dialogs/task-details-page.c
diff options
context:
space:
mode:
Diffstat (limited to 'calendar/gui/dialogs/task-details-page.c')
-rw-r--r--calendar/gui/dialogs/task-details-page.c789
1 files changed, 0 insertions, 789 deletions
diff --git a/calendar/gui/dialogs/task-details-page.c b/calendar/gui/dialogs/task-details-page.c
deleted file mode 100644
index e40db5ba86..0000000000
--- a/calendar/gui/dialogs/task-details-page.c
+++ /dev/null
@@ -1,789 +0,0 @@
-/*
- * Evolution calendar - task details page
- *
- * This program is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 2 of the License, or (at your option) version 3.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public
- * License along with the program; if not, see <http://www.gnu.org/licenses/>
- *
- *
- * Authors:
- * Federico Mena-Quintero <federico@ximian.com>
- * Miguel de Icaza <miguel@ximian.com>
- * Seth Alves <alves@hungry.com>
- * JP Rosevear <jpr@ximian.com>
- *
- * Copyright (C) 1999-2008 Novell, Inc. (www.novell.com)
- *
- */
-
-#ifdef HAVE_CONFIG_H
-#include <config.h>
-#endif
-
-#include <gtk/gtk.h>
-#include <glib/gi18n.h>
-
-#include "../e-timezone-entry.h"
-#include "comp-editor-util.h"
-#include "task-details-page.h"
-
-#define TASK_DETAILS_PAGE_GET_PRIVATE(obj) \
- (G_TYPE_INSTANCE_GET_PRIVATE \
- ((obj), TYPE_TASK_DETAILS_PAGE, TaskDetailsPagePrivate))
-
-struct _TaskDetailsPagePrivate {
- GtkBuilder *builder;
-
- /* Widgets from the UI file */
- GtkWidget *main;
-
- GtkWidget *status_combo;
- GtkWidget *priority_combo;
- GtkWidget *percent_complete;
-
- GtkWidget *date_completed_label;
- GtkWidget *completed_date;
-
- GtkWidget *url_label;
- GtkWidget *url_entry;
- GtkWidget *url;
-};
-
-/* Note that these two arrays must match. */
-static const gint status_map[] = {
- ICAL_STATUS_NONE,
- ICAL_STATUS_INPROCESS,
- ICAL_STATUS_COMPLETED,
- ICAL_STATUS_CANCELLED,
- -1
-};
-
-typedef enum {
- PRIORITY_HIGH,
- PRIORITY_NORMAL,
- PRIORITY_LOW,
- PRIORITY_UNDEFINED
-} TaskEditorPriority;
-
-static const gint priority_map[] = {
- PRIORITY_HIGH,
- PRIORITY_NORMAL,
- PRIORITY_LOW,
- PRIORITY_UNDEFINED,
- -1
-};
-
-G_DEFINE_TYPE (TaskDetailsPage, task_details_page, TYPE_COMP_EDITOR_PAGE)
-
-static TaskEditorPriority
-priority_value_to_index (gint priority_value)
-{
- TaskEditorPriority retval;
-
- if (priority_value == 0)
- retval = PRIORITY_UNDEFINED;
- else if (priority_value <= 4)
- retval = PRIORITY_HIGH;
- else if (priority_value == 5)
- retval = PRIORITY_NORMAL;
- else
- retval = PRIORITY_LOW;
-
- return retval;
-}
-
-static gint
-priority_index_to_value (TaskEditorPriority priority)
-{
- gint retval;
-
- switch (priority) {
- case PRIORITY_UNDEFINED:
- retval = 0;
- break;
- case PRIORITY_HIGH:
- retval = 3;
- break;
- case PRIORITY_NORMAL:
- retval = 5;
- break;
- case PRIORITY_LOW:
- retval = 7;
- break;
- default:
- retval = 0;
- break;
- }
-
- return retval;
-}
-
-/* Fills the widgets with default values */
-static void
-clear_widgets (TaskDetailsPage *tdpage)
-{
- TaskDetailsPagePrivate *priv;
-
- priv = tdpage->priv;
-
- /* Date completed */
- e_date_edit_set_time (E_DATE_EDIT (priv->completed_date), -1);
-
- /* URL */
- gtk_entry_set_text (GTK_ENTRY (priv->url), "");
-}
-
-static void
-sensitize_widgets (TaskDetailsPage *tdpage)
-{
- TaskDetailsPagePrivate *priv = tdpage->priv;
- CompEditor *editor;
- GtkWidget *entry;
- ECalClient *client;
- gboolean read_only;
-
- editor = comp_editor_page_get_editor (COMP_EDITOR_PAGE (tdpage));
- client = comp_editor_get_client (editor);
-
- read_only = e_client_is_readonly (E_CLIENT (client));
-
- gtk_widget_set_sensitive (priv->status_combo, !read_only);
- gtk_widget_set_sensitive (priv->priority_combo, !read_only);
- gtk_widget_set_sensitive (priv->percent_complete, !read_only);
- gtk_widget_set_sensitive (priv->completed_date, !read_only);
- gtk_widget_set_sensitive (priv->url_label, !read_only);
-
- entry = e_url_entry_get_entry (E_URL_ENTRY (priv->url_entry));
- gtk_editable_set_editable (GTK_EDITABLE (entry), !read_only);
-}
-
-static void
-task_details_page_dispose (GObject *object)
-{
- TaskDetailsPagePrivate *priv;
-
- priv = TASK_DETAILS_PAGE_GET_PRIVATE (object);
-
- if (priv->main != NULL) {
- g_object_unref (priv->main);
- priv->main = NULL;
- }
-
- if (priv->builder != NULL) {
- g_object_unref (priv->builder);
- priv->builder = NULL;
- }
-
- /* Chain up to parent's dispose() method. */
- G_OBJECT_CLASS (task_details_page_parent_class)->dispose (object);
-}
-
-static GtkWidget *
-task_details_page_get_widget (CompEditorPage *page)
-{
- TaskDetailsPage *tdpage;
- TaskDetailsPagePrivate *priv;
-
- tdpage = TASK_DETAILS_PAGE (page);
- priv = tdpage->priv;
-
- return priv->main;
-}
-
-static void
-task_details_page_focus_main_widget (CompEditorPage *page)
-{
- TaskDetailsPage *tdpage;
- TaskDetailsPagePrivate *priv;
-
- tdpage = TASK_DETAILS_PAGE (page);
- priv = tdpage->priv;
-
- gtk_widget_grab_focus (priv->status_combo);
-}
-
-static gboolean
-task_details_page_fill_widgets (CompEditorPage *page,
- ECalComponent *comp)
-{
- TaskDetailsPage *tdpage;
- TaskDetailsPagePrivate *priv;
- gint *priority_value, *percent = NULL;
- TaskEditorPriority priority;
- icalproperty_status status;
- CompEditor *editor;
- const gchar *url;
- struct icaltimetype *completed = NULL;
-
- tdpage = TASK_DETAILS_PAGE (page);
- priv = tdpage->priv;
-
- editor = comp_editor_page_get_editor (COMP_EDITOR_PAGE (tdpage));
-
- /* Clean the screen */
- clear_widgets (tdpage);
-
- /* Percent Complete. */
- e_cal_component_get_percent (comp, &percent);
- if (percent) {
- gtk_spin_button_set_value (
- GTK_SPIN_BUTTON (priv->percent_complete), *percent);
- } else {
- /* FIXME: Could check if task is completed and set 100%. */
- gtk_spin_button_set_value (
- GTK_SPIN_BUTTON (priv->percent_complete), 0);
- }
-
- /* Status. */
- e_cal_component_get_status (comp, &status);
- if (status == ICAL_STATUS_NONE || status == ICAL_STATUS_NEEDSACTION) {
- /* Try to use the percent value. */
- if (percent) {
- if (*percent == 100)
- status = ICAL_STATUS_COMPLETED;
- else if (*percent > 0)
- status = ICAL_STATUS_INPROCESS;
- else
- status = ICAL_STATUS_NONE;
- } else
- status = ICAL_STATUS_NONE;
- }
- e_dialog_combo_box_set (priv->status_combo, status, status_map);
-
- if (percent)
- e_cal_component_free_percent (percent);
-
- /* Completed Date. */
- e_cal_component_get_completed (comp, &completed);
- if (completed) {
- icaltimezone *utc_zone, *zone;
-
- /* Completed is in UTC, but that would confuse the user, so
- * we convert it to local time. */
- utc_zone = icaltimezone_get_utc_timezone ();
- zone = comp_editor_get_timezone (editor);
-
- icaltimezone_convert_time (completed, utc_zone, zone);
-
- e_date_edit_set_date (
- E_DATE_EDIT (priv->completed_date),
- completed->year, completed->month,
- completed->day);
- e_date_edit_set_time_of_day (
- E_DATE_EDIT (priv->completed_date),
- completed->hour,
- completed->minute);
-
- e_cal_component_free_icaltimetype (completed);
- }
-
- /* Priority. */
- e_cal_component_get_priority (comp, &priority_value);
- if (priority_value) {
- priority = priority_value_to_index (*priority_value);
- e_cal_component_free_priority (priority_value);
- } else {
- priority = PRIORITY_UNDEFINED;
- }
- e_dialog_combo_box_set (priv->priority_combo, priority, priority_map);
-
- /* URL */
- e_cal_component_get_url (comp, &url);
- gtk_entry_set_text (GTK_ENTRY (priv->url), url ? url : "");
-
- sensitize_widgets (tdpage);
-
- return TRUE;
-}
-
-static gboolean
-task_details_page_fill_component (CompEditorPage *page,
- ECalComponent *comp)
-{
- TaskDetailsPage *tdpage;
- TaskDetailsPagePrivate *priv;
- struct icaltimetype icalcomplete, icaltoday;
- icalproperty_status status;
- TaskEditorPriority priority;
- CompEditor *editor;
- gint priority_value, percent;
- const gchar *text;
- gboolean date_set;
- icaltimezone *zone;
-
- tdpage = TASK_DETAILS_PAGE (page);
- priv = tdpage->priv;
-
- editor = comp_editor_page_get_editor (COMP_EDITOR_PAGE (tdpage));
- zone = comp_editor_get_timezone (editor);
-
- /* Percent Complete. */
- percent = gtk_spin_button_get_value_as_int (
- GTK_SPIN_BUTTON (priv->percent_complete));
- e_cal_component_set_percent (comp, &percent);
-
- /* Status. */
- status = e_dialog_combo_box_get (priv->status_combo, status_map);
- e_cal_component_set_status (comp, status);
-
- /* Priority. */
- priority = e_dialog_combo_box_get (priv->priority_combo, priority_map);
- priority_value = priority_index_to_value (priority);
- e_cal_component_set_priority (comp, &priority_value);
-
- icalcomplete = icaltime_null_time ();
-
- /* COMPLETED must be in UTC. */
- icalcomplete.is_utc = 1;
-
- /* Completed Date. */
- if (!e_date_edit_date_is_valid (E_DATE_EDIT (priv->completed_date)) ||
- !e_date_edit_time_is_valid (E_DATE_EDIT (priv->completed_date))) {
- comp_editor_page_display_validation_error (
- page, _("Completed date is wrong"),
- priv->completed_date);
- return FALSE;
- }
-
- date_set = e_date_edit_get_date (
- E_DATE_EDIT (priv->completed_date),
- &icalcomplete.year,
- &icalcomplete.month,
- &icalcomplete.day);
-
- if (date_set) {
- e_date_edit_get_time_of_day (
- E_DATE_EDIT (priv->completed_date),
- &icalcomplete.hour,
- &icalcomplete.minute);
-
- /* COMPLETED today or before */
- icaltoday = icaltime_current_time_with_zone (zone);
- icaltimezone_convert_time (
- &icaltoday, zone,
- icaltimezone_get_utc_timezone ());
-
- if (icaltime_compare_date_only (icalcomplete, icaltoday) > 0) {
- comp_editor_page_display_validation_error (
- page, _("Completed date is wrong"),
- priv->completed_date);
- return FALSE;
- }
-
- /* COMPLETED must be in UTC, so we assume that the date in the
- * dialog is in the current timezone, and we now convert it
- * to UTC. FIXME: We should really use one timezone for the
- * entire time the dialog is shown. Otherwise if the user
- * changes the timezone, the COMPLETED date may get changed
- * as well. */
- icaltimezone_convert_time (
- &icalcomplete, zone,
- icaltimezone_get_utc_timezone ());
- e_cal_component_set_completed (comp, &icalcomplete);
- } else {
- e_cal_component_set_completed (comp, NULL);
- }
-
- /* URL. */
- text = gtk_entry_get_text (GTK_ENTRY (priv->url));
- e_cal_component_set_url (comp, text);
-
- return TRUE;
-}
-
-static gboolean
-task_details_page_fill_timezones (CompEditorPage *page,
- GHashTable *timezones)
-{
- icaltimezone *zone;
-
- /* Add UTC timezone, which is the one
- * used for the DATE-COMPLETED property. */
- zone = icaltimezone_get_utc_timezone ();
- if (zone != NULL) {
- gconstpointer tzid = icaltimezone_get_tzid (zone);
-
- if (!g_hash_table_lookup (timezones, tzid))
- g_hash_table_insert (timezones, (gpointer) tzid, zone);
- }
-
- return TRUE;
-}
-
-static void
-task_details_page_class_init (TaskDetailsPageClass *class)
-{
- GObjectClass *object_class;
- CompEditorPageClass *editor_page_class;
-
- g_type_class_add_private (class, sizeof (TaskDetailsPagePrivate));
-
- object_class = G_OBJECT_CLASS (class);
- object_class->dispose = task_details_page_dispose;
-
- editor_page_class = COMP_EDITOR_PAGE_CLASS (class);
- editor_page_class->get_widget = task_details_page_get_widget;
- editor_page_class->focus_main_widget = task_details_page_focus_main_widget;
- editor_page_class->fill_widgets = task_details_page_fill_widgets;
- editor_page_class->fill_component = task_details_page_fill_component;
- editor_page_class->fill_timezones = task_details_page_fill_timezones;
-}
-
-static void
-task_details_page_init (TaskDetailsPage *tdpage)
-{
- tdpage->priv = TASK_DETAILS_PAGE_GET_PRIVATE (tdpage);
-}
-
-/* Gets the widgets from the XML file and returns if they are all available. */
-static gboolean
-get_widgets (TaskDetailsPage *tdpage)
-{
- CompEditorPage *page = COMP_EDITOR_PAGE (tdpage);
- TaskDetailsPagePrivate *priv;
- GSList *accel_groups;
- GtkWidget *toplevel;
- GtkWidget *parent;
-
- priv = tdpage->priv;
-
-#define GW(name) e_builder_get_widget (priv->builder, name)
-
- priv->main = GW ("task-details-page");
- if (!priv->main)
- return FALSE;
-
- /* Get the GtkAccelGroup from the toplevel window, so we can install
- * it when the notebook page is mapped. */
- toplevel = gtk_widget_get_toplevel (priv->main);
- accel_groups = gtk_accel_groups_from_object (G_OBJECT (toplevel));
- if (accel_groups)
- page->accel_group = g_object_ref (accel_groups->data);
-
- g_object_ref (priv->main);
- parent = gtk_widget_get_parent (priv->main);
- gtk_container_remove (GTK_CONTAINER (parent), priv->main);
-
- priv->status_combo = GW ("status-combobox");
- priv->priority_combo = GW ("priority-combobox");
- priv->percent_complete = GW ("percent-complete");
-
- priv->date_completed_label = GW ("date_completed_label");
-
- priv->completed_date = GW ("completed-date");
- gtk_widget_show (priv->completed_date);
-
- priv->url_label = GW ("url_label");
-
- priv->url_entry = GW ("url_entry");
- gtk_widget_show (priv->url_entry);
- priv->url = e_url_entry_get_entry (E_URL_ENTRY (priv->url_entry));
- atk_object_set_name (gtk_widget_get_accessible (priv->url), _("Web Page"));
-
-#undef GW
-
- return (priv->status_combo
- && priv->priority_combo
- && priv->percent_complete
- && priv->date_completed_label
- && priv->completed_date
- && priv->url_label
- && priv->url);
-}
-
-static void
-complete_date_changed (TaskDetailsPage *tdpage,
- time_t ctime,
- gboolean complete)
-{
- CompEditorPageDates dates = {NULL, NULL, NULL, NULL};
- icaltimezone *zone;
- struct icaltimetype completed_tt = icaltime_null_time ();
-
- /* Get the current time in UTC. */
- zone = icaltimezone_get_utc_timezone ();
- completed_tt = icaltime_from_timet_with_zone (ctime, FALSE, zone);
- completed_tt.is_utc = TRUE;
-
- dates.start = NULL;
- dates.end = NULL;
- dates.due = NULL;
- if (complete)
- dates.complete = &completed_tt;
-
- /* Notify upstream */
- comp_editor_page_notify_dates_changed (COMP_EDITOR_PAGE (tdpage),
- &dates);
-}
-
-static void
-date_changed_cb (EDateEdit *dedit,
- TaskDetailsPage *tdpage)
-{
- TaskDetailsPagePrivate *priv = tdpage->priv;
- CompEditorPageDates dates = {NULL, NULL, NULL, NULL};
- struct icaltimetype completed_tt = icaltime_null_time ();
- icalproperty_status status;
- gboolean date_set;
-
- if (comp_editor_page_get_updating (COMP_EDITOR_PAGE (tdpage)))
- return;
-
- comp_editor_page_set_updating (COMP_EDITOR_PAGE (tdpage), TRUE);
-
- date_set = e_date_edit_get_date (
- E_DATE_EDIT (priv->completed_date),
- &completed_tt.year,
- &completed_tt.month,
- &completed_tt.day);
- e_date_edit_get_time_of_day (
- E_DATE_EDIT (priv->completed_date),
- &completed_tt.hour,
- &completed_tt.minute);
-
- status = e_dialog_combo_box_get (priv->status_combo, status_map);
-
- if (!date_set) {
- completed_tt = icaltime_null_time ();
- if (status == ICAL_STATUS_COMPLETED) {
- e_dialog_combo_box_set (
- priv->status_combo,
- ICAL_STATUS_NONE,
- status_map);
- gtk_spin_button_set_value (
- GTK_SPIN_BUTTON (priv->percent_complete), 0);
- }
- } else {
- if (status != ICAL_STATUS_COMPLETED) {
- e_dialog_combo_box_set (
- priv->status_combo,
- ICAL_STATUS_COMPLETED,
- status_map);
- }
- gtk_spin_button_set_value (
- GTK_SPIN_BUTTON (priv->percent_complete), 100);
- }
-
- comp_editor_page_set_updating (COMP_EDITOR_PAGE (tdpage), FALSE);
-
- /* Notify upstream */
- dates.complete = &completed_tt;
- comp_editor_page_notify_dates_changed (COMP_EDITOR_PAGE (tdpage), &dates);
-}
-
-static void
-status_changed (GtkWidget *combo,
- TaskDetailsPage *tdpage)
-{
- TaskDetailsPagePrivate *priv;
- icalproperty_status status;
- CompEditor *editor;
- time_t ctime = -1;
-
- priv = tdpage->priv;
-
- if (comp_editor_page_get_updating (COMP_EDITOR_PAGE (tdpage)))
- return;
-
- editor = comp_editor_page_get_editor (COMP_EDITOR_PAGE (tdpage));
-
- comp_editor_page_set_updating (COMP_EDITOR_PAGE (tdpage), TRUE);
-
- status = e_dialog_combo_box_get (priv->status_combo, status_map);
- if (status == ICAL_STATUS_NONE) {
- gtk_spin_button_set_value (
- GTK_SPIN_BUTTON (priv->percent_complete), 0);
- e_date_edit_set_time (E_DATE_EDIT (priv->completed_date), ctime);
- complete_date_changed (tdpage, 0, FALSE);
- } else if (status == ICAL_STATUS_INPROCESS) {
- gint percent_complete = gtk_spin_button_get_value_as_int (
- GTK_SPIN_BUTTON (priv->percent_complete));
- if (percent_complete <= 0 || percent_complete >= 100)
- gtk_spin_button_set_value (
- GTK_SPIN_BUTTON (priv->percent_complete), 50);
-
- e_date_edit_set_time (E_DATE_EDIT (priv->completed_date), ctime);
- complete_date_changed (tdpage, 0, FALSE);
- } else if (status == ICAL_STATUS_COMPLETED) {
- gtk_spin_button_set_value (
- GTK_SPIN_BUTTON (priv->percent_complete), 100);
- ctime = time (NULL);
- e_date_edit_set_time (E_DATE_EDIT (priv->completed_date), ctime);
- complete_date_changed (tdpage, ctime, TRUE);
- }
-
- comp_editor_page_set_updating (COMP_EDITOR_PAGE (tdpage), FALSE);
-
- comp_editor_set_changed (editor, TRUE);
-}
-
-static void
-percent_complete_changed (GtkAdjustment *adj,
- TaskDetailsPage *tdpage)
-{
- TaskDetailsPagePrivate *priv;
- gint percent;
- icalproperty_status status;
- CompEditor *editor;
- gboolean complete;
- time_t ctime = -1;
-
- priv = tdpage->priv;
-
- if (comp_editor_page_get_updating (COMP_EDITOR_PAGE (tdpage)))
- return;
-
- editor = comp_editor_page_get_editor (COMP_EDITOR_PAGE (tdpage));
-
- comp_editor_page_set_updating (COMP_EDITOR_PAGE (tdpage), TRUE);
-
- percent = gtk_spin_button_get_value_as_int (
- GTK_SPIN_BUTTON (priv->percent_complete));
- if (percent == 100) {
- complete = TRUE;
- ctime = time (NULL);
- status = ICAL_STATUS_COMPLETED;
- } else {
- complete = FALSE;
-
- if (percent == 0)
- status = ICAL_STATUS_NONE;
- else
- status = ICAL_STATUS_INPROCESS;
- }
-
- e_dialog_combo_box_set (priv->status_combo, status, status_map);
- e_date_edit_set_time (E_DATE_EDIT (priv->completed_date), ctime);
- complete_date_changed (tdpage, ctime, complete);
-
- comp_editor_page_set_updating (COMP_EDITOR_PAGE (tdpage), FALSE);
-
- comp_editor_set_changed (editor, TRUE);
-}
-
-/* Hooks the widget signals */
-static void
-init_widgets (TaskDetailsPage *tdpage)
-{
- TaskDetailsPagePrivate *priv;
- GtkAdjustment *adjustment;
- CompEditor *editor;
-
- priv = tdpage->priv;
-
- editor = comp_editor_page_get_editor (COMP_EDITOR_PAGE (tdpage));
-
- /* Make sure the EDateEdit widgets use our timezones to get the
- * current time. */
- e_date_edit_set_get_time_callback (
- E_DATE_EDIT (priv->completed_date),
- (EDateEditGetTimeCallback) comp_editor_get_current_time,
- g_object_ref (editor),
- (GDestroyNotify) g_object_unref);
-
- /* These are created by hand, so hook the mnemonics manually */
- gtk_label_set_mnemonic_widget (
- GTK_LABEL (priv->date_completed_label),
- priv->completed_date);
- gtk_label_set_mnemonic_widget (
- GTK_LABEL (priv->url_label),
- priv->url_entry);
-
- /* Connect signals. The Status, Percent Complete & Date Completed
- * properties are closely related so whenever one changes we may need
- * to update the other 2. */
- g_signal_connect (
- GTK_COMBO_BOX (priv->status_combo), "changed",
- G_CALLBACK (status_changed), tdpage);
-
- adjustment = gtk_spin_button_get_adjustment (
- GTK_SPIN_BUTTON (priv->percent_complete));
- g_signal_connect (
- adjustment, "value_changed",
- G_CALLBACK (percent_complete_changed), tdpage);
-
- /* Priority */
- g_signal_connect_swapped (
- GTK_COMBO_BOX (priv->priority_combo), "changed",
- G_CALLBACK (comp_editor_page_changed), tdpage);
-
- /* Completed Date */
- g_signal_connect (
- priv->completed_date, "changed",
- G_CALLBACK (date_changed_cb), tdpage);
- g_signal_connect_swapped (
- priv->completed_date, "changed",
- G_CALLBACK (comp_editor_page_changed), tdpage);
-
- /* URL */
- g_signal_connect_swapped (
- priv->url, "changed",
- G_CALLBACK (comp_editor_page_changed), tdpage);
-}
-
-/**
- * task_details_page_construct:
- * @tdpage: An task details page.
- *
- * Constructs an task page by loading its Glade data.
- *
- * Return value: The same object as @tdpage, or NULL if the widgets could not
- * be created.
- **/
-TaskDetailsPage *
-task_details_page_construct (TaskDetailsPage *tdpage)
-{
- TaskDetailsPagePrivate *priv = tdpage->priv;
- CompEditor *editor;
-
- editor = comp_editor_page_get_editor (COMP_EDITOR_PAGE (tdpage));
-
- priv->builder = gtk_builder_new ();
- e_load_ui_builder_definition (priv->builder, "task-details-page.ui");
-
- if (!get_widgets (tdpage)) {
- g_message (
- "task_details_page_construct(): "
- "Could not find all widgets in the XML file!");
- return NULL;
- }
-
- init_widgets (tdpage);
-
- g_signal_connect_swapped (
- editor, "notify::client",
- G_CALLBACK (sensitize_widgets), tdpage);
-
- return tdpage;
-}
-
-/**
- * task_details_page_new:
- *
- * Creates a new task details page.
- *
- * Return value: A newly-created task details page, or NULL if the page could
- * not be created.
- **/
-TaskDetailsPage *
-task_details_page_new (CompEditor *editor)
-{
- TaskDetailsPage *tdpage;
-
- tdpage = g_object_new (TYPE_TASK_DETAILS_PAGE, "editor", editor, NULL);
- if (!task_details_page_construct (tdpage)) {
- g_object_unref (tdpage);
- g_return_val_if_reached (NULL);
- }
-
- return tdpage;
-}