summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGeorges Basile Stavracas Neto <georges.stavracas@gmail.com>2022-10-17 14:03:41 -0300
committerGeorges Basile Stavracas Neto <georges.stavracas@gmail.com>2022-10-17 23:37:13 -0300
commit102346534a0454a3985632d6ddbf71f4602bb1c1 (patch)
tree440306b2dc36a85bb61b6f087d5b563db14b0f27
parent679a392b71e67cf5769501dcd100dd4042255c24 (diff)
downloadgnome-calendar-102346534a0454a3985632d6ddbf71f4602bb1c1.tar.gz
event-editor/dialog: Improve detection of MOD_ALL exclusion cases
-rw-r--r--src/gui/event-editor/gcal-event-editor-dialog.c18
-rw-r--r--src/gui/event-editor/gcal-schedule-section.c17
-rw-r--r--src/gui/event-editor/gcal-schedule-section.h2
3 files changed, 26 insertions, 11 deletions
diff --git a/src/gui/event-editor/gcal-event-editor-dialog.c b/src/gui/event-editor/gcal-event-editor-dialog.c
index 3f83e7a1..6c3527db 100644
--- a/src/gui/event-editor/gcal-event-editor-dialog.c
+++ b/src/gui/event-editor/gcal-event-editor-dialog.c
@@ -331,7 +331,7 @@ on_done_button_clicked_cb (GtkButton *button,
GcalCalendar *selected_calendar;
GcalCalendar *calendar;
GcalManager *manager;
- gboolean schedule_changed;
+ gboolean can_show_mod_all;
gboolean was_recurrent;
gint i;
@@ -341,7 +341,7 @@ on_done_button_clicked_cb (GtkButton *button,
if (gcal_calendar_is_read_only (calendar))
GCAL_GOTO (out);
- schedule_changed = FALSE;
+ can_show_mod_all = TRUE;
if (!self->event_is_new)
{
gboolean anything_changed = FALSE;
@@ -352,18 +352,14 @@ on_done_button_clicked_cb (GtkButton *button,
section_changed = gcal_event_editor_section_changed (self->sections[i]);
anything_changed |= section_changed;
-
- if (self->sections[i] == self->schedule_section)
- schedule_changed = section_changed;
}
- GCAL_TRACE_MSG ("Event %s changed: %d, schedule changed: %d",
- gcal_event_get_uid (self->event),
- anything_changed,
- schedule_changed);
-
if (!anything_changed)
goto out;
+
+ can_show_mod_all =
+ !gcal_schedule_section_recurrence_changed (GCAL_SCHEDULE_SECTION (self->schedule_section)) &&
+ !gcal_schedule_section_day_changed (GCAL_SCHEDULE_SECTION (self->schedule_section));
}
/*
@@ -399,7 +395,7 @@ on_done_button_clicked_cb (GtkButton *button,
{
gcal_utils_ask_recurrence_modification_type (GTK_WIDGET (self),
self->event,
- !schedule_changed,
+ can_show_mod_all,
on_ask_recurrence_response_save_cb,
self);
return;
diff --git a/src/gui/event-editor/gcal-schedule-section.c b/src/gui/event-editor/gcal-schedule-section.c
index 93f5e029..2aed8e30 100644
--- a/src/gui/event-editor/gcal-schedule-section.c
+++ b/src/gui/event-editor/gcal-schedule-section.c
@@ -827,3 +827,20 @@ gcal_schedule_section_recurrence_changed (GcalScheduleSection *self)
GCAL_RETURN (!gcal_recurrence_is_equal (recurrence, gcal_event_get_recurrence (self->event)));
}
+
+gboolean
+gcal_schedule_section_day_changed (GcalScheduleSection *self)
+{
+ g_autoptr (GDateTime) start_date = NULL;
+ g_autoptr (GDateTime) end_date = NULL;
+
+ g_return_val_if_fail (GCAL_IS_SCHEDULE_SECTION (self), FALSE);
+
+ GCAL_ENTRY;
+
+ start_date = get_date_start (self);
+ end_date = get_date_end (self);
+
+ GCAL_RETURN (gcal_date_time_compare_date (start_date, gcal_event_get_date_start (self->event)) < 0 ||
+ gcal_date_time_compare_date (end_date, gcal_event_get_date_end (self->event)) > 0);
+}
diff --git a/src/gui/event-editor/gcal-schedule-section.h b/src/gui/event-editor/gcal-schedule-section.h
index ee676a82..def974c3 100644
--- a/src/gui/event-editor/gcal-schedule-section.h
+++ b/src/gui/event-editor/gcal-schedule-section.h
@@ -29,4 +29,6 @@ G_DECLARE_FINAL_TYPE (GcalScheduleSection, gcal_schedule_section, GCAL, SCHEDULE
gboolean gcal_schedule_section_recurrence_changed (GcalScheduleSection *self);
+gboolean gcal_schedule_section_day_changed (GcalScheduleSection *self);
+
G_END_DECLS