aboutsummaryrefslogtreecommitdiffstats
path: root/widgets/misc/e-dateedit.h
diff options
context:
space:
mode:
authorDamon Chaplin <damon@helixcode.com>2000-11-27 07:10:17 +0800
committerDamon Chaplin <damon@src.gnome.org>2000-11-27 07:10:17 +0800
commitcc432378790ce854441f9fa630448fc7733bd484 (patch)
tree5f32a2b505ae61c534c71cb0ee902b0be6275e86 /widgets/misc/e-dateedit.h
parentb526e3dc17ff35b5d9d04f8102a8c264c0861619 (diff)
downloadgsoc2013-evolution-cc432378790ce854441f9fa630448fc7733bd484.tar.gz
gsoc2013-evolution-cc432378790ce854441f9fa630448fc7733bd484.tar.zst
gsoc2013-evolution-cc432378790ce854441f9fa630448fc7733bd484.zip
updated to emit "changed" when appropriate, which turned out to be
2000-10-26 Damon Chaplin <damon@helixcode.com> * e-dateedit.[hc]: updated to emit "changed" when appropriate, which turned out to be amazingly difficult :( Also added e_date_edit_get/set_date() to get/set just the date. Added e_date_edit_date_is_valid() & e_date_edit_time_is_valid() so you can check if the user has tried to enter an invalid date. (All the get_date/time functions return the last valid date entered.) * test-dateedit.c: updated a bit. svn path=/trunk/; revision=6672
Diffstat (limited to 'widgets/misc/e-dateedit.h')
-rw-r--r--widgets/misc/e-dateedit.h37
1 files changed, 33 insertions, 4 deletions
diff --git a/widgets/misc/e-dateedit.h b/widgets/misc/e-dateedit.h
index 903c64e732..9dd31b79dc 100644
--- a/widgets/misc/e-dateedit.h
+++ b/widgets/misc/e-dateedit.h
@@ -28,6 +28,14 @@
/*
* EDateEdit - a widget based on GnomeDateEdit to provide a date & optional
* time field with popups for entering a date.
+ *
+ * It emits a "changed" signal when the date and/or time has changed.
+ * You can check if the last date or time entered was invalid by
+ * calling e_date_edit_date_is_valid() and e_date_edit_time_is_valid().
+ *
+ * Note that when the user types in a date or time, it will only emit the
+ * signals when the user presses the return key or switches the keyboard
+ * focus to another widget, or you call one of the _get_time/date functions.
*/
#ifndef __E_DATE_EDIT_H_
@@ -54,7 +62,7 @@ struct _EDateEdit {
GtkHBox hbox;
/*< private >*/
- EDateEditPrivate *_priv;
+ EDateEditPrivate *priv;
};
struct _EDateEditClass {
@@ -66,12 +74,33 @@ struct _EDateEditClass {
guint e_date_edit_get_type (void);
GtkWidget* e_date_edit_new (void);
-time_t e_date_edit_get_time (EDateEdit *dedit);
+/* Returns TRUE if the last date and time set were valid. The date and time
+ are only set when the user hits Return or switches keyboard focus, or
+ selects a date or time from the popup. */
+gboolean e_date_edit_date_is_valid (EDateEdit *dedit);
+gboolean e_date_edit_time_is_valid (EDateEdit *dedit);
+
+/* Returns the last valid date & time set, or -1 if the date & time was set to
+ 'None' and this is permitted via e_date_edit_set_allow_no_date_set. */
+time_t e_date_edit_get_time (EDateEdit *dedit);
void e_date_edit_set_time (EDateEdit *dedit,
time_t the_time);
-/* These get or set the value in the time field, useful if only a time is
- being edited. */
+/* This returns the last valid date set, without the time. It returns TRUE
+ if a date is set, or FALSE if the date is set to 'None' and this is
+ permitted via e_date_edit_set_allow_no_date_set. */
+gboolean e_date_edit_get_date (EDateEdit *dedit,
+ gint *year,
+ gint *month,
+ gint *day);
+void e_date_edit_set_date (EDateEdit *dedit,
+ gint year,
+ gint month,
+ gint day);
+
+/* This returns the last valid time set, without the date. It returns TRUE
+ if a time is set, or FALSE if the time is set to 'None' and this is
+ permitted via e_date_edit_set_allow_no_date_set. */
gboolean e_date_edit_get_time_of_day (EDateEdit *dedit,
gint *hour,
gint *minute);