mirror of
https://github.com/M66B/FairEmail.git
synced 2025-01-04 06:20:26 +00:00
Event times are always UTC
This commit is contained in:
parent
a04a9f4c8c
commit
fbb9bfbe33
1 changed files with 20 additions and 15 deletions
|
@ -54,6 +54,7 @@ import biweekly.io.text.ICalReader;
|
||||||
import biweekly.parameter.ParticipationStatus;
|
import biweekly.parameter.ParticipationStatus;
|
||||||
import biweekly.property.Action;
|
import biweekly.property.Action;
|
||||||
import biweekly.property.Attendee;
|
import biweekly.property.Attendee;
|
||||||
|
import biweekly.property.ICalProperty;
|
||||||
import biweekly.property.RecurrenceRule;
|
import biweekly.property.RecurrenceRule;
|
||||||
import biweekly.property.Trigger;
|
import biweekly.property.Trigger;
|
||||||
import biweekly.util.Duration;
|
import biweekly.util.Duration;
|
||||||
|
@ -95,6 +96,16 @@ public class CalendarHelper {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static String getTimeZoneID(ICalendar icalendar, ICalProperty property) {
|
||||||
|
TimezoneInfo tzinfo = icalendar.getTimezoneInfo();
|
||||||
|
TimezoneAssignment tza = (tzinfo == null ? null : tzinfo.getTimezone(property));
|
||||||
|
TimeZone tz = (tza == null ? null : tza.getTimeZone());
|
||||||
|
String tzid = (tz == null ? null : tz.getID());
|
||||||
|
if (tzid == null)
|
||||||
|
tzid = TimeZone.getDefault().getID();
|
||||||
|
return tzid;
|
||||||
|
}
|
||||||
|
|
||||||
static Long exists(Context context, String selectedAccount, String selectedName, String uid) {
|
static Long exists(Context context, String selectedAccount, String selectedName, String uid) {
|
||||||
ContentResolver resolver = context.getContentResolver();
|
ContentResolver resolver = context.getContentResolver();
|
||||||
try (Cursor cursor = resolver.query(CalendarContract.Events.CONTENT_URI,
|
try (Cursor cursor = resolver.query(CalendarContract.Events.CONTENT_URI,
|
||||||
|
@ -154,19 +165,14 @@ public class CalendarHelper {
|
||||||
ICalDate start = (event.getDateStart() == null ? null : event.getDateStart().getValue());
|
ICalDate start = (event.getDateStart() == null ? null : event.getDateStart().getValue());
|
||||||
ICalDate end = (event.getDateEnd() == null ? null : event.getDateEnd().getValue());
|
ICalDate end = (event.getDateEnd() == null ? null : event.getDateEnd().getValue());
|
||||||
|
|
||||||
// Assume one time zone
|
String tzstart = getTimeZoneID(icalendar, event.getDateStart());
|
||||||
TimezoneInfo tzinfo = icalendar.getTimezoneInfo();
|
String tzend = getTimeZoneID(icalendar, event.getDateEnd());
|
||||||
TimezoneAssignment tza = (tzinfo == null ? null : tzinfo.getTimezone(event.getDateStart()));
|
|
||||||
TimeZone tz = (tza == null ? null : tza.getTimeZone());
|
|
||||||
String tzid = (tz == null ? null : tz.getID());
|
|
||||||
if (tzid == null)
|
|
||||||
tzid = TimeZone.getDefault().getID();
|
|
||||||
|
|
||||||
String rrule = null;
|
String rrule = null;
|
||||||
RecurrenceRule recurrence = event.getRecurrenceRule();
|
RecurrenceRule recurrence = event.getRecurrenceRule();
|
||||||
if (recurrence != null) {
|
if (recurrence != null) {
|
||||||
RecurrenceRuleScribe scribe = new RecurrenceRuleScribe();
|
RecurrenceRuleScribe scribe = new RecurrenceRuleScribe();
|
||||||
WriteContext wcontext = new WriteContext(ICalVersion.V2_0, tzinfo, null);
|
WriteContext wcontext = new WriteContext(ICalVersion.V2_0, icalendar.getTimezoneInfo(), null);
|
||||||
rrule = scribe.writeText(recurrence, wcontext);
|
rrule = scribe.writeText(recurrence, wcontext);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -206,9 +212,10 @@ public class CalendarHelper {
|
||||||
if (!TextUtils.isEmpty(organizer))
|
if (!TextUtils.isEmpty(organizer))
|
||||||
values.put(CalendarContract.Events.ORGANIZER, organizer);
|
values.put(CalendarContract.Events.ORGANIZER, organizer);
|
||||||
|
|
||||||
values.put(CalendarContract.Events.EVENT_TIMEZONE, tzid);
|
|
||||||
values.put(CalendarContract.Events.DTSTART, start.getTime());
|
values.put(CalendarContract.Events.DTSTART, start.getTime());
|
||||||
values.put(CalendarContract.Events.DTEND, end.getTime());
|
values.put(CalendarContract.Events.DTEND, end.getTime());
|
||||||
|
values.put(CalendarContract.Events.EVENT_TIMEZONE, "UTC");
|
||||||
|
values.put(CalendarContract.Events.EVENT_END_TIMEZONE, "UTC");
|
||||||
|
|
||||||
if (rrule != null)
|
if (rrule != null)
|
||||||
values.put(CalendarContract.Events.RRULE, rrule);
|
values.put(CalendarContract.Events.RRULE, rrule);
|
||||||
|
@ -229,9 +236,8 @@ public class CalendarHelper {
|
||||||
" id=" + calId + ":" + eventId +
|
" id=" + calId + ":" + eventId +
|
||||||
" uid=" + uid +
|
" uid=" + uid +
|
||||||
" organizer=" + organizer +
|
" organizer=" + organizer +
|
||||||
" tz=" + tzid +
|
" start=" + new Date(start.getTime()) + "/" + tzstart +
|
||||||
" start=" + new Date(start.getTime()) +
|
" end=" + new Date(end.getTime()) + "/" + tzend +
|
||||||
" end=" + new Date(end.getTime()) +
|
|
||||||
" rrule=" + rrule +
|
" rrule=" + rrule +
|
||||||
" summary=" + summary +
|
" summary=" + summary +
|
||||||
" location=" + location +
|
" location=" + location +
|
||||||
|
@ -243,9 +249,8 @@ public class CalendarHelper {
|
||||||
" id=" + calId + ":" + existId +
|
" id=" + calId + ":" + existId +
|
||||||
" uid=" + uid +
|
" uid=" + uid +
|
||||||
" organizer=" + organizer +
|
" organizer=" + organizer +
|
||||||
" tz=" + tzid +
|
" start=" + new Date(start.getTime()) + "/" + tzstart +
|
||||||
" start=" + new Date(start.getTime()) +
|
" end=" + new Date(end.getTime()) + "/" + tzend +
|
||||||
" end=" + new Date(end.getTime()) +
|
|
||||||
" rrule=" + rrule +
|
" rrule=" + rrule +
|
||||||
" summary=" + summary +
|
" summary=" + summary +
|
||||||
" location=" + location +
|
" location=" + location +
|
||||||
|
|
Loading…
Reference in a new issue