Как произвести повторение rschedule продолжительности с временными сдвигами - PullRequest
1 голос
/ 08 ноября 2019

Я использую rSchedule для получения интервалов рабочего часа. Но часовой пояс игнорируется. Как мне этого добиться?

На вход вводятся интервалы рабочих часов в день с часовым поясом, как показано ниже.

const input = {
  workingHours:[{start:9, end:12}, {start:13, end:18}], 
  timeZone:'Europe/Berlin'
};

С помощью приведенного ниже кода я ожидаю получить интервалы относительно дневных световых сдвигов в году. Однако полученный вывод игнорирует предоставленную мной временную зону.

import { Schedule } from "@rschedule/core/generators";
import '@rschedule/moment-tz-date-adapter/setup';
import moment from 'moment-timezone';

const schedule = new Schedule({
      rrules: [
        {
          frequency: "MONTHLY",//frequency: "WEEKLY",
          //byDayOfWeek: ["MO", 'TU', 'WE', 'TH', 'FR'],
          duration:1000 * 60 * 60 * 3,//input.workingHours[0].end-input.workingHours[0].start,
          byHourOfDay:[12],//input.workingHours[0].end
          timezone:'Europe/Berlin',//input.timeZone,

          start: moment(Date.UTC(2019, 0, 1)),
          end: moment(Date.UTC(2020, 0, 0))
        }
      ]
    });

    schedule.occurrences().toArray().forEach(adapter => {
      console.log(
          {
            start: adapter.date.toISOString(),
            end: adapter.end.toISOString(),
          }
        )
    })

Выход игнорирует часовой пояс:

 { start: '2019-01-01T09:00:00.000Z', end: '2019-01-01T12:00:00.000Z' }
 { start: '2019-02-01T09:00:00.000Z', end: '2019-02-01T12:00:00.000Z' }
 { start: '2019-03-01T09:00:00.000Z', end: '2019-03-01T12:00:00.000Z' }
 { start: '2019-04-01T09:00:00.000Z', end: '2019-04-01T12:00:00.000Z' }
 { start: '2019-05-01T09:00:00.000Z', end: '2019-05-01T12:00:00.000Z' }
 { start: '2019-06-01T09:00:00.000Z', end: '2019-06-01T12:00:00.000Z' }
 { start: '2019-07-01T09:00:00.000Z', end: '2019-07-01T12:00:00.000Z' }
 { start: '2019-08-01T09:00:00.000Z', end: '2019-08-01T12:00:00.000Z' }
 { start: '2019-09-01T09:00:00.000Z', end: '2019-09-01T12:00:00.000Z' }
 { start: '2019-10-01T09:00:00.000Z', end: '2019-10-01T12:00:00.000Z' }
 { start: '2019-11-01T09:00:00.000Z', end: '2019-11-01T12:00:00.000Z' }
 { start: '2019-12-01T09:00:00.000Z', end: '2019-12-01T12:00:00.000Z' }

Ожидаемый вывод:

{ start: '2019-01-01T11:00:00.000Z', end: '2019-01-01T14:00:00.000Z' },
{ start: '2019-02-01T11:00:00.000Z', end: '2019-02-01T14:00:00.000Z' },
{ start: '2019-03-01T11:00:00.000Z', end: '2019-03-01T14:00:00.000Z' },
{ start: '2019-04-01T10:00:00.000Z', end: '2019-04-01T13:00:00.000Z' },
{ start: '2019-05-01T10:00:00.000Z', end: '2019-05-01T13:00:00.000Z' },
{ start: '2019-06-01T10:00:00.000Z', end: '2019-06-01T13:00:00.000Z' },
{ start: '2019-07-01T10:00:00.000Z', end: '2019-07-01T13:00:00.000Z' },
{ start: '2019-08-01T10:00:00.000Z', end: '2019-08-01T13:00:00.000Z' },
{ start: '2019-09-01T10:00:00.000Z', end: '2019-09-01T13:00:00.000Z' },
{ start: '2019-10-01T10:00:00.000Z', end: '2019-10-01T13:00:00.000Z' },
{ start: '2019-11-01T11:00:00.000Z', end: '2019-11-01T14:00:00.000Z' },
{ start: '2019-12-01T11:00:00.000Z', end: '2019-12-01T14:00:00.000Z' }

1 Ответ

0 голосов
/ 09 ноября 2019

Поскольку я не знаком с этими часовыми поясами (и не знаю, в каком часовом поясе предполагается «ожидаемый результат»), немного неясно, что вы ожидаете. Но, как @ JorgeFuentesGonzález указал в комментарии, проблема заключается в , вероятно, , что вы не предоставляете start дату и время в надлежащем часовом поясе.

Как указано в Исходный код rSchedule (который должен удобно отображаться в виде всплывающей подсказки в редакторах, таких как VSCode - edit Я также рассмотрел это и в документации по rSchedule ),опция конфигурации timezone для объектов Rule не изменяет часовой пояс, в котором находится правило, он меняет часовой пояс, в котором отображается правило in. Это различие важно для внутреннего функционирования rSchedule, но яв этом случае можно увидеть, что это неясно.

Таким образом, ваше правило генерирует события в вашем местном часовом поясе (потому что start: moment(Date.UTC(2019, 0, 1)) генерирует локальный moment), а затем эти события преобразуются в 'Europe/Berlin'часовой пояс перед выходом. Кроме ждать! Это не то, что происходит. Этот Rule является частью Schedule, поэтому часовой пояс расписания определяет выходной часовой пояс событий. В расписании, похоже, нет часового пояса (поэтому он находится в местном часовом поясе). Поэтому я думаю, что правило находится в местном часовом поясе, а выходные даты - в местном часовом поясе.

  • Примечание: запись в журнал консоли с использованием toISOString() может скрывать тот факт, что ваши выходные датынаходятся в вашем местном часовом поясе, а не в любом часовом поясе, который вы ожидаете.

В зависимости от того, чего вы пытаетесь достичь, я бы предложил что-то вроде следующего:

import { Schedule } from "@rschedule/core/generators";
import '@rschedule/moment-tz-date-adapter/setup';
import moment from 'moment-timezone';

const schedule = new Schedule({
  rrules: [
    {
      frequency: "MONTHLY",//frequency: "WEEKLY",
      duration:1000 * 60 * 60 * 3,//input.workingHours[0].end-input.workingHours[0].start,
      byHourOfDay:[12],//input.workingHours[0].end
      start: moment.tz(Date.UTC(2019, 0, 1), 'Europe/Berlin'),
      end: moment.tz(Date.UTC(2020, 0, 0), 'Europe/Berlin')
    }
  ],
  timezone:'Europe/Berlin'
});

Демонстрация Codesandbox здесь .

Дайте мне знать, если вы все еще не видите, чего ожидаете.

...