Podpora mock dat pro vývoj o víkendech
This commit is contained in:
parent
b438d2112a
commit
c814624dbc
@ -12,9 +12,10 @@ app.add_middleware(
|
|||||||
)
|
)
|
||||||
|
|
||||||
@app.get("/")
|
@app.get("/")
|
||||||
def read_root():
|
def read_root(mock: bool = False):
|
||||||
return {
|
return {
|
||||||
'sladovnicka': getMenuSladovnicka(),
|
'sladovnicka': getMenuSladovnicka(mock),
|
||||||
'uMotliku:': getMenuUMotliku(),
|
# TODO opravit dvojtečku!
|
||||||
'techTower': getMenuTechTower()
|
'uMotliku:': getMenuUMotliku(mock),
|
||||||
|
'techTower': getMenuTechTower(mock)
|
||||||
}
|
}
|
||||||
|
@ -96,7 +96,14 @@ def printMenu(name: str, foodList: List[Food]):
|
|||||||
print('\n')
|
print('\n')
|
||||||
|
|
||||||
|
|
||||||
def getMenuSladovnicka() -> List[Food]:
|
def getMenuSladovnicka(mock: bool = False) -> List[Food]:
|
||||||
|
if mock:
|
||||||
|
foodList: List[Food] = []
|
||||||
|
foodList.append(Food("Zelná polévka s klobásou", "0,25l", "35 Kč", True))
|
||||||
|
foodList.append(Food("Hovězí na česneku s bramborovým knedlíkem", "150g", "135 Kč"))
|
||||||
|
foodList.append(Food("Přírodní holandský řízek s bramborovou kaší, rajčatový salát", "250g", "135 Kč"))
|
||||||
|
foodList.append(Food("Bagel s vinnou klobásou, cibulový konfit, kysané zelí, slanina a hořčicová mayo, hranolky, curry omáčka", "350g", "135 Kč"))
|
||||||
|
return foodList
|
||||||
html = getOrDownloadHtml('sladovnicka', URL_SLADOVNICKA)
|
html = getOrDownloadHtml('sladovnicka', URL_SLADOVNICKA)
|
||||||
soup = BeautifulSoup(html, "html.parser")
|
soup = BeautifulSoup(html, "html.parser")
|
||||||
div = soup.select_one("div.tab-pane.fade.in.active")
|
div = soup.select_one("div.tab-pane.fade.in.active")
|
||||||
@ -137,7 +144,14 @@ def getMenuSladovnicka() -> List[Food]:
|
|||||||
return foodList
|
return foodList
|
||||||
|
|
||||||
|
|
||||||
def getMenuUMotliku() -> List[Food]:
|
def getMenuUMotliku(mock: bool = False) -> List[Food]:
|
||||||
|
if mock:
|
||||||
|
foodList: List[Food] = []
|
||||||
|
foodList.append(Food("Hovězí vývar s nudlemi", "0,33l", "35 Kč", True))
|
||||||
|
foodList.append(Food("Opečený párek, čočka, sázené vejce, okurka", "150g", "135 Kč"))
|
||||||
|
foodList.append(Food("Hovězí líčka na červeném víně, bramborová kaše", "150g", "145 Kč"))
|
||||||
|
foodList.append(Food("Tortilla s trhaným kuřecím masem, uzeným sýrem, dipem a kukuřicí, míchaný salát", "150g", "135 Kč"))
|
||||||
|
return foodList
|
||||||
html = getOrDownloadHtml('u_motliku', URL_MOTLICI)
|
html = getOrDownloadHtml('u_motliku', URL_MOTLICI)
|
||||||
soup = BeautifulSoup(html, "html.parser")
|
soup = BeautifulSoup(html, "html.parser")
|
||||||
table = soup.find("table", {"class": "Xtable-striped"})
|
table = soup.find("table", {"class": "Xtable-striped"})
|
||||||
@ -175,7 +189,13 @@ def getMenuUMotliku() -> List[Food]:
|
|||||||
return foodList
|
return foodList
|
||||||
|
|
||||||
|
|
||||||
def getMenuTechTower() -> List[Food]:
|
def getMenuTechTower(mock: bool = False) -> List[Food]:
|
||||||
|
if mock:
|
||||||
|
foodList: List[Food] = []
|
||||||
|
foodList.append(Food("Bavorská gulášová polévka s kroupami", "-", "40 Kč", True))
|
||||||
|
foodList.append(Food("Vepřové výpečky, kedlubnové zelí, bramborový knedlík", "-", "120 Kč"))
|
||||||
|
foodList.append(Food("Hambuger Black Angus s čedarem a slaninou, cibulové kroužky", "-", "220 Kč"))
|
||||||
|
return foodList
|
||||||
html = getOrDownloadHtml('techtower', URL_TECHTOWER)
|
html = getOrDownloadHtml('techtower', URL_TECHTOWER)
|
||||||
soup = BeautifulSoup(html, "html.parser")
|
soup = BeautifulSoup(html, "html.parser")
|
||||||
fonts = soup.find_all("font", {"class": ["wsw-41"]})
|
fonts = soup.find_all("font", {"class": ["wsw-41"]})
|
||||||
@ -189,7 +209,7 @@ def getMenuTechTower() -> List[Food]:
|
|||||||
siblings = font.parent.parent.find_next_siblings("p")
|
siblings = font.parent.parent.find_next_siblings("p")
|
||||||
# dayNumber = date.today().strftime("%w")
|
# dayNumber = date.today().strftime("%w")
|
||||||
currentDayName = getDayNameOfDate(datetime.datetime.now())
|
currentDayName = getDayNameOfDate(datetime.datetime.now())
|
||||||
foodList = []
|
foodList: List[Food] = []
|
||||||
doParse = False
|
doParse = False
|
||||||
for i in range(0, len(siblings)):
|
for i in range(0, len(siblings)):
|
||||||
text = siblings[i].text.strip().replace('\t', '').replace('\n', ' ')
|
text = siblings[i].text.strip().replace('\t', '').replace('\n', ' ')
|
||||||
|
@ -1,3 +1,4 @@
|
|||||||
|
export NODE_ENV=development
|
||||||
./food_api/run_dev.sh &
|
./food_api/run_dev.sh &
|
||||||
cd server && yarn install && yarn start &
|
cd server && yarn install && yarn start &
|
||||||
cd client && yarn install && yarn start &
|
cd client && yarn install && yarn start &
|
||||||
|
1
server/.env.development
Normal file
1
server/.env.development
Normal file
@ -0,0 +1 @@
|
|||||||
|
MOCK_DATA=true
|
@ -18,6 +18,7 @@
|
|||||||
"dependencies": {
|
"dependencies": {
|
||||||
"cheerio": "^1.0.0-rc.12",
|
"cheerio": "^1.0.0-rc.12",
|
||||||
"cors": "^2.8.5",
|
"cors": "^2.8.5",
|
||||||
|
"dotenv": "^16.1.3",
|
||||||
"express": "^4.18.2",
|
"express": "^4.18.2",
|
||||||
"request": "^2.88.2",
|
"request": "^2.88.2",
|
||||||
"request-promise": "^4.2.6",
|
"request-promise": "^4.2.6",
|
||||||
|
@ -110,7 +110,7 @@ export const fetchPizzy = async () => {
|
|||||||
// TODO tohle sem absolutně nepatří! dát do vlastní servisky!
|
// TODO tohle sem absolutně nepatří! dát do vlastní servisky!
|
||||||
export const fetchFood = async () => {
|
export const fetchFood = async () => {
|
||||||
try {
|
try {
|
||||||
const json = await rp(foodUrl);
|
const json = await rp({ uri: foodUrl, qs: { "mock": process.env.MOCK_DATA } });
|
||||||
return JSON.parse(json);
|
return JSON.parse(json);
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
console.error("Chyba při volání Food API", error);
|
console.error("Chyba při volání Food API", error);
|
||||||
|
@ -4,6 +4,11 @@ import bodyParser from "body-parser";
|
|||||||
import { fetchFood, fetchPizzy } from "./chefie";
|
import { fetchFood, fetchPizzy } from "./chefie";
|
||||||
import cors from 'cors';
|
import cors from 'cors';
|
||||||
import { getData, updateChoice } from "./service";
|
import { getData, updateChoice } from "./service";
|
||||||
|
import dotenv from 'dotenv';
|
||||||
|
import path from 'path';
|
||||||
|
|
||||||
|
const ENVIRONMENT = process.env.NODE_ENV || 'production'
|
||||||
|
dotenv.config({ path: path.resolve(__dirname, `../.env.${ENVIRONMENT}`) });
|
||||||
|
|
||||||
const app = express();
|
const app = express();
|
||||||
const server = require("http").createServer(app);
|
const server = require("http").createServer(app);
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
import { ClientData, Locations } from "./types";
|
import { ClientData, Locations } from "./types";
|
||||||
import { db } from "./database";
|
import { db } from "./database";
|
||||||
import { getHumanDate, getIsWeekend } from "./utils";
|
import { getHumanDate, getIsWeekend } from "./utils";
|
||||||
import { getDate } from "./utils";
|
import { formatDate } from "./utils";
|
||||||
|
|
||||||
// /** Jedna konkrétní pizza */
|
// /** Jedna konkrétní pizza */
|
||||||
// interface Pizza {
|
// interface Pizza {
|
||||||
@ -31,17 +31,24 @@ import { getDate } from "./utils";
|
|||||||
// orders?: Order[], // seznam objednávek, pokud není vyplněno, není založen pizza day
|
// orders?: Order[], // seznam objednávek, pokud není vyplněno, není založen pizza day
|
||||||
// }
|
// }
|
||||||
|
|
||||||
|
/** Vrátí dnešní datum, případně fiktivní datum pro účely vývoje a testování. */
|
||||||
|
function getToday(): Date {
|
||||||
|
if (process.env.MOCK_DATA) {
|
||||||
|
return new Date('2023-05-31');
|
||||||
|
}
|
||||||
|
return new Date();
|
||||||
|
}
|
||||||
|
|
||||||
/** Vrátí "prázdná" (implicitní) data, pokud ještě nikdo nehlasoval. */
|
/** Vrátí "prázdná" (implicitní) data, pokud ještě nikdo nehlasoval. */
|
||||||
function getEmptyData(): ClientData {
|
function getEmptyData(): ClientData {
|
||||||
return { date: getHumanDate(new Date()), isWeekend: getIsWeekend(new Date()), choices: {} };
|
return { date: getHumanDate(getToday()), isWeekend: getIsWeekend(getToday()), choices: {} };
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Vrátí veškerá klientská data pro aktuální den.
|
* Vrátí veškerá klientská data pro aktuální den.
|
||||||
*/
|
*/
|
||||||
export function getData(): ClientData {
|
export function getData(): ClientData {
|
||||||
const data = db.get(getDate()) || getEmptyData();
|
const data = db.get(formatDate(getToday())) || getEmptyData();
|
||||||
console.log("Vracím data pro dnešní den", data); // TODO smazat
|
|
||||||
return data;
|
return data;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -70,7 +77,7 @@ export function getData(): ClientData {
|
|||||||
// }
|
// }
|
||||||
|
|
||||||
export function initIfNeeded() {
|
export function initIfNeeded() {
|
||||||
const today = getDate();
|
const today = formatDate(getToday());
|
||||||
if (!db.has(today)) {
|
if (!db.has(today)) {
|
||||||
db.set(today, getEmptyData());
|
db.set(today, getEmptyData());
|
||||||
}
|
}
|
||||||
@ -91,7 +98,7 @@ export function removeChoice(login: string, data: ClientData) {
|
|||||||
|
|
||||||
export function updateChoice(login: string, choice: Locations | null) {
|
export function updateChoice(login: string, choice: Locations | null) {
|
||||||
initIfNeeded();
|
initIfNeeded();
|
||||||
const today = getDate();
|
const today = formatDate(getToday());
|
||||||
let data: ClientData = db.get(today);
|
let data: ClientData = db.get(today);
|
||||||
data = removeChoice(login, data);
|
data = removeChoice(login, data);
|
||||||
if (choice !== null) {
|
if (choice !== null) {
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
export function getDate() {
|
/** Vrátí datum v ISO formátu. */
|
||||||
const date = new Date();
|
export function formatDate(date: Date) {
|
||||||
let currentDay = String(date.getDate()).padStart(2, '0');
|
let currentDay = String(date.getDate()).padStart(2, '0');
|
||||||
let currentMonth = String(date.getMonth() + 1).padStart(2, "0");
|
let currentMonth = String(date.getMonth() + 1).padStart(2, "0");
|
||||||
let currentYear = date.getFullYear();
|
let currentYear = date.getFullYear();
|
||||||
|
@ -465,6 +465,11 @@ domutils@^3.0.1:
|
|||||||
domelementtype "^2.3.0"
|
domelementtype "^2.3.0"
|
||||||
domhandler "^5.0.1"
|
domhandler "^5.0.1"
|
||||||
|
|
||||||
|
dotenv@^16.1.3:
|
||||||
|
version "16.1.3"
|
||||||
|
resolved "https://registry.yarnpkg.com/dotenv/-/dotenv-16.1.3.tgz#0c67e90d0ddb48d08c570888f709b41844928210"
|
||||||
|
integrity sha512-FYssxsmCTtKL72fGBSvb1K9dRz0/VZeWqFme/vSb7r7323x4CRaHu4LvQ5JG3+s6yt2YPbBrkpiEODktfyjI9A==
|
||||||
|
|
||||||
ecc-jsbn@~0.1.1:
|
ecc-jsbn@~0.1.1:
|
||||||
version "0.1.2"
|
version "0.1.2"
|
||||||
resolved "https://registry.npmjs.org/ecc-jsbn/-/ecc-jsbn-0.1.2.tgz"
|
resolved "https://registry.npmjs.org/ecc-jsbn/-/ecc-jsbn-0.1.2.tgz"
|
||||||
|
Loading…
x
Reference in New Issue
Block a user