Compare commits
9 Commits
42c60f9db5
...
scraper_te
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
eef9b788e4 | ||
|
|
d304805006 | ||
|
|
cecc914935 | ||
| 206f7d6fb3 | |||
| df0e47c610 | |||
| 3b9aa8150b | |||
| bc557b35af | |||
| 4987dc4cf7 | |||
| 48825185b8 |
@@ -66,8 +66,13 @@ class scraper:
|
||||
matches_to_add = []
|
||||
|
||||
# TODO: Sprawdź, czy sportowiec istnieje w bazie.
|
||||
# Jeśli nie, dodaj go w podobny sposób, jak
|
||||
# w sample_data_init() (w lewy_db.py).
|
||||
if not self.__czy_x_istnieje("sportowcy", zewnetrzne_id_sportowca=zewnetrzne_id_sportowca):
|
||||
print(f"{c.OKCYAN}Dodaję nowego sportowca do bazy danych{c.ENDC}")
|
||||
self.db.simple_insert_one("sportowcy",
|
||||
zewnetrzne_id_sportowca=zewnetrzne_id_sportowca,
|
||||
imie="Robert",
|
||||
nazwisko="Lewandowski"
|
||||
)
|
||||
|
||||
page = 0
|
||||
match_num = 0
|
||||
@@ -83,17 +88,14 @@ class scraper:
|
||||
retrieved_matches = safe_traverse(retrieved_page, ["lastMatches"], default=[])
|
||||
for match in retrieved_matches:
|
||||
|
||||
match_id = safe_traverse(match, ["eventEncodedId"], default="non-existent-match-id")
|
||||
match_id = safe_traverse(match, ["eventEncodedId"], default="non-existent-match-id")
|
||||
home_club_id = safe_traverse(match, ["homeParticipantUrl"], default="non-existent-club-id")
|
||||
away_club_id = safe_traverse(match, ["awayParticipantUrl"], default="non-existent-club-id")
|
||||
|
||||
# Sprawdź, czy mecz nie znajduje się już w bazie
|
||||
if self.czy_mecz_istnieje(zewnetrzne_id_meczu=match_id):
|
||||
stop_scraping = True
|
||||
break
|
||||
|
||||
# Sprawdź, czy klub znajduje się już w bazie. Jeśli nie,
|
||||
# trzeba go dodać przed meczem.
|
||||
if not self.czy_klub_istnieje(id_klubu=home_club_id):
|
||||
print(f"{c.OKCYAN}Nowy klub{c.ENDC}: {home_club_id}")
|
||||
self.db.simple_insert_one("kluby",
|
||||
@@ -107,29 +109,42 @@ class scraper:
|
||||
pelna_nazwa=safe_traverse(match, ["awayParticipantName"]),
|
||||
skrocona_nazwa=safe_traverse(match, ["awayParticipant3CharName"]))
|
||||
|
||||
# TODO: (opcjonalnie) zamień *słownik match* na *obiekt mecz*
|
||||
# TODO: Zamień słownik match na obiekt mecz
|
||||
mecz = {
|
||||
"zewnetrzne_id_meczu": match_id,
|
||||
"data": safe_traverse(match, ["startTimeTimestamp"], default=0),
|
||||
"id_klubu_gospodarzy": home_club_id,
|
||||
"id_klubu_gosci": away_club_id,
|
||||
"gole_gospodarzy": safe_traverse(match, ["homeScore", "current"], default=0),
|
||||
"gole_gosci": safe_traverse(match, ["awayScore", "current"], default=0),
|
||||
"rozgrywki": safe_traverse(match, ["tournament", "name"], default="Brak"),
|
||||
"zewnetrzne_id_sportowca": zewnetrzne_id_sportowca
|
||||
}
|
||||
|
||||
# TODO: Dodaj obiekt mecz do bazy
|
||||
self.db.simple_insert_one("mecze", **mecz)
|
||||
|
||||
|
||||
# TODO: dodaj obiekt mecz do bazy (simple_insert_one(), simple_insert_many())
|
||||
print(f"{c.OKCYAN}Nowy mecz ({match_num}){c.ENDC}: {match}")
|
||||
print(f"{c.OKCYAN}Nowy mecz ({match_num}){c.ENDC}: {match_id}")
|
||||
match_num += 1
|
||||
|
||||
|
||||
# TODO: Zaktualizuj statystyki sportowca
|
||||
# np. zlicz gole RL9
|
||||
strzelcy = safe_traverse(match, ["goals"], default=[])
|
||||
liczba_goli = 0
|
||||
for gol in strzelcy:
|
||||
if gol.get("playerId") == zewnetrzne_id_sportowca:
|
||||
liczba_goli += 1
|
||||
|
||||
|
||||
# Opcjonalnie: odczekaj kilka sekund (?)
|
||||
# Problem w tym, że time.sleep() jest blokujące,
|
||||
# a asyncio i flask nie idą ze sobą w parze.
|
||||
# Można to załatwić osobnym skryptem, ale
|
||||
# martwmy się tym dopiero, gdy dostaniemy
|
||||
# rate limita. - sherl
|
||||
if liczba_goli > 0:
|
||||
# zwiększamy liczbę goli zawodnika
|
||||
print(f"{c.OKBLUE}Zwiększam gole Lewandowskiego o {liczba_goli}{c.ENDC}")
|
||||
self.db.increment_stat("sportowcy", {"zewnetrzne_id_sportowca": zewnetrzne_id_sportowca}, "gole", liczba_goli)
|
||||
|
||||
page += 1
|
||||
time.sleep(15)
|
||||
|
||||
|
||||
|
||||
def aktualizuj_dane(self):
|
||||
"""
|
||||
Pobiera mecze dla każdego sportowca wymienionego
|
||||
|
||||
@@ -67,6 +67,7 @@ def setup():
|
||||
app.add_url_rule('/mecze', view_func=lewy_routes.mecze)
|
||||
app.add_url_rule('/statystyki', view_func=lewy_routes.statystyki)
|
||||
app.add_url_rule('/toggle_dark_mode', view_func=lewy_routes.toggle_dark_mode)
|
||||
app.add_url_rule('/historia', view_func=lewy_routes.historia)
|
||||
|
||||
# API:
|
||||
app.add_url_rule('/api/', view_func=lewy_api.api_greeting)
|
||||
|
||||
@@ -105,6 +105,20 @@ def debugger_halt(r):
|
||||
breakpoint()
|
||||
return 200, "ok", []
|
||||
|
||||
def last_goal_for(sportowiec: str = "MVC8zHZD"):
|
||||
"""
|
||||
Pobierz klub, dla którego sportowiec (domyślnie Robert) oddał ostatni gol.
|
||||
|
||||
:returns: Klub, lub None
|
||||
:rtype: kluby | None
|
||||
"""
|
||||
|
||||
sportowiec = getDb().simple_select_all("sportowcy", zewnetrzne_id_zawodnika=sportowiec)
|
||||
if sportowiec != []:
|
||||
return sportowiec[0].ostatni_gol_dla
|
||||
|
||||
return None
|
||||
|
||||
def lookup(data, request):
|
||||
"""
|
||||
Obsługuje zapytania zwrócone do /api/v1/...
|
||||
|
||||
@@ -6,9 +6,22 @@ from sqlalchemy.orm import Mapped, mapped_column, DeclarativeBase, Session, rela
|
||||
from typing import List
|
||||
import time
|
||||
import toml
|
||||
import traceback
|
||||
|
||||
global db
|
||||
|
||||
class c:
|
||||
HEADER = '\033[95m'
|
||||
OKBLUE = '\033[94m'
|
||||
OKCYAN = '\033[96m'
|
||||
OKGREEN = '\033[92m'
|
||||
WARNING = '\033[93m'
|
||||
FAIL = '\033[91m'
|
||||
ENDC = '\033[0m'
|
||||
BOLD = '\033[1m'
|
||||
UNDERLINE = '\033[4m'
|
||||
ENDL = '\n'
|
||||
|
||||
class baza():
|
||||
|
||||
# global sportowcy, trofea, sportowcy_w_meczach, statystyki_sportowcow, kluby, mecze
|
||||
@@ -23,6 +36,9 @@ class baza():
|
||||
self.db = self.initDB(self.app, config)
|
||||
self.refresh_session()
|
||||
|
||||
def __repr__(self):
|
||||
return f"<Obiekt bazodanowy baza ({len(self.entities)} encji)>"
|
||||
|
||||
def initDB(self, app, config):
|
||||
global sportowcy, trofea, sportowcy_w_meczach, statystyki_sportowcow, kluby, mecze
|
||||
tnp = config['general']['db_prefix'] + "_lewangoalski_"
|
||||
@@ -106,6 +122,8 @@ class baza():
|
||||
zoltych_kartek_sum: Mapped[ int] = mapped_column()
|
||||
czerwonych_kartek_sum: Mapped[ int] = mapped_column()
|
||||
wygranych_sum: Mapped[ int] = mapped_column()
|
||||
przegranych_sum: Mapped[ int] = mapped_column()
|
||||
remisow_sum: Mapped[ int] = mapped_column()
|
||||
wynik_sum: Mapped[ int] = mapped_column()
|
||||
meczow_do_wynikow_sum: Mapped[ int] = mapped_column()
|
||||
|
||||
@@ -142,6 +160,23 @@ class baza():
|
||||
def __repr__(self):
|
||||
return f"<Mecz #{self.id_meczu} ({self.zewnetrzne_id_meczu}, {self.gospodarze.skrocona_nazwa} vs. {self.goscie.skrocona_nazwa})>"
|
||||
|
||||
def jsonify(self):
|
||||
return {
|
||||
"id_meczu": self.id_meczu,
|
||||
"zewnetrzne_id_meczu": self.zewnetrzne_id_meczu,
|
||||
"data": self.data.strftime("%Y-%m-%d"),
|
||||
"gospodarze_id": self.gospodarze_id,
|
||||
"gospodarze": self.gospodarze.skrocona_nazwa,
|
||||
"goscie_id": self.goscie_id,
|
||||
"goscie": self.goscie.skrocona_nazwa,
|
||||
"gosp_wynik": self.gosp_wynik,
|
||||
"gosc_wynik": self.gosc_wynik,
|
||||
"sezon": self.sezon,
|
||||
"nazwa_turnieju": self.nazwa_turnieju,
|
||||
"skrocona_nazwa_turnieju": self.skrocona_nazwa_turnieju,
|
||||
"flaga": self.flaga
|
||||
}
|
||||
|
||||
self.entities = {
|
||||
'sportowcy': sportowcy,
|
||||
'trofea': trofea,
|
||||
@@ -167,18 +202,42 @@ class baza():
|
||||
try:
|
||||
return_val = func(self, *args, **kwargs)
|
||||
except:
|
||||
print(f"{c.FAIL}"
|
||||
f"Wystąpił błąd podczas wykonywania zapytania SQL:"
|
||||
f"{c.ENDC}"
|
||||
"\n"
|
||||
f"{traceback.format_exc()}")
|
||||
self.session.rollback()
|
||||
self.session.close()
|
||||
self.refresh_session()
|
||||
return return_val
|
||||
return wrapper
|
||||
|
||||
def str_to_column(self, string: str):
|
||||
"""
|
||||
Zamienia tekstowy zapis "tabela.kolumna"
|
||||
na obiekt modelu bazy (ze zmiennej self.entities).
|
||||
Zwraca None jeśli takowego nie znajdzie.
|
||||
Zamiennik dla niepożądanego eval().
|
||||
|
||||
:param string: Zapis tekstowy
|
||||
:type string: str
|
||||
"""
|
||||
try:
|
||||
table_str, column_str = string.split('.')
|
||||
except:
|
||||
raise ValueError("Nieprawidłowe dane - podaj zarówno tabelę, jak i kolumnę, np.: \"kluby.id_klubu\".")
|
||||
if hasattr(self.entities[table_str], column_str):
|
||||
return getattr(self.entities[table_str], column_str)
|
||||
return None
|
||||
|
||||
@exit_gracefully
|
||||
def simple_select_all(self, entity_type, **kwargs):
|
||||
"""
|
||||
Użycie:
|
||||
simple_select_all(ldb.sportowcy, zewnetrzne_id_zawodnika="MVC8zHZD")
|
||||
simple_select_all("sportowcy", id_zawodnika=1)
|
||||
simple_select_all("kluby", ..., LIMIT=5, ORDER_BY="kluby.skrocona_nazwa")
|
||||
|
||||
https://stackoverflow.com/a/75316945
|
||||
Did they make it harder to query dynamically on purpose? ~Frank 19.11.2023
|
||||
@@ -187,16 +246,73 @@ class baza():
|
||||
if not isinstance(entity_type, str):
|
||||
entity_type = entity_type.__name__
|
||||
|
||||
print(f"[{round(time.time())}] SELECT")
|
||||
query_params, special_args = self.extract_special_args(kwargs)
|
||||
|
||||
print(f"[{round(time.time())}] SELECT {entity_type}")
|
||||
|
||||
results = (
|
||||
self.session.
|
||||
query(self.entities[entity_type]).
|
||||
filter_by(**kwargs).
|
||||
all()
|
||||
filter_by(**query_params)
|
||||
)
|
||||
|
||||
print(f"[{round(time.time())}] SELECT RESULTS: {results}")
|
||||
# Obsługuje "ORDER_BY", "LIMIT", itp. itd.
|
||||
results = self.manipulate_results(results, special_args)
|
||||
|
||||
results_objs = results.all()
|
||||
print(f"[{round(time.time())}] SELECT RESULTS: {results_objs}")
|
||||
|
||||
return results_objs
|
||||
|
||||
def extract_special_args(self, dictionary: dict):
|
||||
"""
|
||||
Zwraca krotkę składającą się ze słowników z:
|
||||
- parametrami wyszukiwania
|
||||
- specjalnymi argumentami
|
||||
|
||||
:param dictionary: Słownik wejściowy
|
||||
:type dictionary: dict
|
||||
"""
|
||||
|
||||
# Save special arguments received with kwargs,
|
||||
# that are meant for SQL operations to special_args,
|
||||
# and delete from the rest, that will be passed
|
||||
# directly to filter_by().
|
||||
# They will not be passed as search query, but serve
|
||||
# as an additional search parameter.
|
||||
dictionary = dictionary.copy()
|
||||
|
||||
special_keywords = ("ORDER_BY", "ORDER_BY_DESC", "LIMIT")
|
||||
special_args = {}
|
||||
|
||||
for arg in special_keywords:
|
||||
if arg in dictionary:
|
||||
special_args[arg] = dictionary[arg]
|
||||
del dictionary[arg]
|
||||
|
||||
return dictionary, special_args
|
||||
|
||||
def manipulate_results(self, results, special_args: dict):
|
||||
"""
|
||||
Wykonuje specjalne operacje na rezultatach wyszukiwania.
|
||||
|
||||
:param results: Wyniki wyszukiwania (ORM)
|
||||
:param special_args: Specjalne operacje
|
||||
:type special_args: dict
|
||||
"""
|
||||
|
||||
if "ORDER_BY" in special_args:
|
||||
column = self.str_to_column(special_args["ORDER_BY"])
|
||||
if column is not None:
|
||||
results = results.order_by(column)
|
||||
|
||||
if "ORDER_BY_DESC" in special_args:
|
||||
column = self.str_to_column(special_args["ORDER_BY_DESC"])
|
||||
if column is not None:
|
||||
results = results.order_by(column.desc())
|
||||
|
||||
if "LIMIT" in special_args:
|
||||
results = results.limit(special_args["LIMIT"])
|
||||
|
||||
return results
|
||||
|
||||
@@ -213,7 +329,15 @@ class baza():
|
||||
if not isinstance(entity_type, str):
|
||||
entity_type = entity_type.__name__
|
||||
|
||||
print(f"[{round(time.time())}] INSERT")
|
||||
if "id" in kwargs:
|
||||
print(f"{c.FAIL}UWAGA!{c.ENDC}")
|
||||
print(f"Próbujesz dodać obiekt do tabeli, który ma już identyfikator.\n"
|
||||
f"To spowoduje problemy w przyszłości, gdy będziesz chciał dodać nowy obiekt do bazy bez ustawiania id na sztywno\n"
|
||||
f"(id klucza głównego nie zostanie zaktualizowane w sekwencji, przez co baza będzie próbowała dodać obiekt z id już istniejącego rekordu!).\n"
|
||||
f"Aby naprawić dodawanie z autoinkrementującym kluczem zobacz {c.WARNING}https://stackoverflow.com/a/8745101{c.ENDC}\n"
|
||||
f"Zostałeś ostrzeżony!")
|
||||
|
||||
print(f"[{round(time.time())}] INSERT {entity_type}")
|
||||
|
||||
obj = self.entities[entity_type](**kwargs)
|
||||
#with Session(self.db.engine) as session:
|
||||
@@ -237,6 +361,131 @@ class baza():
|
||||
return 0
|
||||
#return 1
|
||||
|
||||
@exit_gracefully
|
||||
def increment_fields(self, entity_type, record_id, **increments):
|
||||
"""
|
||||
Dodaje wartości do istniejących pól (np. goli_sum += 2).
|
||||
|
||||
Użycie:
|
||||
increment_fields(ldb.statystyki_sportowcow, 123, goli_sum=2, asyst_sum=1)
|
||||
"""
|
||||
|
||||
if not isinstance(entity_type, str):
|
||||
entity_type = entity_type.__name__
|
||||
|
||||
if entity_type not in self.entities:
|
||||
print(f"Nieznany typ encji: {entity_type}")
|
||||
return -1
|
||||
|
||||
model_class = self.entities[entity_type]
|
||||
|
||||
print(f"[{round(time.time())}] INCREMENT {entity_type}")
|
||||
|
||||
record = self.session.get(model_class, record_id)
|
||||
if not record:
|
||||
print(f"Rekord z ID {record_id} nie istnieje w tabeli {entity_type}")
|
||||
return -1
|
||||
|
||||
for key, increment_value in increments.items():
|
||||
if hasattr(record, key):
|
||||
current_value = getattr(record, key, 0)
|
||||
setattr(record, key, current_value + increment_value)
|
||||
else:
|
||||
print(f"⚠️ Pole '{key}' nie istnieje w modelu '{entity_type}' - pomijam.")
|
||||
|
||||
self.session.commit()
|
||||
return 0
|
||||
|
||||
@exit_gracefully
|
||||
def get_id_meczu_by_zewnetrzne_id(self, external_id: str) -> int | None:
|
||||
"""
|
||||
Zwraca id_meczu na podstawie zewnetrzne_id_meczu.
|
||||
|
||||
:param external_id: zewnętrzne ID meczu
|
||||
:return: id_meczu lub None jeśli nie znaleziono
|
||||
"""
|
||||
stmt = select(mecze.id_meczu).where(mecze.zewnetrzne_id_meczu == external_id)
|
||||
result = self.session.execute(stmt).scalar_one_or_none()
|
||||
return result
|
||||
|
||||
@exit_gracefully
|
||||
def get_id_zawodnika_by_zewnetrzne_id(self, external_id: str) -> int | None:
|
||||
"""
|
||||
Zwraca id_zawodnika na podstawie zewnetrzne_id_zawodnika.
|
||||
|
||||
:param external_id: zewnętrzne ID meczu
|
||||
:return: id_zawodnika lub None jeśli nie znaleziono
|
||||
"""
|
||||
stmt = select(sportowcy.id_zawodnika).where(sportowcy.zewnetrzne_id_zawodnika == external_id)
|
||||
result = self.session.execute(stmt).scalar_one_or_none()
|
||||
return result
|
||||
|
||||
@exit_gracefully
|
||||
def simple_update_one(self, entity_type, record_id, **kwargs):
|
||||
"""
|
||||
Użycie:
|
||||
simple_update_one(ldb.kluby, "polska", pelna_nazwa="Nowa Nazwa", skrocona_nazwa="NN")
|
||||
|
||||
Aktualizuje pojedynczy rekord w bazie danych na podstawie ID.
|
||||
"""
|
||||
if not isinstance(entity_type, str):
|
||||
entity_type = entity_type.__name__
|
||||
|
||||
if entity_type not in self.entities:
|
||||
print(f"Nieznany typ encji: {entity_type}")
|
||||
return -1
|
||||
|
||||
model_class = self.entities[entity_type]
|
||||
|
||||
print(f"[{round(time.time())}] UPDATE {entity_type}")
|
||||
|
||||
record = self.session.get(model_class, record_id)
|
||||
if not record:
|
||||
print(f"Rekord z ID {record_id} nie istnieje w tabeli {entity_type}")
|
||||
return -1
|
||||
|
||||
for key, value in kwargs.items():
|
||||
if hasattr(record, key):
|
||||
setattr(record, key, value)
|
||||
else:
|
||||
print(f"⚠️ Pole '{key}' nie istnieje w modelu '{entity_type}' - pomijam.")
|
||||
|
||||
self.session.commit()
|
||||
return 0
|
||||
|
||||
@exit_gracefully
|
||||
def dodaj_sportowca_w_meczu(self, entity_type, record_id, **kwargs):
|
||||
"""
|
||||
Użycie:
|
||||
dodaj_sportowca_w_meczu(ldb.sportowcy_w_meczu, ...)
|
||||
|
||||
Dodaje pojedynczy rekord w bazie danych.
|
||||
"""
|
||||
if not isinstance(entity_type, str):
|
||||
entity_type = entity_type.__name__
|
||||
|
||||
if entity_type not in self.entities:
|
||||
print(f"Nieznany typ encji: {entity_type}")
|
||||
return -1
|
||||
|
||||
model_class = self.entities[entity_type]
|
||||
|
||||
print(f"[{round(time.time())}] INSERT {entity_type}")
|
||||
|
||||
record = self.session.get(model_class, record_id)
|
||||
if not record:
|
||||
print(f"Rekord z ID {record_id} nie istnieje w tabeli {entity_type}")
|
||||
return -1
|
||||
|
||||
for key, value in kwargs.items():
|
||||
if hasattr(record, key):
|
||||
setattr(record, key, value)
|
||||
else:
|
||||
print(f"⚠️ Pole '{key}' nie istnieje w modelu '{entity_type}' - pomijam.")
|
||||
|
||||
self.session.commit()
|
||||
return 0
|
||||
|
||||
@exit_gracefully
|
||||
def sample_data_init(self, override_safety_check=False):
|
||||
"""
|
||||
@@ -270,41 +519,48 @@ class baza():
|
||||
goscie_id="undefined",
|
||||
gosp_wynik=0,
|
||||
gosc_wynik=0,
|
||||
sezon="1970/1970",
|
||||
sezon="1970-1970",
|
||||
nazwa_turnieju="Nieznany turniej",
|
||||
skrocona_nazwa_turnieju="N/A",
|
||||
flaga=0)
|
||||
|
||||
|
||||
#Robercik
|
||||
self.simple_insert_one(statystyki_sportowcow,
|
||||
ostatni_mecz=1,
|
||||
ilosc_wystapien=0,
|
||||
minut_gry=0,
|
||||
gier_sum=0,
|
||||
goli_sum=0,
|
||||
asyst_sum=0,
|
||||
ilosc_wystapien=487,
|
||||
minut_gry=0, # Brak danych
|
||||
gier_sum=487,
|
||||
goli_sum=381,
|
||||
asyst_sum=44,
|
||||
interwencji_sum=0,
|
||||
nieobronionych_interwencji_sum=0,
|
||||
zoltych_kartek_sum=0,
|
||||
zoltych_kartek_sum=2,
|
||||
czerwonych_kartek_sum=0,
|
||||
wygranych_sum=0,
|
||||
wynik_sum=0,
|
||||
meczow_do_wynikow_sum=0)
|
||||
|
||||
wygranych_sum=0, # Brak danych
|
||||
przegranych_sum=0, # Brak danych
|
||||
remisow_sum=0, # Brak danych
|
||||
wynik_sum=0, # Brak danych
|
||||
meczow_do_wynikow_sum=0 # Brak danych
|
||||
)
|
||||
sportowiec = sportowcy(
|
||||
zewnetrzne_id_zawodnika="MVC8zHZD",
|
||||
imie="Robert",
|
||||
nazwisko="Lewandowski",
|
||||
data_urodzenia="21.08.1988",
|
||||
czy_aktywny=True,
|
||||
klub_id="undefined",
|
||||
klub_id="Barcelona",
|
||||
narodowosc="PL",
|
||||
ilosc_trofeow=0,
|
||||
ilosc_trofeow=0, # Brak danych na Flashscore
|
||||
pierwszy_mecz_id=1,
|
||||
ostatni_gol_dla_id="undefined",
|
||||
statystyki_id=1,
|
||||
wycena=64_940_000)
|
||||
wycena=67_000_000 # Wartość rynkowa: €15.3 mln
|
||||
)
|
||||
|
||||
trofeum = trofea(
|
||||
nazwa="Nieznane trofeum",
|
||||
sezon="0000/0000",
|
||||
sezon="0000-0000",
|
||||
rok=1970)
|
||||
|
||||
session.add(sportowiec)
|
||||
@@ -316,6 +572,496 @@ class baza():
|
||||
trofeum.zawodnik = sportowiec
|
||||
sportowiec.ostatnie_trofeum = trofeum
|
||||
|
||||
# MIEJSCE NA DANE KOLEJNYCH SPORTOWCÓW
|
||||
# TRZEBA ZROBIĆ TO RĘCZNIE, ZGODNIE ZE SCHEMATEM:
|
||||
# self.simple_insert_one(statystyki_sportowcow,
|
||||
# ostatni_mecz=1,
|
||||
# ilosc_wystapien=0,
|
||||
# minut_gry=0,
|
||||
# gier_sum=0,
|
||||
# goli_sum=0,
|
||||
# asyst_sum=0,
|
||||
# interwencji_sum=0,
|
||||
# nieobronionych_interwencji_sum=0,
|
||||
# zoltych_kartek_sum=0,
|
||||
# czerwonych_kartek_sum=0,
|
||||
# wygranych_sum=0,
|
||||
# przegranych_sum=0,
|
||||
# remisow_sum=0,
|
||||
# wynik_sum=0,
|
||||
# meczow_do_wynikow_sum=0)
|
||||
|
||||
# self.simple_insert_one(sportowcy,
|
||||
# zewnetrzne_id_zawodnika="...",
|
||||
# imie="...",
|
||||
# nazwisko="...",
|
||||
# data_urodzenia="...",
|
||||
# czy_aktywny=True, # NIE WSZYSCY SĄ AKTYWNI!
|
||||
# klub_id="undefined",
|
||||
# narodowosc="...",
|
||||
# ilosc_trofeow=0,
|
||||
# pierwszy_mecz_id=1,
|
||||
# ostatni_gol_dla_id="undefined",
|
||||
# statystyki_id=2, # itd...
|
||||
# wycena=...) # w złotówkach
|
||||
|
||||
#Ronaldo
|
||||
self.simple_insert_one(statystyki_sportowcow,
|
||||
ostatni_mecz=1,
|
||||
ilosc_wystapien=702,
|
||||
minut_gry=0, # Brak danych
|
||||
gier_sum=702,
|
||||
goli_sum=569,
|
||||
asyst_sum=81,
|
||||
interwencji_sum=0,
|
||||
nieobronionych_interwencji_sum=0,
|
||||
zoltych_kartek_sum=92,
|
||||
czerwonych_kartek_sum=8,
|
||||
wygranych_sum=0, # Brak danych
|
||||
przegranych_sum=0, # Brak danych
|
||||
remisow_sum=0, # Brak danych
|
||||
wynik_sum=0, # Brak danych
|
||||
meczow_do_wynikow_sum=0 # Brak danych
|
||||
)
|
||||
sportowiec = sportowcy(
|
||||
zewnetrzne_id_zawodnika="WGOY4FSt",
|
||||
imie="Cristiano",
|
||||
nazwisko="Ronaldo",
|
||||
data_urodzenia="05.02.1985",
|
||||
czy_aktywny=True,
|
||||
klub_id="Al Nassr Riyadh",
|
||||
narodowosc="PT",
|
||||
ilosc_trofeow=0, # Brak danych na Flashscore
|
||||
pierwszy_mecz_id=1,
|
||||
ostatni_gol_dla_id="undefined",
|
||||
statystyki_id=2,
|
||||
wycena=55_000_000 # Wartość rynkowa: €12.1 mln
|
||||
)
|
||||
#Messi
|
||||
self.simple_insert_one(statystyki_sportowcow,
|
||||
ostatni_mecz=1,
|
||||
ilosc_wystapien=619,
|
||||
minut_gry=0, # Brak danych o łącznym czasie gry
|
||||
gier_sum=619,
|
||||
goli_sum=528,
|
||||
asyst_sum=53,
|
||||
interwencji_sum=0,
|
||||
nieobronionych_interwencji_sum=0,
|
||||
zoltych_kartek_sum=0,
|
||||
czerwonych_kartek_sum=0,
|
||||
wygranych_sum=0, # Brak danych
|
||||
przegranych_sum=0, # Brak danych
|
||||
remisow_sum=0, # Brak danych
|
||||
wynik_sum=0, # Brak danych
|
||||
meczow_do_wynikow_sum=0 # Brak danych
|
||||
)
|
||||
sportowiec = sportowcy(
|
||||
zewnetrzne_id_zawodnika="vgOOdZbd",
|
||||
imie="Lionel",
|
||||
nazwisko="Messi",
|
||||
data_urodzenia="24.06.1987",
|
||||
czy_aktywny=True,
|
||||
klub_id="Inter Miami",
|
||||
narodowosc="AR",
|
||||
ilosc_trofeow=0, # Brak danych na Flashscore
|
||||
pierwszy_mecz_id=1,
|
||||
ostatni_gol_dla_id="undefined",
|
||||
statystyki_id=3,
|
||||
wycena=67_000_000 # Wartość rynkowa: €15.3 mln
|
||||
)
|
||||
#Mbappe
|
||||
self.simple_insert_one(statystyki_sportowcow,
|
||||
ostatni_mecz=1,
|
||||
ilosc_wystapien=280,
|
||||
minut_gry=0, # Brak danych o łącznym czasie gry
|
||||
gier_sum=280,
|
||||
goli_sum=222,
|
||||
asyst_sum=67,
|
||||
interwencji_sum=0,
|
||||
nieobronionych_interwencji_sum=0,
|
||||
zoltych_kartek_sum=38,
|
||||
czerwonych_kartek_sum=2,
|
||||
wygranych_sum=0, # Brak danych
|
||||
przegranych_sum=0, # Brak danych
|
||||
remisow_sum=0, # Brak danych
|
||||
wynik_sum=0, # Brak danych
|
||||
meczow_do_wynikow_sum=0 # Brak danych
|
||||
)
|
||||
sportowiec = sportowcy(
|
||||
zewnetrzne_id_zawodnika="Wn6E2SED",
|
||||
imie="Kylian",
|
||||
nazwisko="Mbappé",
|
||||
data_urodzenia="20.12.1998",
|
||||
czy_aktywny=True,
|
||||
klub_id="Real Madryt",
|
||||
narodowosc="FR",
|
||||
ilosc_trofeow=0, # Brak danych na Flashscore
|
||||
pierwszy_mecz_id=1,
|
||||
ostatni_gol_dla_id="undefined",
|
||||
statystyki_id=4,
|
||||
wycena=185_700_000 # Wartość rynkowa: €185.7 mln
|
||||
)
|
||||
#Zlatan
|
||||
self.simple_insert_one(statystyki_sportowcow,
|
||||
ostatni_mecz=1,
|
||||
ilosc_wystapien=519,
|
||||
minut_gry=0, # Brak danych o łącznym czasie gry
|
||||
gier_sum=519,
|
||||
goli_sum=355,
|
||||
asyst_sum=63,
|
||||
interwencji_sum=0,
|
||||
nieobronionych_interwencji_sum=0,
|
||||
zoltych_kartek_sum=87,
|
||||
czerwonych_kartek_sum=9,
|
||||
wygranych_sum=0, # Brak danych
|
||||
przegranych_sum=0, # Brak danych
|
||||
remisow_sum=0, # Brak danych
|
||||
wynik_sum=0, # Brak danych
|
||||
meczow_do_wynikow_sum=0 # Brak danych
|
||||
)
|
||||
sportowiec = sportowcy(
|
||||
zewnetrzne_id_zawodnika="AiH2zDve",
|
||||
imie="Zlatan",
|
||||
nazwisko="Ibrahimović",
|
||||
data_urodzenia="03.10.1981",
|
||||
czy_aktywny=False,
|
||||
klub_id="undefined",
|
||||
narodowosc="SE",
|
||||
ilosc_trofeow=0, # Brak danych na Flashscore
|
||||
pierwszy_mecz_id=1,
|
||||
ostatni_gol_dla_id="undefined",
|
||||
statystyki_id=5,
|
||||
wycena=0 # Zakończył karierę
|
||||
)
|
||||
#Suarez
|
||||
self.simple_insert_one(statystyki_sportowcow,
|
||||
ostatni_mecz=1,
|
||||
ilosc_wystapien=608,
|
||||
minut_gry=0, # Brak danych o łącznym czasie gry
|
||||
gier_sum=608,
|
||||
goli_sum=399,
|
||||
asyst_sum=122,
|
||||
interwencji_sum=0,
|
||||
nieobronionych_interwencji_sum=0,
|
||||
zoltych_kartek_sum=0,
|
||||
czerwonych_kartek_sum=0,
|
||||
wygranych_sum=0, # Brak danych
|
||||
przegranych_sum=0, # Brak danych
|
||||
remisow_sum=0, # Brak danych
|
||||
wynik_sum=0, # Brak danych
|
||||
meczow_do_wynikow_sum=0 # Brak danych
|
||||
)
|
||||
sportowiec = sportowcy(
|
||||
zewnetrzne_id_zawodnika="dUShzrBp",
|
||||
imie="Luis",
|
||||
nazwisko="Suárez",
|
||||
data_urodzenia="24.01.1987",
|
||||
czy_aktywny=True,
|
||||
klub_id="Inter Miami",
|
||||
narodowosc="UY",
|
||||
ilosc_trofeow=0, # Brak danych na Flashscore
|
||||
pierwszy_mecz_id=1,
|
||||
ostatni_gol_dla_id="undefined",
|
||||
statystyki_id=6,
|
||||
wycena=8_800_000 # Wartość rynkowa: €2.0 mln
|
||||
)
|
||||
#Haaland
|
||||
self.simple_insert_one(statystyki_sportowcow,
|
||||
ostatni_mecz=1,
|
||||
ilosc_wystapien=235,
|
||||
minut_gry=0, # Brak danych o łącznym czasie gry
|
||||
gier_sum=235,
|
||||
goli_sum=178,
|
||||
asyst_sum=41,
|
||||
interwencji_sum=0,
|
||||
nieobronionych_interwencji_sum=0,
|
||||
zoltych_kartek_sum=18,
|
||||
czerwonych_kartek_sum=0,
|
||||
wygranych_sum=0, # Brak danych
|
||||
przegranych_sum=0, # Brak danych
|
||||
remisow_sum=0, # Brak danych
|
||||
wynik_sum=0, # Brak danych
|
||||
meczow_do_wynikow_sum=0 # Brak danych
|
||||
)
|
||||
sportowiec = sportowcy(
|
||||
zewnetrzne_id_zawodnika="UmV9iQmE",
|
||||
imie="Erling",
|
||||
nazwisko="Haaland",
|
||||
data_urodzenia="21.07.2000",
|
||||
czy_aktywny=True,
|
||||
klub_id="Manchester City",
|
||||
narodowosc="NO",
|
||||
ilosc_trofeow=0, # Brak danych
|
||||
pierwszy_mecz_id=1,
|
||||
ostatni_gol_dla_id="undefined",
|
||||
statystyki_id=7,
|
||||
wycena=777_500_000 # ~€178.7 mln
|
||||
)
|
||||
#Karim Benzema
|
||||
self.simple_insert_one(statystyki_sportowcow,
|
||||
ostatni_mecz=1,
|
||||
ilosc_wystapien=589,
|
||||
minut_gry=0, # Brak danych
|
||||
gier_sum=589,
|
||||
goli_sum=305,
|
||||
asyst_sum=0,
|
||||
interwencji_sum=0,
|
||||
nieobronionych_interwencji_sum=0,
|
||||
zoltych_kartek_sum=14,
|
||||
czerwonych_kartek_sum=0,
|
||||
wygranych_sum=0, # Brak danych
|
||||
przegranych_sum=0,
|
||||
remisow_sum=0,
|
||||
wynik_sum=0,
|
||||
meczow_do_wynikow_sum=0
|
||||
)
|
||||
|
||||
sportowiec = sportowcy(
|
||||
zewnetrzne_id_zawodnika="tpV0VX0S",
|
||||
imie="Karim",
|
||||
nazwisko="Benzema",
|
||||
data_urodzenia="19.12.1987",
|
||||
czy_aktywny=True,
|
||||
klub_id="Al Ittihad",
|
||||
narodowosc="FR",
|
||||
ilosc_trofeow=0, # Flashscore nie podaje
|
||||
pierwszy_mecz_id=1,
|
||||
ostatni_gol_dla_id="undefined",
|
||||
statystyki_id=8,
|
||||
wycena=31_950_000 # €7.1 mln
|
||||
)
|
||||
#Sergio Aguero
|
||||
self.simple_insert_one(statystyki_sportowcow,
|
||||
ostatni_mecz=1,
|
||||
ilosc_wystapien=443,
|
||||
minut_gry=0, # Brak danych o czasie gry
|
||||
gier_sum=443,
|
||||
goli_sum=254,
|
||||
asyst_sum=38,
|
||||
interwencji_sum=0,
|
||||
nieobronionych_interwencji_sum=0,
|
||||
zoltych_kartek_sum=47,
|
||||
czerwonych_kartek_sum=2,
|
||||
wygranych_sum=0, # Brak danych
|
||||
przegranych_sum=0, # Brak danych
|
||||
remisow_sum=0, # Brak danych
|
||||
wynik_sum=0, # Brak danych
|
||||
meczow_do_wynikow_sum=0 # Brak danych
|
||||
)
|
||||
|
||||
sportowiec = sportowcy(
|
||||
zewnetrzne_id_zawodnika="vw8ZV7HC",
|
||||
imie="Sergio",
|
||||
nazwisko="Agüero",
|
||||
data_urodzenia="02.06.1988",
|
||||
czy_aktywny=False,
|
||||
klub_id="retired",
|
||||
narodowosc="AR",
|
||||
ilosc_trofeow=0, # Brak danych
|
||||
pierwszy_mecz_id=1,
|
||||
ostatni_gol_dla_id="undefined",
|
||||
statystyki_id=9,
|
||||
wycena=0 # Zakończył karierę
|
||||
)
|
||||
#Edinson Cavani
|
||||
self.simple_insert_one(statystyki_sportowcow,
|
||||
ostatni_mecz=1,
|
||||
ilosc_wystapien=507,
|
||||
minut_gry=0, # Brak danych o czasie gry
|
||||
gier_sum=507,
|
||||
goli_sum=273,
|
||||
asyst_sum=62,
|
||||
interwencji_sum=0,
|
||||
nieobronionych_interwencji_sum=0,
|
||||
zoltych_kartek_sum=3,
|
||||
czerwonych_kartek_sum=0,
|
||||
wygranych_sum=0, # Brak danych
|
||||
przegranych_sum=0, # Brak danych
|
||||
remisow_sum=0, # Brak danych
|
||||
wynik_sum=0, # Brak danych
|
||||
meczow_do_wynikow_sum=0 # Brak danych
|
||||
)
|
||||
|
||||
sportowiec = sportowcy(
|
||||
zewnetrzne_id_zawodnika="Qgx2trzH",
|
||||
imie="Edinson",
|
||||
nazwisko="Cavani",
|
||||
data_urodzenia="14.02.1987",
|
||||
czy_aktywny=True,
|
||||
klub_id="Boca Juniors",
|
||||
narodowosc="UY",
|
||||
ilosc_trofeow=0,
|
||||
pierwszy_mecz_id=1,
|
||||
ostatni_gol_dla_id="undefined",
|
||||
statystyki_id=10,
|
||||
wycena=4_212_000 # PLN
|
||||
)
|
||||
#Radamel Falcao
|
||||
self.simple_insert_one(statystyki_sportowcow,
|
||||
ostatni_mecz=1,
|
||||
ilosc_wystapien=360,
|
||||
minut_gry=0, # brak danych o czasie gry
|
||||
gier_sum=360,
|
||||
goli_sum=170,
|
||||
asyst_sum=17,
|
||||
interwencji_sum=54,
|
||||
nieobronionych_interwencji_sum=1,
|
||||
zoltych_kartek_sum=0, # brak danych
|
||||
czerwonych_kartek_sum=0,
|
||||
wygranych_sum=0,
|
||||
przegranych_sum=0,
|
||||
remisow_sum=0,
|
||||
wynik_sum=0,
|
||||
meczow_do_wynikow_sum=0
|
||||
)
|
||||
sportowiec = sportowcy(
|
||||
zewnetrzne_id_zawodnika="2oMimkAU",
|
||||
imie="Radamel",
|
||||
nazwisko="Falcao",
|
||||
data_urodzenia="10.02.1986",
|
||||
czy_aktywny=True,
|
||||
klub_id="Millonarios",
|
||||
narodowosc="CO",
|
||||
ilosc_trofeow=0, # brak danych
|
||||
pierwszy_mecz_id=1,
|
||||
ostatni_gol_dla_id="undefined",
|
||||
statystyki_id=11,
|
||||
wycena=1_084_500 #PLN
|
||||
)
|
||||
#Wayne Rooney
|
||||
self.simple_insert_one(statystyki_sportowcow,
|
||||
ostatni_mecz=1,
|
||||
ilosc_wystapien=568,
|
||||
minut_gry=0, # brak danych o czasie gry
|
||||
gier_sum=568,
|
||||
goli_sum=234,
|
||||
asyst_sum=47,
|
||||
interwencji_sum=0, # brak danych
|
||||
nieobronionych_interwencji_sum=0, # brak danych
|
||||
zoltych_kartek_sum=105,
|
||||
czerwonych_kartek_sum=4,
|
||||
wygranych_sum=0, # brak danych
|
||||
przegranych_sum=0,
|
||||
remisow_sum=0,
|
||||
wynik_sum=0,
|
||||
meczow_do_wynikow_sum=0
|
||||
)
|
||||
sportowiec = sportowcy(
|
||||
zewnetrzne_id_zawodnika="WfXv1DCa",
|
||||
imie="Wayne",
|
||||
nazwisko="Rooney",
|
||||
data_urodzenia="24.10.1985",
|
||||
czy_aktywny=False, # zakończył karierę
|
||||
klub_id="undefined",
|
||||
narodowosc="ENG",
|
||||
ilosc_trofeow=0, # brak danych
|
||||
pierwszy_mecz_id=1,
|
||||
ostatni_gol_dla_id="undefined",
|
||||
statystyki_id=12,
|
||||
wycena=0 # brak wyceny
|
||||
)
|
||||
#Robin van Persie
|
||||
self.simple_insert_one(statystyki_sportowcow,
|
||||
ostatni_mecz=1,
|
||||
ilosc_wystapien=374,
|
||||
minut_gry=0, # brak danych o czasie gry
|
||||
gier_sum=374,
|
||||
goli_sum=190,
|
||||
asyst_sum=16,
|
||||
interwencji_sum=0, # brak danych
|
||||
nieobronionych_interwencji_sum=0, # brak danych
|
||||
zoltych_kartek_sum=54,
|
||||
czerwonych_kartek_sum=3,
|
||||
wygranych_sum=0, # brak danych
|
||||
przegranych_sum=0,
|
||||
remisow_sum=0,
|
||||
wynik_sum=0,
|
||||
meczow_do_wynikow_sum=0
|
||||
)
|
||||
sportowiec = sportowcy(
|
||||
zewnetrzne_id_zawodnika="0vgcq6un",
|
||||
imie="Robin",
|
||||
nazwisko="van Persie",
|
||||
data_urodzenia="06.08.1983",
|
||||
czy_aktywny=False,
|
||||
klub_id="undefined", # zakończył karierę
|
||||
narodowosc="NED",
|
||||
ilosc_trofeow=0, # brak danych
|
||||
pierwszy_mecz_id=1,
|
||||
ostatni_gol_dla_id="undefined",
|
||||
statystyki_id=13,
|
||||
wycena=0 # zakończył karierę
|
||||
)
|
||||
#Harry Kane
|
||||
self.simple_insert_one(statystyki_sportowcow,
|
||||
ostatni_mecz=1,
|
||||
ilosc_wystapien=439,
|
||||
minut_gry=0, # brak danych o czasie gry
|
||||
gier_sum=439,
|
||||
goli_sum=295,
|
||||
asyst_sum=64,
|
||||
interwencji_sum=0, # brak danych
|
||||
nieobronionych_interwencji_sum=0,
|
||||
zoltych_kartek_sum=48,
|
||||
czerwonych_kartek_sum=1,
|
||||
wygranych_sum=0, # brak danych
|
||||
przegranych_sum=0,
|
||||
remisow_sum=0,
|
||||
wynik_sum=0,
|
||||
meczow_do_wynikow_sum=0
|
||||
)
|
||||
sportowiec = sportowcy(
|
||||
zewnetrzne_id_zawodnika="v5HSlEAa",
|
||||
imie="Harry",
|
||||
nazwisko="Kane",
|
||||
data_urodzenia="28.07.1993",
|
||||
czy_aktywny=True,
|
||||
klub_id="Bayern Monachium",
|
||||
narodowosc="ENG",
|
||||
ilosc_trofeow=0, # brak danych
|
||||
pierwszy_mecz_id=1,
|
||||
ostatni_gol_dla_id="undefined",
|
||||
statystyki_id=14,
|
||||
wycena=344_700_000 # PLN
|
||||
)
|
||||
#Ciro Immobile
|
||||
self.simple_insert_one(statystyki_sportowcow,
|
||||
ostatni_mecz=1,
|
||||
ilosc_wystapien=455,
|
||||
minut_gry=0, # brak danych o czasie gry
|
||||
gier_sum=455,
|
||||
goli_sum=250,
|
||||
asyst_sum=51,
|
||||
interwencji_sum=0, # brak danych
|
||||
nieobronionych_interwencji_sum=0,
|
||||
zoltych_kartek_sum=71,
|
||||
czerwonych_kartek_sum=3,
|
||||
wygranych_sum=0,
|
||||
przegranych_sum=0,
|
||||
remisow_sum=0,
|
||||
wynik_sum=0,
|
||||
meczow_do_wynikow_sum=0
|
||||
)
|
||||
sportowiec = sportowcy(
|
||||
zewnetrzne_id_zawodnika="4S9fNUYh",
|
||||
imie="Ciro",
|
||||
nazwisko="Immobile",
|
||||
data_urodzenia="20.02.1990",
|
||||
czy_aktywny=True,
|
||||
klub_id="Besiktas",
|
||||
narodowosc="IT",
|
||||
ilosc_trofeow=0, # brak danych
|
||||
pierwszy_mecz_id=1,
|
||||
ostatni_gol_dla_id="undefined",
|
||||
statystyki_id=15,
|
||||
wycena=12_600_000 # PLN
|
||||
)
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
session.commit()
|
||||
return 0
|
||||
|
||||
return 1
|
||||
@@ -1,8 +1,13 @@
|
||||
from flask import render_template, request, make_response
|
||||
import lewy_api_v1
|
||||
import lewy_db
|
||||
import lewy_globals
|
||||
|
||||
def index():
|
||||
dark_mode = request.cookies.get('darkMode', 'disabled')
|
||||
# Przykładowe użycie endpointu last_goal_for():
|
||||
# roberts_last_goals_club = lewy_api_v1.last_goal_for()
|
||||
# print(roberts_last_goals_club.id_klubu)
|
||||
stats = {
|
||||
'goals': 38,
|
||||
'assists': 12,
|
||||
@@ -34,6 +39,14 @@ def statystyki():
|
||||
}
|
||||
return render_template('stats.html', stats=stats)
|
||||
|
||||
def historia():
|
||||
selected_club = request.args.get("club","FC Barcelona")
|
||||
history = [
|
||||
{'club': 'FC Barcelona', 'goals': 22},
|
||||
{'club': 'Bayern Monachium', 'goals': 132},
|
||||
]
|
||||
return render_template('history.html', history=history, selected_club=selected_club)
|
||||
|
||||
def toggle_dark_mode():
|
||||
# Przełącz tryb i zapisz w ciasteczku
|
||||
dark_mode = request.cookies.get('darkMode', 'disabled')
|
||||
|
||||
BIN
FlaskWebProject/FlaskWebProject/static/Borussia_Dortmund.png
Normal file
BIN
FlaskWebProject/FlaskWebProject/static/Borussia_Dortmund.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 165 KiB |
BIN
FlaskWebProject/FlaskWebProject/static/FC_Barcelona.png
Normal file
BIN
FlaskWebProject/FlaskWebProject/static/FC_Barcelona.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 206 KiB |
BIN
FlaskWebProject/FlaskWebProject/static/FC_Bayern.png
Normal file
BIN
FlaskWebProject/FlaskWebProject/static/FC_Bayern.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 186 KiB |
BIN
FlaskWebProject/FlaskWebProject/static/Lech_Poznan.png
Normal file
BIN
FlaskWebProject/FlaskWebProject/static/Lech_Poznan.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 15 KiB |
BIN
FlaskWebProject/FlaskWebProject/static/fonts/Exo2-ExtraBold.ttf
Normal file
BIN
FlaskWebProject/FlaskWebProject/static/fonts/Exo2-ExtraBold.ttf
Normal file
Binary file not shown.
BIN
FlaskWebProject/FlaskWebProject/static/fonts/Exo2-SemiBold.ttf
Normal file
BIN
FlaskWebProject/FlaskWebProject/static/fonts/Exo2-SemiBold.ttf
Normal file
Binary file not shown.
BIN
FlaskWebProject/FlaskWebProject/static/gigabuła.png
Normal file
BIN
FlaskWebProject/FlaskWebProject/static/gigabuła.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 244 KiB |
BIN
FlaskWebProject/FlaskWebProject/static/lewandowski_no_bg.png
Normal file
BIN
FlaskWebProject/FlaskWebProject/static/lewandowski_no_bg.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 351 KiB |
@@ -1,127 +1,463 @@
|
||||
* {
|
||||
box-sizing: border-box;
|
||||
}
|
||||
|
||||
@font-face {
|
||||
font-family: 'Exo2SemiBold';
|
||||
src: url('fonts/Exo2-SemiBold.ttf') format('truetype');
|
||||
font-weight: normal;
|
||||
font-style: normal;
|
||||
}
|
||||
|
||||
@font-face {
|
||||
font-family: 'Exo2ExtraBold';
|
||||
src: url('fonts/Exo2-ExtraBold.ttf') format('truetype');
|
||||
font-weight: normal;
|
||||
font-style: normal;
|
||||
}
|
||||
|
||||
:root {
|
||||
--barca-blue: #002147;
|
||||
--barca-red: #A50044;
|
||||
--barca-gold: #FDB913;
|
||||
--barca-blue: #002147;
|
||||
--barca-red: #A50044;
|
||||
--barca-gold: #FDB913;
|
||||
--polska-red-dark: #DC143C;
|
||||
--polska-red: #E30B17;
|
||||
--polska-white: #FFFFFF;
|
||||
--polska-red: #E30B17;
|
||||
--polska-white: #FFFFFF;
|
||||
|
||||
--polska-section-color: #05204A;
|
||||
--section-color: #051839;
|
||||
--pink-highlight: #E1317E;
|
||||
--blue-highlight: #00B9BF;
|
||||
--yellow-highlight: #FFD23F;
|
||||
--border-radius: 5px;
|
||||
}
|
||||
|
||||
/* Podstawowy styl */
|
||||
body {
|
||||
font-family: 'Segoe UI', sans-serif;
|
||||
font-family: 'Exo2ExtraBold', sans-serif;
|
||||
margin: 0;
|
||||
padding: 0;
|
||||
background: white;
|
||||
color: #222;
|
||||
background-color: var(--section-color);
|
||||
color: black;
|
||||
transition: all 0s ease;
|
||||
display: flex;
|
||||
flex-direction: column;
|
||||
align-items: stretch; /* Wyśrodkowanie elementów w poziomie */
|
||||
justify-content: flex-start; /* Ustalamy początek na górze */
|
||||
align-items: stretch;
|
||||
/* Wyśrodkowanie elementów w poziomie */
|
||||
justify-content: flex-start;
|
||||
/* Ustalamy początek na górze */
|
||||
min-height: 100vh;
|
||||
}
|
||||
|
||||
/* Header */
|
||||
.header-content {
|
||||
width: 100%;
|
||||
display: flex;
|
||||
justify-content: center;
|
||||
align-items: center;
|
||||
padding: 20px 0;
|
||||
background: var(--section-color);
|
||||
color: white;
|
||||
font-size: 15px;
|
||||
z-index: -2;
|
||||
position: relative;
|
||||
/* box-shadow: 0px -5px 10px 2px rgba(0, 0, 0, 0.347); */
|
||||
}
|
||||
|
||||
|
||||
.header-content h1 {
|
||||
border-bottom: 10px solid var(--barca-red);
|
||||
border-radius: 10px;
|
||||
padding: 5px;
|
||||
animation: header-content 500ms ease;
|
||||
transform: skewX(-5deg);
|
||||
}
|
||||
|
||||
.header-content-special {
|
||||
font-size: 50px;
|
||||
color: var(--barca-gold);
|
||||
}
|
||||
|
||||
.profile-image {
|
||||
width: 40%;
|
||||
padding: 20px;
|
||||
position: relative;
|
||||
}
|
||||
|
||||
.profile-image-cover {
|
||||
background: linear-gradient(185deg, transparent 40% 60%, var(--section-color) 85%, var(--section-color) 90%);
|
||||
position: absolute;
|
||||
width: 100%;
|
||||
height: 100%;
|
||||
left: 0;
|
||||
top: 0;
|
||||
}
|
||||
|
||||
.profile-image img {
|
||||
width: 100%;
|
||||
max-width: 600px;
|
||||
animation: header-content 400ms ease;
|
||||
background: linear-gradient(90deg, var(--barca-blue) 50%, var(--barca-red) 50% 100%);
|
||||
border-radius: var(--border-radius);
|
||||
transform: skewX(2deg) skewY(0deg);
|
||||
}
|
||||
|
||||
@keyframes header-content {
|
||||
0% {
|
||||
opacity: 00%;
|
||||
transform: skewX(30deg);
|
||||
}
|
||||
|
||||
100% {
|
||||
opacity: 100%;
|
||||
}
|
||||
}
|
||||
|
||||
header button {
|
||||
border: none;
|
||||
font-size: 16px;
|
||||
cursor: pointer;
|
||||
width: 100%;
|
||||
height: 100%;
|
||||
border-radius: var(--border-radius);
|
||||
}
|
||||
|
||||
|
||||
/* Styl nawigacji */
|
||||
.navbar {
|
||||
background: linear-gradient(to right, #002147, #A50044);
|
||||
|
||||
background: linear-gradient(to right,#002147,#A50044);
|
||||
color: white;
|
||||
padding: 1rem 1rem;
|
||||
padding: 2.3rem 1rem;
|
||||
height: 1.5rem;
|
||||
position: sticky;
|
||||
top: 0;
|
||||
left: 0;
|
||||
width: 100% - 2rem;
|
||||
width: 100%;
|
||||
z-index: 999;
|
||||
display: flex;
|
||||
justify-content: space-between;
|
||||
justify-content: space-around;
|
||||
align-items: center;
|
||||
box-shadow: 0 4px 10px rgba(0, 0, 0, 0.3);
|
||||
}
|
||||
|
||||
.navbar ul {
|
||||
display: flex;
|
||||
align-items: center;
|
||||
box-shadow: 0 4px 10px rgba(0, 0, 0, 0.3);
|
||||
}
|
||||
|
||||
.logo {
|
||||
font-size: 1.5rem;
|
||||
font-weight: bold;
|
||||
color: var(--barca-gold);
|
||||
display: flex;
|
||||
align-items: center;
|
||||
}
|
||||
|
||||
.logo-text {
|
||||
font-size: 1.5rem;
|
||||
font-weight: bold;
|
||||
color: var(--barca-gold);
|
||||
}
|
||||
|
||||
.logo-icon {
|
||||
font-size: 2.8em;
|
||||
}
|
||||
|
||||
.logo-link {
|
||||
text-decoration: none;
|
||||
}
|
||||
|
||||
.nav-links {
|
||||
display: flex;
|
||||
gap: 0rem;
|
||||
list-style: none;
|
||||
display: flex;
|
||||
gap: 0rem;
|
||||
list-style: none;
|
||||
height: 100%;
|
||||
}
|
||||
|
||||
.nav-links li a{
|
||||
background-color: rgba(255, 255, 255, 0.05);
|
||||
padding: 1rem 1.25rem; /* dopasowane do .navbar padding */
|
||||
height: 100%;
|
||||
border-radius: 0;
|
||||
color: var(--barca-gold);
|
||||
text-decoration: none;
|
||||
font-weight: 500;
|
||||
border: none;
|
||||
cursor: pointer;
|
||||
transition: 0.3s ease;
|
||||
align-items: center;
|
||||
.nav-links li a {
|
||||
display: block;
|
||||
color: white;
|
||||
/* dopasowane do .navbar padding */
|
||||
font-weight: 500;
|
||||
border: none;
|
||||
cursor: pointer;
|
||||
align-items: center;
|
||||
text-decoration: none;
|
||||
border-radius: var(--border-radius);
|
||||
padding: 10px 20px;
|
||||
height: 100%;
|
||||
transition: 100ms ease;
|
||||
position: relative;
|
||||
}
|
||||
li button{
|
||||
background-color: rgba(255, 255, 255, 0.05);
|
||||
|
||||
.nav-links li a::before {
|
||||
display: flex;
|
||||
justify-content: center;
|
||||
position: absolute;
|
||||
bottom: 0;
|
||||
left: 0;
|
||||
width: 100%;
|
||||
height: 100%;
|
||||
opacity: 0%;
|
||||
font-size: 25px;
|
||||
transition: 100ms ease;
|
||||
}
|
||||
|
||||
.nav-links li:hover a::before {
|
||||
opacity: 100%;
|
||||
transform: translateY(-20px);
|
||||
}
|
||||
|
||||
.nav-links li:nth-child(1) a::before {
|
||||
content: "🏠";
|
||||
}
|
||||
|
||||
.nav-links li:nth-child(2) a::before {
|
||||
content: "📅";
|
||||
}
|
||||
|
||||
.nav-links li:nth-child(3) a::before {
|
||||
content: "📊";
|
||||
}
|
||||
|
||||
.nav-links li:nth-child(4) a::before {
|
||||
content: "🏆";
|
||||
}
|
||||
|
||||
.nav-links li {
|
||||
display: block;
|
||||
}
|
||||
|
||||
.nav-links li:has(button) {
|
||||
padding: 20px;
|
||||
}
|
||||
|
||||
.nav-links li button {
|
||||
width: 1.5em;
|
||||
height: 1.5em;
|
||||
padding: 20px;
|
||||
font-size: 30px;
|
||||
border-radius: 50%;
|
||||
padding: 0;
|
||||
margin: 0;
|
||||
background-color: var(--bg-color);
|
||||
border: none;
|
||||
}
|
||||
|
||||
.nav-links li a:hover,
|
||||
.nav-links li button {
|
||||
background-color: var(--barca-blue);
|
||||
position: relative;
|
||||
overflow: hidden;
|
||||
box-shadow: 0px 0px 6px 1px #FDB913;
|
||||
transition: 100ms ease;
|
||||
}
|
||||
|
||||
.nav-links li button:hover {
|
||||
background-color: var(--barca-gold, #FDB913);
|
||||
color: var(--barca-blue, #002147);
|
||||
transform: scale(1.1, 1.1);
|
||||
}
|
||||
|
||||
.nav-links li button::after {
|
||||
content: "";
|
||||
display: block;
|
||||
position: absolute;
|
||||
top: 0;
|
||||
right: -1px;
|
||||
background-color: var(--barca-red);
|
||||
width: 50%;
|
||||
height: 100%;
|
||||
}
|
||||
|
||||
.nav-links li button::before {
|
||||
content: "";
|
||||
background: url('FC_Barcelona.png');
|
||||
background-size: contain;
|
||||
z-index: 1;
|
||||
display: block;
|
||||
position: absolute;
|
||||
top: 5px;
|
||||
left: 5px;
|
||||
width: 80%;
|
||||
height: 80%;
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
.nav-links a:hover {
|
||||
background-color: var(--barca-gold, #FDB913);
|
||||
color: var(--barca-blue, #002147);
|
||||
}
|
||||
|
||||
.hamburger {
|
||||
display: none;
|
||||
font-size: 2rem;
|
||||
color: var(--barca-gold);
|
||||
cursor: pointer;
|
||||
display: none;
|
||||
font-size: 2rem;
|
||||
color: var(--barca-gold);
|
||||
cursor: pointer;
|
||||
}
|
||||
|
||||
@media (max-width: 768px) {
|
||||
.nav-links {
|
||||
display: none;
|
||||
flex-direction: column;
|
||||
background-color: #002147;
|
||||
position: absolute;
|
||||
top: 2.5rem;
|
||||
right: 0rem;
|
||||
padding: 0rem;
|
||||
gap: 0;
|
||||
width: 200px;
|
||||
}
|
||||
.nav-links li {
|
||||
width: 100%;
|
||||
.nav-links {
|
||||
display: none;
|
||||
flex-direction: column;
|
||||
background-color: var(--barca-blue);
|
||||
position: absolute;
|
||||
top: 2.5rem;
|
||||
right: 0rem;
|
||||
padding: 0rem;
|
||||
gap: 0;
|
||||
width: 200px;
|
||||
}
|
||||
|
||||
.nav-links li {
|
||||
width: 100%;
|
||||
}
|
||||
|
||||
.nav-links li a,
|
||||
.nav-links li button {
|
||||
display: block;
|
||||
width: 100%;
|
||||
text-align: left;
|
||||
padding: 1rem;
|
||||
margin: 0;
|
||||
border-radius: 0;
|
||||
/* brak zaokrągleń w mobilnym menu */
|
||||
}
|
||||
|
||||
.nav-links.show {
|
||||
display: flex;
|
||||
}
|
||||
|
||||
.hamburger {
|
||||
display: block;
|
||||
}
|
||||
}
|
||||
|
||||
.nav-links li a,
|
||||
.nav-links li button {
|
||||
display: block;
|
||||
width: 100%;
|
||||
text-align: left;
|
||||
padding: 1rem;
|
||||
margin: 0;
|
||||
border-radius: 0; /* brak zaokrągleń w mobilnym menu */
|
||||
}
|
||||
|
||||
.nav-links.show {
|
||||
display: flex;
|
||||
}
|
||||
|
||||
.hamburger {
|
||||
display: block;
|
||||
}
|
||||
}
|
||||
|
||||
/* Wyśrodkowanie głównej zawartości */
|
||||
main {
|
||||
padding: 0px; /* Maksymalna szerokość treści */
|
||||
text-align: center; /* Wyśrodkowanie tekstu */
|
||||
display: flex;
|
||||
align-items: center;
|
||||
flex-direction: column;
|
||||
}
|
||||
|
||||
.main-index {
|
||||
border-radius: var(--border-radius);
|
||||
margin-top: 20px;
|
||||
padding: 20px;
|
||||
width: 80%;
|
||||
max-width: 1200px;
|
||||
background-color: rgba(255, 255, 255, 0.086);
|
||||
color: white;
|
||||
}
|
||||
|
||||
.about-section {
|
||||
border-radius: var(--border-radius);
|
||||
background-color: var(--barca-blue);
|
||||
padding: 20px;
|
||||
color: white;
|
||||
display: grid;
|
||||
grid-template-columns: 1fr 1fr;
|
||||
grid-gap: 20px;
|
||||
grid-template-areas:
|
||||
"how how"
|
||||
"- about-section-image"
|
||||
"- about-section-image"
|
||||
"- about-section-image";
|
||||
}
|
||||
|
||||
.about-section article h3 {
|
||||
background-color: var(--barca-gold);
|
||||
color: black;
|
||||
text-align: center;
|
||||
border-radius: var(--border-radius);
|
||||
padding: 10px;
|
||||
}
|
||||
|
||||
.about-section article h4 {
|
||||
background-color: #00B9BF;
|
||||
width: fit-content;
|
||||
padding: 10px;
|
||||
color: black;
|
||||
border-radius: (--border-radius)
|
||||
}
|
||||
|
||||
.article__how-it-works {
|
||||
grid-area: how;
|
||||
}
|
||||
|
||||
.about-section article a {
|
||||
display: block;
|
||||
width: 100%;
|
||||
color: var(--barca-gold);
|
||||
text-align: center;
|
||||
}
|
||||
|
||||
.about-section-image {
|
||||
grid-area: about-section-image;
|
||||
z-index: 0;
|
||||
position: relative;
|
||||
}
|
||||
|
||||
.about-section-image::after {
|
||||
content: "";
|
||||
display: block;
|
||||
position: absolute;
|
||||
right: 0;
|
||||
bottom: 0;
|
||||
width: 90%;
|
||||
height: 90%;
|
||||
|
||||
z-index: -1;
|
||||
background-color: #051839;
|
||||
border-radius: 20px;
|
||||
}
|
||||
|
||||
.about-section-image img {
|
||||
width: 100%;
|
||||
z-index: 3;
|
||||
}
|
||||
|
||||
.general-stats-section {
|
||||
border-radius: var(--border-radius);
|
||||
display: flex;
|
||||
flex-direction: column;
|
||||
align-items: center;
|
||||
}
|
||||
|
||||
.general-stats-section h2 {
|
||||
width: 100%;
|
||||
background-color: #002147;
|
||||
padding: 20px;
|
||||
text-align: center;
|
||||
|
||||
}
|
||||
|
||||
.general-stats-section .grid {
|
||||
display: grid;
|
||||
grid-template-columns: 1fr 1fr 1fr;
|
||||
height: 150px;
|
||||
gap: 20px;
|
||||
width: 100%;
|
||||
}
|
||||
|
||||
.general-stats-section .grid article {
|
||||
display: flex;
|
||||
justify-content: center;
|
||||
align-items: center;
|
||||
flex-direction: column;
|
||||
width: 100%;
|
||||
font-size: 1.3em;
|
||||
}
|
||||
.general-stats-section .grid article:nth-child(1){background-color: var(--blue-highlight);}
|
||||
.general-stats-section .grid article:nth-child(2){background-color: var(--yellow-highlight);}
|
||||
.general-stats-section .grid article:nth-child(3){background-color: var(--pink-highlight);}
|
||||
.general-stats-section .grid p
|
||||
{
|
||||
font-size: 40px;
|
||||
}
|
||||
.general-stats-section .grid h3, .general-stats-section .grid p
|
||||
{
|
||||
margin: 0;
|
||||
padding: 0;
|
||||
}
|
||||
|
||||
/* Styl dla tabeli */
|
||||
@@ -131,7 +467,8 @@ table {
|
||||
margin-top: 20px;
|
||||
}
|
||||
|
||||
th, td {
|
||||
th,
|
||||
td {
|
||||
padding: 10px;
|
||||
border-bottom: 1px solid #ccc;
|
||||
text-align: center;
|
||||
@@ -143,102 +480,224 @@ th, td {
|
||||
height: 100px;
|
||||
border-radius: 50%;
|
||||
display: block;
|
||||
margin: 0 auto; /* Wyśrodkowanie obrazka */
|
||||
margin: 0 auto;
|
||||
/* Wyśrodkowanie obrazka */
|
||||
}
|
||||
|
||||
.section__matches
|
||||
{
|
||||
background-color: white;
|
||||
width: 80%;
|
||||
border-radius: var(--border-radius);
|
||||
max-width: 1000px;
|
||||
}
|
||||
.section__matches h2
|
||||
{
|
||||
margin: 0;
|
||||
border-radius: var(--border-radius);
|
||||
background-color: var(--barca-gold);
|
||||
padding: 20px;
|
||||
text-align: center;
|
||||
}
|
||||
.section__matches td:nth-child(1)
|
||||
{
|
||||
border-radius: 25px 0 0px 25px;
|
||||
}
|
||||
|
||||
.section__matches td:last-child
|
||||
{
|
||||
border-radius: 0 25px 25px 0;
|
||||
}
|
||||
.section__matches th
|
||||
{
|
||||
font-size: 1.3em;
|
||||
color: var(--barca-red)
|
||||
}
|
||||
.section__matches tr
|
||||
{
|
||||
transition: 100ms ease;
|
||||
}
|
||||
.section__matches tr:hover:has(:not(th))
|
||||
{
|
||||
transform: scale(1.05,1.05);
|
||||
background-color: #00B9BF;
|
||||
}
|
||||
|
||||
/* Styl dla trybu polskiego */
|
||||
body.poland-mode .navbar {
|
||||
background: linear-gradient(to bottom,#bd4148,#dc1414);
|
||||
body.poland-mode {
|
||||
background-color: var(--polska-section-color);
|
||||
}
|
||||
|
||||
body.poland-mode .logo{
|
||||
body.poland-mode .navbar {
|
||||
background: linear-gradient(to bottom, #bd4148, #dc1414);
|
||||
}
|
||||
|
||||
body.poland-mode .logo {
|
||||
color: var(--polska-white)
|
||||
}
|
||||
body.poland-mode .nav-links li a{
|
||||
|
||||
body.poland-mode .logo-text {
|
||||
color: white;
|
||||
}
|
||||
body.poland-mode .nav-links li button:hover,
|
||||
body.poland-mode .nav-links li a:hover{
|
||||
background-color: #e96161;
|
||||
color:#220000
|
||||
}
|
||||
body.poland-mode .hamburger{
|
||||
color: white;
|
||||
}
|
||||
@media (max-width: 768px) {
|
||||
body.poland-mode .nav-links {
|
||||
background-color: var(--polska-red);/*Ale oczopląs*/
|
||||
}
|
||||
}
|
||||
body.poland-mode .section-stats{
|
||||
background: linear-gradient(to bottom,#bd4148,#dc1414);
|
||||
}
|
||||
body.poland-mode .section-stats h2{
|
||||
color:#220000
|
||||
}
|
||||
body.poland-mode .stat-box{
|
||||
border-color: white;
|
||||
}
|
||||
body.poland-mode .stat-box h3{
|
||||
color: white;
|
||||
}
|
||||
/* Przyciski i elementy */
|
||||
header button {
|
||||
padding: 10px 15px;
|
||||
border: none;
|
||||
background-color: #007bff;
|
||||
color: white;
|
||||
font-size: 16px;
|
||||
cursor: pointer;
|
||||
border-radius: 5px;
|
||||
transition: background-color 0.3s;
|
||||
}
|
||||
|
||||
header button:hover {
|
||||
background-color: #0056b3;
|
||||
body.poland-mode .nav-links li a {
|
||||
color: white;
|
||||
}
|
||||
|
||||
|
||||
body.poland-mode .nav-links li a:hover {
|
||||
color: #220000;
|
||||
background-color: white;
|
||||
}
|
||||
|
||||
body.poland-mode .nav-links li button::before {
|
||||
background: none;
|
||||
}
|
||||
|
||||
body.poland-mode .nav-links li button {
|
||||
background-color: red;
|
||||
box-shadow: 0px 0px 6px 5px rgba(109, 0, 0, 0.219);
|
||||
position: relative;
|
||||
overflow: hidden;
|
||||
}
|
||||
|
||||
body.poland-mode .nav-links li button::after {
|
||||
content: "";
|
||||
display: block;
|
||||
position: absolute;
|
||||
top: 0;
|
||||
left: 0;
|
||||
background-color: white;
|
||||
width: 100%;
|
||||
height: 50%;
|
||||
}
|
||||
|
||||
body.poland-mode .profile-image img {
|
||||
width: 100%;
|
||||
animation: header-content 300ms ease;
|
||||
background: linear-gradient(rgba(255, 255, 255, 0.534) 50%, rgba(255, 0, 0, 0.551) 50% 100%);
|
||||
border-radius: var(--border-radius);
|
||||
}
|
||||
|
||||
body.poland-mode .header-content-special {
|
||||
font-size: 50px;
|
||||
color: red;
|
||||
}
|
||||
|
||||
body.poland-mode .header-content {
|
||||
background-color: var(--polska-section-color)
|
||||
}
|
||||
|
||||
body.poland-mode .header-content h1 {
|
||||
border-bottom-color: red;
|
||||
}
|
||||
|
||||
body.poland-mode .profile-image-cover {
|
||||
background: linear-gradient(185deg, transparent 40% 60%, var(--polska-section-color) 85%, var(--polska-section-color) 90%);
|
||||
position: absolute;
|
||||
width: 100%;
|
||||
height: 100%;
|
||||
left: 0;
|
||||
top: 0;
|
||||
}
|
||||
|
||||
|
||||
body.poland-mode .hamburger {
|
||||
color: white;
|
||||
}
|
||||
|
||||
@media (max-width: 768px) {
|
||||
body.poland-mode .nav-links {
|
||||
background-color: var(--polska-red);
|
||||
/*Ale oczopląs*/
|
||||
}
|
||||
}
|
||||
|
||||
body.poland-mode .section-stats {
|
||||
background: linear-gradient(to bottom, #bd4148, #dc1414);
|
||||
}
|
||||
|
||||
body.poland-mode .section-stats h2 {
|
||||
color: #220000
|
||||
}
|
||||
|
||||
body.poland-mode .stat-box {
|
||||
border-color: white;
|
||||
}
|
||||
|
||||
body.poland-mode .stat-box h3 {
|
||||
color: white;
|
||||
}
|
||||
|
||||
/* Przyciski i elementy */
|
||||
|
||||
|
||||
/* Style dla listy meczów */
|
||||
.section-stats {
|
||||
background: linear-gradient(135deg, #002147, #A50044);
|
||||
color: white;
|
||||
border-radius: 20px;
|
||||
box-shadow: 0 4px 15px rgba(0,0,0,0.3);
|
||||
padding: 2rem 2rem;
|
||||
background: linear-gradient(135deg, #002147, #A50044);
|
||||
color: white;
|
||||
border-radius: 20px;
|
||||
box-shadow: 0 4px 15px rgba(0, 0, 0, 0.3);
|
||||
padding: 2rem 2rem;
|
||||
max-width: 1000px;
|
||||
margin: 0 auto;
|
||||
margin: 0 auto;
|
||||
margin-bottom: 10px;
|
||||
}
|
||||
}
|
||||
|
||||
.section-stats h2 {
|
||||
font-size: 2rem;
|
||||
margin-bottom: 1rem;
|
||||
color: var(--barca-red);
|
||||
}
|
||||
font-size: 2rem;
|
||||
margin-bottom: 1rem;
|
||||
color: var(--barca-red);
|
||||
}
|
||||
|
||||
.stats {
|
||||
display: flex;
|
||||
justify-content: space-around;
|
||||
text-align: center;
|
||||
margin-top: 2rem;
|
||||
flex-wrap: wrap;
|
||||
gap: 2rem;
|
||||
display: flex;
|
||||
justify-content: space-around;
|
||||
text-align: center;
|
||||
margin-top: 2rem;
|
||||
flex-wrap: wrap;
|
||||
gap: 2rem;
|
||||
}
|
||||
|
||||
.stat-box {
|
||||
background-color: rgba(255, 255, 255, 0.1);
|
||||
border: 2px solid var(--barca-gold);
|
||||
color: white;
|
||||
padding: 2rem;
|
||||
border-radius: 15px;
|
||||
width: 160px;
|
||||
box-shadow: 0 6px 20px rgba(0, 0, 0, 0.4);
|
||||
transition: transform 0.3s ease;
|
||||
background-color: rgba(255, 255, 255, 0.1);
|
||||
border: 2px solid var(--barca-gold);
|
||||
color: white;
|
||||
padding: 2rem;
|
||||
border-radius: 15px;
|
||||
width: 160px;
|
||||
box-shadow: 0 6px 20px rgba(0, 0, 0, 0.4);
|
||||
transition: transform 0.3s ease;
|
||||
}
|
||||
|
||||
.stat-box:hover {
|
||||
transform: scale(1.1, 1.1);
|
||||
}
|
||||
|
||||
.stat-box h3 {
|
||||
font-size: 2.5rem;
|
||||
margin-bottom: 0.5rem;
|
||||
color: var(--barca-gold);
|
||||
}
|
||||
.stat-box p {
|
||||
font-size: 1.1rem;
|
||||
font-size: 2.5rem;
|
||||
margin-bottom: 0.5rem;
|
||||
color: var(--barca-gold);
|
||||
}
|
||||
|
||||
.stat-box p {
|
||||
font-size: 1.1rem;
|
||||
}
|
||||
|
||||
.choose-club button {
|
||||
height: 50px;
|
||||
width: 50px;
|
||||
background-color: white;
|
||||
border: none;
|
||||
}
|
||||
|
||||
.choose-club button img {
|
||||
height: 40px;
|
||||
width: 40px;
|
||||
}
|
||||
|
||||
.choose-club button img:hover {
|
||||
height: 45px;
|
||||
width: 45px;
|
||||
background-color: #ffffff7e;
|
||||
}
|
||||
@@ -1,47 +1,54 @@
|
||||
<!DOCTYPE html>
|
||||
<html lang="pl">
|
||||
|
||||
<head>
|
||||
<meta charset="UTF-8">
|
||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
||||
<title>{% block title %}Lewandowski Stats{% endblock %}</title>
|
||||
<link rel="stylesheet" href="{{ url_for('static', filename='style.css') }}">
|
||||
<meta property="og:title" content="Robert Lewandowski Stats">
|
||||
<meta property="og:type" content="website" >
|
||||
<meta property="og:url" content="https://lewy.7o7.cx/" >
|
||||
<meta property="og:type" content="website">
|
||||
<meta property="og:url" content="https://lewy.7o7.cx/">
|
||||
<meta property="og:description" content="Najnowsze informacje o meczach, golach, asystach i innych statystykach">
|
||||
<meta property="og:image" content="{{ url_for('static', filename='lewandowski.jpg') }}" >
|
||||
<meta property="og:image:height" content = "143">
|
||||
<meta property="og:image:width" content = "100">
|
||||
<meta property="og:image" content="{{ url_for('static', filename='lewandowski.jpg') }}">
|
||||
<meta property="og:image:height" content="143">
|
||||
<meta property="og:image:width" content="100">
|
||||
</head>
|
||||
<body>
|
||||
<nav class="navbar">
|
||||
<div class="logo">Robert Lewandowski</div>
|
||||
<ul class="nav-links">
|
||||
<li><a href="/">🏠 Strona główna</a></li>
|
||||
<li><a href="/mecze">📅 Mecze</a></li>
|
||||
<li><a href="/statystyki">📊 Statystyki</a></li>
|
||||
<li><a href="/statystyki">📊 Statystyki</a></li>
|
||||
<li><button id="theme-toggle" onclick="toggleTheme()">🌙 / 🌞</button></li>
|
||||
</ul>
|
||||
<div class="hamburger">☰</div>
|
||||
</nav>
|
||||
|
||||
<header>
|
||||
<body>
|
||||
<header class="base-header">
|
||||
<nav class="navbar">
|
||||
<a class="logo-link" href="/"><div class="logo-text">Robert Lewandowski</div></a>
|
||||
<ul class="nav-links">
|
||||
<li><a href="/">Strona główna</a></li>
|
||||
<li><a href="/mecze">Mecze</a></li>
|
||||
<li><a href="/statystyki">Statystyki</a></li>
|
||||
<li><a href="/historia">Osiągnięcia</a></li>
|
||||
<li><button id="theme-toggle" onclick="toggleTheme()"></button></li>
|
||||
</ul>
|
||||
<div class="hamburger">☰</div>
|
||||
</nav>
|
||||
|
||||
<div class="header-content">
|
||||
<center><img src="{{ url_for('static', filename='lewandowski.jpg') }}" alt="Robert Lewandowski" class="profile-image"></center>
|
||||
<h1>Statystyki Roberta Lewandowskiego</h1>
|
||||
<div class="profile-image">
|
||||
<img src="{{ url_for('static', filename='lewandowski_no_bg.png') }}" alt="Robert Lewandowski">
|
||||
<div class="profile-image-cover"></div>
|
||||
</div>
|
||||
<h1>Statystyki <br><span class="header-content-special"> Roberta <br> Lewandowskiego</span></h1>
|
||||
</div>
|
||||
<div></div>
|
||||
</header>
|
||||
|
||||
<main>
|
||||
{% block content %}{% endblock %}
|
||||
</main>
|
||||
<script>
|
||||
const hamburger = document.querySelector('.hamburger');
|
||||
const navLinks = document.querySelector('.nav-links');
|
||||
hamburger.addEventListener('click', () => {
|
||||
navLinks.classList.toggle('show');});
|
||||
</script>
|
||||
<script>
|
||||
const hamburger = document.querySelector('.hamburger');
|
||||
const navLinks = document.querySelector('.nav-links');
|
||||
hamburger.addEventListener('click', () => {
|
||||
navLinks.classList.toggle('show');
|
||||
});
|
||||
</script>
|
||||
<script>
|
||||
function toggleTheme() {
|
||||
const currentMode = document.body.classList.contains('poland-mode') ? 'poland' : 'fcb';
|
||||
@@ -59,8 +66,9 @@
|
||||
</script>
|
||||
|
||||
<!--!>Footer<-->
|
||||
<hr style='width: 50%'/>
|
||||
<hr style='width: 50%' />
|
||||
{% block footer %}{% endblock %}
|
||||
|
||||
</body>
|
||||
|
||||
</html>
|
||||
30
FlaskWebProject/FlaskWebProject/templates/history.html
Normal file
30
FlaskWebProject/FlaskWebProject/templates/history.html
Normal file
@@ -0,0 +1,30 @@
|
||||
{% extends "base.html" %}
|
||||
|
||||
{% block title %}Strona Główna{% endblock %}
|
||||
|
||||
{% block content %}
|
||||
<section class="choose-club">
|
||||
<a href="{{ url_for('historia', club='FC Barcelona') }}">
|
||||
<button><img src="{{ url_for('static', filename='FC_Barcelona.png') }}"></button>
|
||||
</a>
|
||||
<a href="{{ url_for('historia', club='Bayern Monachium') }}">
|
||||
<button><img src="{{ url_for('static', filename='FC_Bayern.png') }}"></button>
|
||||
</a>
|
||||
</section>
|
||||
|
||||
<!-- Wyświetlanie danych tylko dla wybranego klubu -->
|
||||
{% for stats in history %}
|
||||
{% if stats.club == selected_club %}
|
||||
<section class="club-stats">
|
||||
<h2>{{ stats.club }} - All time stats</h2>
|
||||
<div class="stats">
|
||||
Gole: {{ stats.goals }}
|
||||
</div>
|
||||
</section>
|
||||
{% endif %}
|
||||
{% endfor %}
|
||||
{% endblock %}
|
||||
|
||||
{% block footer %}
|
||||
{{ commit_in_html | safe }}
|
||||
{% endblock %}
|
||||
@@ -3,13 +3,56 @@
|
||||
{% block title %}Strona Główna{% endblock %}
|
||||
|
||||
{% block content %}
|
||||
<h2>Witaj na stronie poświęconej statystykom Roberta Lewandowskiego!</h2>
|
||||
<p>Tu znajdziesz najnowsze informacje o meczach, golach, asystach i innych statystykach.</p>
|
||||
<div>
|
||||
<h3>Ogólne statystyki:</h3>
|
||||
<p>Gole: {{ goals }}</p>
|
||||
<p>Asysty: {{ assists }}</p>
|
||||
<p>Liczba meczów: {{ matches }}</p>
|
||||
<div class="main-index">
|
||||
<h2>Witaj na stronie poświęconej <br> statystykom Roberta Lewandowskiego!</h2>
|
||||
<p>Tu znajdziesz najnowsze informacje o meczach, golach, asystach i innych statystykach.</p>
|
||||
<section class="about-section">
|
||||
<article class="article__how-it-works">
|
||||
<h3>Jak to działa?</h3>
|
||||
<h4>Pobieranie statystyk</h4>
|
||||
<p>Lorem ipsum dolor sit amet consectetur adipisicing elit. Ratione harum minus hic, voluptate perspiciatis laborum? Alias maxime, voluptate reprehenderit iusto dolorem officiis porro voluptatibus repellat dicta doloribus, blanditiis similique accusantium.</p>
|
||||
<h4>Porównywanie zawodników</h4>
|
||||
<p>Lorem, ipsum dolor sit amet consectetur adipisicing elit. Fuga, in perspiciatis. Sequi laborum et animi quas sit voluptatibus alias sed ad molestias nulla vel cum, consectetur commodi odio aliquam officia.</p>
|
||||
</article>
|
||||
<div class="about-section-image">
|
||||
<img src="{{ url_for('static', filename='gigabuła.png') }}">
|
||||
</div>
|
||||
<article>
|
||||
<h3>Mecze</h3>
|
||||
<p>Lorem ipsum dolor sit amet consectetur adipisicing elit. Soluta ullam iusto ex? Quo amet officia aliquam odio sint harum nam eaque nihil ipsa quos aliquid, illum voluptatum, numquam, magnam omnis?</p>
|
||||
<a href="/mecze">Zobacz mecze</a>
|
||||
</article>
|
||||
<article>
|
||||
<h3>Statystyki</h3>
|
||||
<p>Lorem ipsum dolor sit amet consectetur adipisicing elit. Temporibus dolore tenetur nulla sint recusandae illo dolores aspernatur ducimus, omnis vitae ipsam neque animi voluptates eos porro, nihil iusto veniam commodi!</p>
|
||||
<a href="/statystyki">Zobacz statystyki</a>
|
||||
</article>
|
||||
<article>
|
||||
<h3>Osiągnięcia</h3>
|
||||
<p>Lorem ipsum dolor sit amet consectetur adipisicing elit. Quod dicta veritatis quibusdam eligendi corrupti. Expedita delectus assumenda ipsum illum molestias a voluptates, voluptas quia reprehenderit, quod non, eum veritatis tenetur!</p>
|
||||
<a href="/historia">Zobacz osiągnięcia</a>
|
||||
</article>
|
||||
</section>
|
||||
|
||||
<section class="general-stats-section">
|
||||
<h2>Ogólne statystyki:</h3>
|
||||
<div class="grid">
|
||||
|
||||
<article>
|
||||
<h3>Gole:</h3>
|
||||
<p>{{ goals }}</p>
|
||||
</article>
|
||||
<article>
|
||||
<h3>Asysty</h3>
|
||||
<p>{{ assists }}</p>
|
||||
</article>
|
||||
<article>
|
||||
<h3>Liczba meczów</h3>
|
||||
<p>{{ matches }}</p>
|
||||
</article>
|
||||
</div>
|
||||
</section>
|
||||
|
||||
</div>
|
||||
{% endblock %}
|
||||
|
||||
|
||||
@@ -3,23 +3,25 @@
|
||||
{% block title %}Lista meczów{% endblock %}
|
||||
|
||||
{% block content %}
|
||||
<h2>📅 Mecze Roberta</h2>
|
||||
<table>
|
||||
<tr>
|
||||
<th>Data</th>
|
||||
<th>Przeciwnik</th>
|
||||
<th>Gole</th>
|
||||
<th>Asysty</th>
|
||||
<th>Minuty</th>
|
||||
</tr>
|
||||
{% for match in matches %}
|
||||
<tr>
|
||||
<td>{{ match.date }}</td>
|
||||
<td>{{ match.opponent }}</td>
|
||||
<td>{{ match.goals }}</td>
|
||||
<td>{{ match.assists }}</td>
|
||||
<td>{{ match.minutes }}</td>
|
||||
</tr>
|
||||
{% endfor %}
|
||||
</table>
|
||||
<section class="section__matches">
|
||||
<h2>📅 Mecze Roberta</h2>
|
||||
<table>
|
||||
<tr>
|
||||
<th>Data</th>
|
||||
<th>Przeciwnik</th>
|
||||
<th>Gole</th>
|
||||
<th>Asysty</th>
|
||||
<th>Minuty</th>
|
||||
</tr>
|
||||
{% for match in matches %}
|
||||
<tr>
|
||||
<td>{{ match.date }}</td>
|
||||
<td>{{ match.opponent }}</td>
|
||||
<td>{{ match.goals }}</td>
|
||||
<td>{{ match.assists }}</td>
|
||||
<td>{{ match.minutes }}</td>
|
||||
</tr>
|
||||
{% endfor %}
|
||||
</table>
|
||||
</section>
|
||||
{% endblock %}
|
||||
|
||||
Reference in New Issue
Block a user