Javascript.RU

Создать новую тему Ответ
 
Опции темы Искать в теме
  #1 (permalink)  
Старый 20.04.2021, 12:41
Новичок на форуме
Отправить личное сообщение для typicsort Посмотреть профиль Найти все сообщения от typicsort
 
Регистрация: 20.04.2021
Сообщений: 5

Работа с методами
Как правильно можно засунуть эти 2 триггера в отдельные 2 метода(exampleWork1 и exampleWork2)?


module.exports = functions.pubsub
  .schedule("0 0 12 * *")
  .timeZone("")
  .onRun(async () => {
    const startDate = startOfDate();
    const endDate = endOfDate();
    const dateBefore = dateBeforeGameDay();
    const finishedGameStatusDayBefore = [
      ...finishedGameOrdersStatusIds
    ];
    let listGameOrders = await getGameOrdersForEmailing(startDate, endDate);
    let finishGameOrdersStatus = listGameOrders.filter((order) => {
      const gameDate = DateTime.fromJSDate(order.pickupDate)
        .toJSDate();
      if (dateBefore.getDay() === gameDate.getDay()) {
        return !finishedGameStatusDayBefore.includes(order.GameStatus);
      }
      return !finishedGameOrdersStatusIds.includes(order.GameStatus);
    });
    let rows = finishGameOrdersStatus
      .map(
        (id) =>
          `</td><td>${game.id}</td></tr>`
      )
    let view = ``;
    let statusGameOrdersView = `
<style></style>
  `;
    await sentGameHtmlEmail(statusGameOrdersView);
  });



const processGamerReminderEmail = async (gamerOrders: OrderData[]) => {
  const firstOrder = _.head(gamerOrders);
  const gamerName = firstOrder
    ? firstOrder.gamerName
      ? firstOrder.gamerName
      : ""
    : "";
  const gamerId = firstOrder
    ? firstGameOrder.gamerId
      ? firstGameOrder.gamerId
      : ""
    : "";
  const gamerData = await (await gamer.doc(gamerId).get()).data();
  const gamerReminderEmail = gamerData.reminderEmail;
  if (gamerReminderEmail === "" || !gamerReminderEmail) {
    console.log(
      ` ${gamerName} reminder email is not detected`
    );
    return;
  }
  let rows = gamerOrders
    .map(
      (doc: OrderData) =>
        `...`
    )
  let view = `<table></table>
                `;
  return await sentGameHtmlEmail(
    gamerReminderEmail
  );
};
module.exports = functions.pubsub
  .schedule("0 0 12 * *")
  .timeZone("")
  .onRun(async () => {
    const startDate = startOfDate();
    const endDate = endOfDate();
    const dateBefore = dateBeforeGameDay();
    const finalizedStatusDayBefore = [
      ...finalisedOrdersStatusIds
    ];
    let listGameOrders = await getGameOrdersMailing(startDate, endDate);
    let ordersStatus = listGameOrders.filter((gameOrder) => {
      const gameDate = DateTime.fromJSDate(gameOrder.gamePDate)
      .toJSDate();
      if (dateBefore.getDay() === gameDate.getDay()) {
        return !finalizedStatusDayBefore.includes(gameOrder.gameStatus.id);
      }
      return !finalisedOrdersStatusIds.includes(gameOrder.gameStatus.id);
    });
    let orderedByGamerId = _.orderBy(
      ordersStatus.map((order) => order),
      "gamerId"
    );
    return await Promise.all(
      _.map(orderedByGamerId, (gameOrders: OrderData[]) => {
        return processGamerReminderEmail(gameOrders);
      })
    );
  });


Я так понимаю что выглядить методы должны приблизительно так?:
newGameEmails(()==>{
exampleWork1(),
exampleWork2()})

Последний раз редактировалось typicsort, 20.04.2021 в 12:55.
Ответить с цитированием
  #2 (permalink)  
Старый 21.04.2021, 11:22
Аватар для MallSerg
Профессор
Отправить личное сообщение для MallSerg Посмотреть профиль Найти все сообщения от MallSerg
 
Регистрация: 07.03.2011
Сообщений: 1,138

Хрустальный шар подсказывает что это специализированное API для сервера баз данных по тупу firebase.

Ты вряд ли дождешься ответа если не будешь указывать для какой системы и в каком окружении этот код будет выполнятся.

Обычно такие системы имеют документацию которая должна давать ответы на все вопросы.
Ответить с цитированием
Ответ



Опции темы Искать в теме
Искать в теме:

Расширенный поиск


Похожие темы
Тема Автор Раздел Ответов Последнее сообщение
Вакансия: Программист IOS, работа в офисе,г.Ростов-на-Дону Анна NikitaOnline Работа 0 21.03.2016 18:45
Javascript фронтенд разработчик(долгосрочная, удаленная работа) cpp Работа 11 16.09.2012 12:04
Постоянная работа / Front-end / Москва kooper Работа 4 29.09.2011 22:06