规则和夏令时
Rrules and dayllght savings
我正在使用 rrule 在我的数据库中创建和存储事件。
一切正常,直到我发现我的重复事件在 3 月 31 日之后有一个小时的差异。
在法国,这一天我们会更改夏令时。
实际上,我的事件存储在 mongo 数据库中,包含事件的开始日期和持续时间,+ 最终规则(所有事件都不是重复事件),如下所示:
{
"_id" : ObjectId("5c8e4706703df43859aabbe7"),
"duration" : 2879,
"type" : "unavailability",
"title" : "Weekend",
"description" : "C'est le weekend",
"rrules" : [
{
"until" : ISODate("2021-03-22T23:00:00.000Z"),
"dtstart" : ISODate("2019-03-11T23:00:00.000Z"),
"byweekday" : [
{
"weekday" : 5
},
{
"weekday" : 6
}
],
"interval" : 1,
"freq" : 2
}
],
"__v" : 0
}
当前端在日历中搜索日期时,它将使用以下参数进行搜索:
?from=2019-03-10T23:00:00.000Z&to=2019-03-17T23:00:00.000Z
它适用于这个日期,因为两者之间没有夏令时。如果我有这个对象:
normalizedDates = { from: 2019-03-10T23:00:00.000Z, to: 2019-03-17T23:00:00.000Z }
和这条规则:
{ until: 2021-03-22T23:00:00.000Z,
dtstart: 2019-03-11T23:00:00.000Z,
byweekday: [ { weekday: 5 }, { weekday: 6 } ],
interval: 1,
freq: 2 }
运行 :
const recurringDays = rruleSet.between(normalizedDates.from, normalizedDates.to)
确实显示:
recurringDays [ 2019-03-23T23:00:00.000Z ]
但是如果你使用:
normalizedDates = { from: 2019-03-31T22:00:00.000Z, to: 2019-04-07T22:00:00.000Z }
规则 returns :
recurringDays [ 2019-03-31T23:00:00.000Z, 2019-04-06T23:00:00.000Z ]
在我期待的时候:
recurringDays [ 2019-04-06T22:00:00.000Z ]
你知道我该如何处理吗?
如果您希望重复规则遵守特定时区的夏令时,那么您必须使用该时区进行计划。在您的示例中,时间表基于 UTC。
R规则提供time zone support。您应该使用它,并指定 tzid: 'Europe/Paris'
.
此外,您可以考虑使用 toString
和 fromString
函数来处理 iCalendar 格式的字符串,并将其存储在您的 MongoDB 实例中,而不是将 RRule 序列化为 JSON.
我正在使用 rrule 在我的数据库中创建和存储事件。
一切正常,直到我发现我的重复事件在 3 月 31 日之后有一个小时的差异。
在法国,这一天我们会更改夏令时。
实际上,我的事件存储在 mongo 数据库中,包含事件的开始日期和持续时间,+ 最终规则(所有事件都不是重复事件),如下所示:
{
"_id" : ObjectId("5c8e4706703df43859aabbe7"),
"duration" : 2879,
"type" : "unavailability",
"title" : "Weekend",
"description" : "C'est le weekend",
"rrules" : [
{
"until" : ISODate("2021-03-22T23:00:00.000Z"),
"dtstart" : ISODate("2019-03-11T23:00:00.000Z"),
"byweekday" : [
{
"weekday" : 5
},
{
"weekday" : 6
}
],
"interval" : 1,
"freq" : 2
}
],
"__v" : 0
}
当前端在日历中搜索日期时,它将使用以下参数进行搜索:
?from=2019-03-10T23:00:00.000Z&to=2019-03-17T23:00:00.000Z
它适用于这个日期,因为两者之间没有夏令时。如果我有这个对象:
normalizedDates = { from: 2019-03-10T23:00:00.000Z, to: 2019-03-17T23:00:00.000Z }
和这条规则:
{ until: 2021-03-22T23:00:00.000Z,
dtstart: 2019-03-11T23:00:00.000Z,
byweekday: [ { weekday: 5 }, { weekday: 6 } ],
interval: 1,
freq: 2 }
运行 :
const recurringDays = rruleSet.between(normalizedDates.from, normalizedDates.to)
确实显示:
recurringDays [ 2019-03-23T23:00:00.000Z ]
但是如果你使用:
normalizedDates = { from: 2019-03-31T22:00:00.000Z, to: 2019-04-07T22:00:00.000Z }
规则 returns :
recurringDays [ 2019-03-31T23:00:00.000Z, 2019-04-06T23:00:00.000Z ]
在我期待的时候:
recurringDays [ 2019-04-06T22:00:00.000Z ]
你知道我该如何处理吗?
如果您希望重复规则遵守特定时区的夏令时,那么您必须使用该时区进行计划。在您的示例中,时间表基于 UTC。
R规则提供time zone support。您应该使用它,并指定 tzid: 'Europe/Paris'
.
此外,您可以考虑使用 toString
和 fromString
函数来处理 iCalendar 格式的字符串,并将其存储在您的 MongoDB 实例中,而不是将 RRule 序列化为 JSON.