Možnost náhledu a výběru na další dny v týdnu
This commit is contained in:
@@ -1,31 +1,56 @@
|
||||
import { formatDate, getHumanDate, getHumanTime, getIsWeekend } from "./utils";
|
||||
import { formatDate, getDayOfWeekIndex, getHumanDate, getHumanTime, getIsWeekend } from "./utils";
|
||||
import { callNotifikace } from "./notifikace";
|
||||
import { generateQr } from "./qr";
|
||||
import { ClientData, PizzaDayState, UdalostEnum, Pizza, PizzaSize, Order, PizzaOrder, Locations, Restaurants, Food, Menu } from "../../types";
|
||||
import getStorage from "./storage";
|
||||
import { getMenuSladovnicka, getMenuTechTower, getMenuUMotliku } from "./restaurants";
|
||||
import { downloadPizzy } from "./chefie";
|
||||
import { getTodayMock } from "./mock";
|
||||
|
||||
const storage = getStorage();
|
||||
|
||||
/** Vrátí dnešní datum, případně fiktivní datum pro účely vývoje a testování. */
|
||||
function getToday(): Date {
|
||||
export function getToday(): Date {
|
||||
if (process.env.MOCK_DATA === 'true') {
|
||||
return new Date('2023-05-31');
|
||||
return new Date(getTodayMock());
|
||||
}
|
||||
return new Date();
|
||||
}
|
||||
|
||||
/** Vrátí "prázdná" (implicitní) data, pokud ještě nikdo nehlasoval. */
|
||||
function getEmptyData(): ClientData {
|
||||
return { date: getHumanDate(getToday()), isWeekend: getIsWeekend(getToday()), choices: {} };
|
||||
/** Vrátí datum v aktuálním týdnu na základě předaného indexu (0 = pondělí). */
|
||||
export const getDateForWeekIndex = (index: number) => {
|
||||
if (index < 0 || index > 4) {
|
||||
// Nechceme shodit server, vrátíme dnešek
|
||||
console.log('Neplatný index dne v týdnu: ' + index);
|
||||
return getToday();
|
||||
}
|
||||
const date = getToday();
|
||||
date.setDate(date.getDate() - getDayOfWeekIndex(date) + index);
|
||||
return date;
|
||||
}
|
||||
|
||||
/** Vrátí "prázdná" (implicitní) data pro předaný den. */
|
||||
function getEmptyData(date?: Date): ClientData {
|
||||
const usedDate = date || getToday();
|
||||
return { date: getHumanDate(usedDate), isWeekend: getIsWeekend(usedDate), weekIndex: getDayOfWeekIndex(usedDate), choices: {} };
|
||||
}
|
||||
|
||||
/**
|
||||
* Vrátí veškerá klientská data pro aktuální den.
|
||||
* Vrátí veškerá klientská data pro předaný den, nebo aktuální den, pokud není předán.
|
||||
*/
|
||||
export async function getData(): Promise<ClientData> {
|
||||
return await storage.getData(formatDate(getToday())) || getEmptyData();
|
||||
export async function getData(date?: Date): Promise<ClientData> {
|
||||
const dateString = formatDate(date ?? getToday());
|
||||
const data = await storage.getData(dateString) || getEmptyData(date);
|
||||
// Dotažení jídel, pokud je ještě nemáme
|
||||
if (!data.menus) {
|
||||
data.menus = {
|
||||
[Restaurants.SLADOVNICKA]: await getRestaurantMenu(Restaurants.SLADOVNICKA, date ?? getToday()),
|
||||
[Restaurants.UMOTLIKU]: await getRestaurantMenu(Restaurants.UMOTLIKU, date ?? getToday()),
|
||||
[Restaurants.TECHTOWER]: await getRestaurantMenu(Restaurants.TECHTOWER, date ?? getToday()),
|
||||
}
|
||||
await storage.setData(dateString, data);
|
||||
}
|
||||
return data;
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -64,9 +89,9 @@ export async function savePizzaList(pizzaList: Pizza[]): Promise<ClientData> {
|
||||
* @param date datum
|
||||
* @param mock příznak, zda chceme pouze mock data
|
||||
*/
|
||||
export async function getRestaurantMenu(restaurant: Restaurants, date?: Date, mock?: boolean): Promise<Menu> {
|
||||
await initIfNeeded();
|
||||
const today = formatDate(getToday());
|
||||
export async function getRestaurantMenu(restaurant: Restaurants, date?: Date): Promise<Menu> {
|
||||
await initIfNeeded(date);
|
||||
const today = formatDate(date ?? getToday());
|
||||
const clientData: ClientData = await storage.getData(today);
|
||||
if (!clientData.menus) {
|
||||
clientData.menus = {};
|
||||
@@ -78,6 +103,7 @@ export async function getRestaurantMenu(restaurant: Restaurants, date?: Date, mo
|
||||
closed: false,
|
||||
food: [],
|
||||
};
|
||||
const mock = process.env.MOCK_DATA === 'true';
|
||||
switch (restaurant) {
|
||||
case Restaurants.SLADOVNICKA:
|
||||
clientData.menus[restaurant].food = await getMenuSladovnicka(date, mock);
|
||||
@@ -307,11 +333,11 @@ export async function finishPizzaDelivery(login: string, bankAccount?: string, b
|
||||
return clientData;
|
||||
}
|
||||
|
||||
export async function initIfNeeded() {
|
||||
const today = formatDate(getToday());
|
||||
const hasData = await storage.hasData(today);
|
||||
export async function initIfNeeded(date?: Date) {
|
||||
const usedDate = formatDate(date ?? getToday());
|
||||
const hasData = await storage.hasData(usedDate);
|
||||
if (!hasData) {
|
||||
await storage.setData(today, getEmptyData());
|
||||
await storage.setData(usedDate, getEmptyData(date || getToday()));
|
||||
}
|
||||
}
|
||||
|
||||
@@ -320,11 +346,12 @@ export async function initIfNeeded() {
|
||||
*
|
||||
* @param login login uživatele
|
||||
* @param location vybrané "umístění"
|
||||
* @param date datum, ke kterému se volba vztahuje
|
||||
* @returns
|
||||
*/
|
||||
export async function removeChoices(login: string, location: Locations) {
|
||||
const today = formatDate(getToday());
|
||||
let data: ClientData = await storage.getData(today);
|
||||
export async function removeChoices(login: string, location: Locations, date?: Date) {
|
||||
const selectedDay = formatDate(date ?? getToday());
|
||||
let data: ClientData = await storage.getData(selectedDay);
|
||||
// TODO zajistit, že neověřený uživatel se stejným loginem nemůže mazat volby ověřeného
|
||||
if (location in data.choices) {
|
||||
if (login in data.choices[location]) {
|
||||
@@ -332,7 +359,7 @@ export async function removeChoices(login: string, location: Locations) {
|
||||
if (Object.keys(data.choices[location]).length === 0) {
|
||||
delete data.choices[location]
|
||||
}
|
||||
await storage.setData(today, data);
|
||||
await storage.setData(selectedDay, data);
|
||||
}
|
||||
}
|
||||
return data;
|
||||
@@ -345,18 +372,19 @@ export async function removeChoices(login: string, location: Locations) {
|
||||
* @param login login uživatele
|
||||
* @param location vybrané "umístění"
|
||||
* @param foodIndex index jídla v jídelním lístku daného umístění, pokud existuje
|
||||
* @param date datum, ke kterému se volba vztahuje
|
||||
* @returns
|
||||
*/
|
||||
export async function removeChoice(login: string, location: Locations, foodIndex: number) {
|
||||
const today = formatDate(getToday());
|
||||
let data: ClientData = await storage.getData(today);
|
||||
export async function removeChoice(login: string, location: Locations, foodIndex: number, date?: Date) {
|
||||
const selectedDay = formatDate(date ?? getToday());
|
||||
let data: ClientData = await storage.getData(selectedDay);
|
||||
// TODO řešit ověření uživatele
|
||||
if (location in data.choices) {
|
||||
if (login in data.choices[location]) {
|
||||
const index = data.choices[location][login].options.indexOf(foodIndex);
|
||||
if (index > -1) {
|
||||
data.choices[location][login].options.splice(index, 1)
|
||||
await storage.setData(today, data);
|
||||
await storage.setData(selectedDay, data);
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -368,16 +396,15 @@ export async function removeChoice(login: string, location: Locations, foodIndex
|
||||
*
|
||||
* @param login login uživatele
|
||||
*/
|
||||
async function removeChoiceIfPresent(login: string) {
|
||||
const today = formatDate(getToday());
|
||||
let data: ClientData = await storage.getData(today);
|
||||
async function removeChoiceIfPresent(login: string, date: string) {
|
||||
let data: ClientData = await storage.getData(date);
|
||||
for (const key of Object.keys(data.choices)) {
|
||||
if (login in data.choices[key]) {
|
||||
delete data.choices[key][login];
|
||||
if (Object.keys(data.choices[key]).length === 0) {
|
||||
delete data.choices[key];
|
||||
}
|
||||
await storage.setData(today, data);
|
||||
await storage.setData(date, data);
|
||||
}
|
||||
}
|
||||
return data;
|
||||
@@ -390,12 +417,13 @@ async function removeChoiceIfPresent(login: string) {
|
||||
* @param location vybrané "umístění"
|
||||
* @param foodIndex volitelný index jídla v daném umístění
|
||||
* @param trusted příznak, zda se jedná o ověřeného uživatele
|
||||
* @param date datum, ke kterému se volba vztahuje
|
||||
* @returns aktuální data
|
||||
*/
|
||||
export async function addChoice(login: string, trusted: boolean, location: Locations, foodIndex?: number) {
|
||||
export async function addChoice(login: string, trusted: boolean, location: Locations, foodIndex?: number, date?: Date) {
|
||||
await initIfNeeded();
|
||||
const today = formatDate(getToday());
|
||||
let data: ClientData = await storage.getData(today);
|
||||
const selectedDate = formatDate(date ?? getToday());
|
||||
let data: ClientData = await storage.getData(selectedDate);
|
||||
// Ověření, že se neověřený užívatel nepokouší přepsat údaje ověřeného
|
||||
const locations = Object.values(data?.choices);
|
||||
let found = false;
|
||||
@@ -411,7 +439,7 @@ export async function addChoice(login: string, trusted: boolean, location: Locat
|
||||
}
|
||||
// Pokud měníme pouze lokaci, mažeme případné předchozí
|
||||
if (foodIndex == null) {
|
||||
data = await removeChoiceIfPresent(login);
|
||||
data = await removeChoiceIfPresent(login, selectedDate);
|
||||
}
|
||||
if (!(location in data.choices)) {
|
||||
data.choices[location] = {};
|
||||
@@ -425,7 +453,7 @@ export async function addChoice(login: string, trusted: boolean, location: Locat
|
||||
if (foodIndex != null && !data.choices[location][login].options.includes(foodIndex)) {
|
||||
data.choices[location][login].options.push(foodIndex);
|
||||
}
|
||||
await storage.setData(today, data);
|
||||
await storage.setData(selectedDate, data);
|
||||
return data;
|
||||
}
|
||||
|
||||
@@ -453,10 +481,11 @@ export async function updateNote(login: string, note?: string) {
|
||||
*
|
||||
* @param login login uživatele
|
||||
* @param time preferovaný čas odchodu
|
||||
* @param date datum, ke kterému se čas vztahuje
|
||||
*/
|
||||
export async function updateDepartureTime(login: string, time?: string) {
|
||||
const today = formatDate(getToday());
|
||||
let clientData: ClientData = await storage.getData(today);
|
||||
export async function updateDepartureTime(login: string, time?: string, date?: Date) {
|
||||
const selectedDate = formatDate(date ?? getToday());
|
||||
let clientData: ClientData = await storage.getData(selectedDate);
|
||||
const found = Object.values(clientData.choices).find(location => login in location);
|
||||
// TODO validace, že se jedná o restauraci
|
||||
if (found) {
|
||||
@@ -465,7 +494,7 @@ export async function updateDepartureTime(login: string, time?: string) {
|
||||
} else {
|
||||
found[login].departureTime = time;
|
||||
}
|
||||
await storage.setData(today, clientData);
|
||||
await storage.setData(selectedDate, clientData);
|
||||
}
|
||||
return clientData;
|
||||
}
|
||||
Reference in New Issue
Block a user