Compare commits
19 Commits
ca961320e7
...
frontend
| Author | SHA1 | Date | |
|---|---|---|---|
| 416b2ccfe0 | |||
| 919d64ca5e | |||
| 2cfa5f1fa4 | |||
| 9b45a3f26f | |||
| 3dfc40cdb0 | |||
| be951d296f | |||
| 6e1e8ccc7d | |||
| 03463905ef | |||
| 35db71b8cc | |||
| f65a174089 | |||
| bdfa31c8ea | |||
| 206f7d6fb3 | |||
| df0e47c610 | |||
| 3b9aa8150b | |||
| bc557b35af | |||
| 4987dc4cf7 | |||
| 48825185b8 | |||
| 42c60f9db5 | |||
| 504702700c |
@@ -61,6 +61,34 @@ class scraper:
|
|||||||
# return False
|
# return False
|
||||||
return self.__czy_x_istnieje("kluby", id_klubu=id_klubu)
|
return self.__czy_x_istnieje("kluby", id_klubu=id_klubu)
|
||||||
|
|
||||||
|
def id_na_imie_nazwisko_urodziny(self, zewnetrzne_id_sportowca: str = "MVC8zHZD"):
|
||||||
|
"""
|
||||||
|
Scraper z dykty xD
|
||||||
|
Pobiera imiona, nazwiska i dni urodzin sportowców z zewnętrznego id.
|
||||||
|
Działa na słowo honoru.
|
||||||
|
|
||||||
|
:param zewnetrzne_id_sportowca: Zewnętrzne id sportowca
|
||||||
|
:type zewnetrzne_id_sportowca: str
|
||||||
|
"""
|
||||||
|
if len(zewnetrzne_id_sportowca) != 8:
|
||||||
|
raise ValueError("Zewnętrzne ID sportowca powinno być długości 8!")
|
||||||
|
r = requests.get(f'https://www.flashscore.pl/?r=4:{zewnetrzne_id_sportowca}')
|
||||||
|
page = r.text
|
||||||
|
|
||||||
|
name_start_pos = page.find("data-testid=\"wcl-scores-heading-02\">") + 36
|
||||||
|
name_end_pos = page.find("</", name_start_pos)
|
||||||
|
name = page[name_start_pos:name_end_pos].strip().split(' ')
|
||||||
|
|
||||||
|
# Tak wiem... można by było użyć beautifulsoup4, ale nie ma sensu dodawać nowych zależności dla tylko jednej metody.
|
||||||
|
birthday_start_pos_1 = page.find("data-testid=\"wcl-scores-simpleText-01\">", name_end_pos) + 39
|
||||||
|
birthday_start_pos_2 = page.find("data-testid=\"wcl-scores-simpleText-01\">", birthday_start_pos_1) + 39
|
||||||
|
birthday_start_pos_3 = page.find("data-testid=\"wcl-scores-simpleText-01\">", birthday_start_pos_2) + 39
|
||||||
|
birthday_start_pos = page.find("data-testid=\"wcl-scores-simpleText-01\">", birthday_start_pos_3) + 39
|
||||||
|
birthday_end_pos = page.find("</", birthday_start_pos) - 1
|
||||||
|
birthday = None if birthday_end_pos - birthday_start_pos > 20 else page[birthday_start_pos:birthday_end_pos].strip(" ()")
|
||||||
|
|
||||||
|
return name, birthday
|
||||||
|
|
||||||
def aktualizuj_dane_sportowca(self, zewnetrzne_id_sportowca: str = "MVC8zHZD"):
|
def aktualizuj_dane_sportowca(self, zewnetrzne_id_sportowca: str = "MVC8zHZD"):
|
||||||
stop_scraping = False
|
stop_scraping = False
|
||||||
matches_to_add = []
|
matches_to_add = []
|
||||||
|
|||||||
@@ -67,6 +67,10 @@ def setup():
|
|||||||
app.add_url_rule('/mecze', view_func=lewy_routes.mecze)
|
app.add_url_rule('/mecze', view_func=lewy_routes.mecze)
|
||||||
app.add_url_rule('/statystyki', view_func=lewy_routes.statystyki)
|
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('/toggle_dark_mode', view_func=lewy_routes.toggle_dark_mode)
|
||||||
|
app.add_url_rule('/club', view_func=lewy_routes.clubs)
|
||||||
|
app.add_url_rule('/representation', view_func=lewy_routes.representation)
|
||||||
|
app.add_url_rule('/compare', view_func=lewy_routes.compare)
|
||||||
|
app.add_url_rule('/trophies', view_func=lewy_routes.trophies)
|
||||||
|
|
||||||
# API:
|
# API:
|
||||||
app.add_url_rule('/api/', view_func=lewy_api.api_greeting)
|
app.add_url_rule('/api/', view_func=lewy_api.api_greeting)
|
||||||
|
|||||||
@@ -105,6 +105,20 @@ def debugger_halt(r):
|
|||||||
breakpoint()
|
breakpoint()
|
||||||
return 200, "ok", []
|
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):
|
def lookup(data, request):
|
||||||
"""
|
"""
|
||||||
Obsługuje zapytania zwrócone do /api/v1/...
|
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
|
from typing import List
|
||||||
import time
|
import time
|
||||||
import toml
|
import toml
|
||||||
|
import traceback
|
||||||
|
|
||||||
global db
|
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():
|
class baza():
|
||||||
|
|
||||||
# global sportowcy, trofea, sportowcy_w_meczach, statystyki_sportowcow, kluby, mecze
|
# global sportowcy, trofea, sportowcy_w_meczach, statystyki_sportowcow, kluby, mecze
|
||||||
@@ -167,18 +180,40 @@ class baza():
|
|||||||
try:
|
try:
|
||||||
return_val = func(self, *args, **kwargs)
|
return_val = func(self, *args, **kwargs)
|
||||||
except:
|
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.rollback()
|
||||||
self.session.close()
|
self.session.close()
|
||||||
self.refresh_session()
|
self.refresh_session()
|
||||||
return return_val
|
return return_val
|
||||||
return wrapper
|
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
|
||||||
|
"""
|
||||||
|
table_str = string[:string.find('.')]
|
||||||
|
column_str = string[string.find('.') + 1:]
|
||||||
|
if hasattr(self.entities[table_str], column_str):
|
||||||
|
return getattr(self.entities[table_str], column_str)
|
||||||
|
return None
|
||||||
|
|
||||||
@exit_gracefully
|
@exit_gracefully
|
||||||
def simple_select_all(self, entity_type, **kwargs):
|
def simple_select_all(self, entity_type, **kwargs):
|
||||||
"""
|
"""
|
||||||
Użycie:
|
Użycie:
|
||||||
simple_select_all(ldb.sportowcy, zewnetrzne_id_zawodnika="MVC8zHZD")
|
simple_select_all(ldb.sportowcy, zewnetrzne_id_zawodnika="MVC8zHZD")
|
||||||
simple_select_all("sportowcy", id_zawodnika=1)
|
simple_select_all("sportowcy", id_zawodnika=1)
|
||||||
|
simple_select_all("kluby", ..., LIMIT=5, ORDER_BY="kluby.skrocona_nazwa")
|
||||||
|
|
||||||
https://stackoverflow.com/a/75316945
|
https://stackoverflow.com/a/75316945
|
||||||
Did they make it harder to query dynamically on purpose? ~Frank 19.11.2023
|
Did they make it harder to query dynamically on purpose? ~Frank 19.11.2023
|
||||||
@@ -187,18 +222,45 @@ class baza():
|
|||||||
if not isinstance(entity_type, str):
|
if not isinstance(entity_type, str):
|
||||||
entity_type = entity_type.__name__
|
entity_type = entity_type.__name__
|
||||||
|
|
||||||
|
# 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.
|
||||||
|
special_keywords = ("ORDER_BY", "ORDER_BY_DESC", "LIMIT")
|
||||||
|
special_args = {}
|
||||||
|
|
||||||
|
for arg in special_keywords:
|
||||||
|
if arg in kwargs:
|
||||||
|
special_args[arg] = kwargs[arg]
|
||||||
|
del kwargs[arg]
|
||||||
|
|
||||||
print(f"[{round(time.time())}] SELECT")
|
print(f"[{round(time.time())}] SELECT")
|
||||||
|
|
||||||
results = (
|
results = (
|
||||||
self.session.
|
self.session.
|
||||||
query(self.entities[entity_type]).
|
query(self.entities[entity_type]).
|
||||||
filter_by(**kwargs).
|
filter_by(**kwargs)
|
||||||
all()
|
|
||||||
)
|
)
|
||||||
|
|
||||||
print(f"[{round(time.time())}] SELECT RESULTS: {results}")
|
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)
|
||||||
|
|
||||||
return results
|
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"])
|
||||||
|
|
||||||
|
results_objs = results.all()
|
||||||
|
print(f"[{round(time.time())}] SELECT RESULTS: {results_objs}")
|
||||||
|
|
||||||
|
return results_objs
|
||||||
|
|
||||||
@exit_gracefully
|
@exit_gracefully
|
||||||
def simple_insert_one(self, entity_type, **kwargs):
|
def simple_insert_one(self, entity_type, **kwargs):
|
||||||
@@ -213,6 +275,14 @@ class baza():
|
|||||||
if not isinstance(entity_type, str):
|
if not isinstance(entity_type, str):
|
||||||
entity_type = entity_type.__name__
|
entity_type = entity_type.__name__
|
||||||
|
|
||||||
|
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")
|
print(f"[{round(time.time())}] INSERT")
|
||||||
|
|
||||||
obj = self.entities[entity_type](**kwargs)
|
obj = self.entities[entity_type](**kwargs)
|
||||||
|
|||||||
@@ -1,8 +1,46 @@
|
|||||||
from flask import render_template, request, make_response
|
from flask import render_template, request, make_response
|
||||||
|
import lewy_api_v1
|
||||||
|
import lewy_db
|
||||||
import lewy_globals
|
import lewy_globals
|
||||||
|
|
||||||
|
def get_lewy_stats():
|
||||||
|
return {
|
||||||
|
'all_time_stats': {
|
||||||
|
'goals': 380,
|
||||||
|
'assists': 120,
|
||||||
|
'matches': 450,
|
||||||
|
},
|
||||||
|
'club_stats': {
|
||||||
|
'goals': 132,
|
||||||
|
'assists': 112,
|
||||||
|
'matches': 245,
|
||||||
|
},
|
||||||
|
'nation_stats': {
|
||||||
|
'goals': 86,
|
||||||
|
'assists': 52,
|
||||||
|
'matches': 158,
|
||||||
|
},
|
||||||
|
'worldcup': {
|
||||||
|
'goals': 7,
|
||||||
|
'assists': 2,
|
||||||
|
'matches': 11,
|
||||||
|
},
|
||||||
|
'euro': {
|
||||||
|
'goals': 6,
|
||||||
|
'assists': 2,
|
||||||
|
'matches': 18,
|
||||||
|
},
|
||||||
|
'cards': {
|
||||||
|
'yellow': 24,
|
||||||
|
'red': 4,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
def index():
|
def index():
|
||||||
dark_mode = request.cookies.get('darkMode', 'disabled')
|
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 = {
|
stats = {
|
||||||
'goals': 38,
|
'goals': 38,
|
||||||
'assists': 12,
|
'assists': 12,
|
||||||
@@ -27,12 +65,39 @@ def mecze():
|
|||||||
return render_template('matches.html', matches=matches)
|
return render_template('matches.html', matches=matches)
|
||||||
|
|
||||||
def statystyki():
|
def statystyki():
|
||||||
stats = {
|
dane=get_lewy_stats()
|
||||||
'goals': 38,
|
return render_template('stats.html', **dane)
|
||||||
'assists': 12,
|
|
||||||
'matches': 45,
|
def clubs():
|
||||||
|
selected_club = request.args.get("club","FC Barcelona")
|
||||||
|
clubs = [
|
||||||
|
{'club': 'FC Barcelona', 'goals': 22,'assist':12},
|
||||||
|
{'club': 'Bayern Monachium', 'goals': 132,'assist':12},
|
||||||
|
{'club': 'Borussia Dortmund', 'goals': 132,'assist':12},
|
||||||
|
{'club': 'Lech Poznan', 'goals': 132,'assist':12},
|
||||||
|
]
|
||||||
|
return render_template('club.html', clubs=clubs, selected_club=selected_club)
|
||||||
|
|
||||||
|
def representation():
|
||||||
|
nation_stats = {
|
||||||
|
'goals': 86,
|
||||||
|
'assists': 52,
|
||||||
|
'matches': 158,
|
||||||
}
|
}
|
||||||
return render_template('stats.html', stats=stats)
|
return render_template('representation.html', nation_stats=nation_stats)
|
||||||
|
def compare():
|
||||||
|
selected_player = request.args.get("player","Leo Messi")
|
||||||
|
lewy=get_lewy_stats()
|
||||||
|
player2 = [
|
||||||
|
{'name':'Leo Messi','goals': 34,'assists': 12},
|
||||||
|
]
|
||||||
|
return render_template('compare.html',player2=player2, selected_player=selected_player,**lewy, )
|
||||||
|
def trophies():
|
||||||
|
trophy = [
|
||||||
|
{'name': 'asdasd', 'year': 2023},
|
||||||
|
{'name': 'ssss', 'sezon': '2022/2023'},
|
||||||
|
]
|
||||||
|
return render_template('trophies.html',trophy=trophy)
|
||||||
|
|
||||||
def toggle_dark_mode():
|
def toggle_dark_mode():
|
||||||
# Przełącz tryb i zapisz w ciasteczku
|
# Przełącz tryb i zapisz w ciasteczku
|
||||||
|
|||||||
BIN
FlaskWebProject/FlaskWebProject/static/Borussia_Dortmund.png
Normal file
|
After Width: | Height: | Size: 165 KiB |
BIN
FlaskWebProject/FlaskWebProject/static/FC_Barcelona.png
Normal file
|
After Width: | Height: | Size: 206 KiB |
BIN
FlaskWebProject/FlaskWebProject/static/FC_Bayern.png
Normal file
|
After Width: | Height: | Size: 186 KiB |
BIN
FlaskWebProject/FlaskWebProject/static/Lech_Poznan.png
Normal file
|
After Width: | Height: | Size: 15 KiB |
BIN
FlaskWebProject/FlaskWebProject/static/fonts/Exo2-ExtraBold.ttf
Normal file
BIN
FlaskWebProject/FlaskWebProject/static/fonts/Exo2-SemiBold.ttf
Normal file
BIN
FlaskWebProject/FlaskWebProject/static/gigabuła.png
Normal file
|
After Width: | Height: | Size: 244 KiB |
BIN
FlaskWebProject/FlaskWebProject/static/lewandowski_no_bg.png
Normal file
|
After Width: | Height: | Size: 351 KiB |
BIN
FlaskWebProject/FlaskWebProject/static/soccer-field.jpg
Normal file
|
After Width: | Height: | Size: 132 KiB |
@@ -1,44 +1,548 @@
|
|||||||
|
* {
|
||||||
|
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;
|
||||||
|
--polska-red-dark: #DC143C;
|
||||||
|
--polska-red: #E30B17;
|
||||||
|
--polska-white: #FFFFFF;
|
||||||
|
|
||||||
|
--polska-section-color: #121623;
|
||||||
|
--section-color: #051839;
|
||||||
|
--pink-highlight: #E1317E;
|
||||||
|
--blue-highlight: #00B9BF;
|
||||||
|
--yellow-highlight: #FFD23F;
|
||||||
|
--border-radius: 5px;
|
||||||
|
}
|
||||||
|
|
||||||
/* Podstawowy styl */
|
/* Podstawowy styl */
|
||||||
body {
|
body {
|
||||||
font-family: 'Arial', sans-serif;
|
font-family: 'Exo2ExtraBold', sans-serif;
|
||||||
margin: 0;
|
margin: 0;
|
||||||
padding: 0;
|
padding: 0;
|
||||||
background: #f7f7f7;
|
background-color: var(--section-color);
|
||||||
color: #222;
|
color: black;
|
||||||
transition: all 0s ease;
|
transition: all 0s ease;
|
||||||
display: flex;
|
display: flex;
|
||||||
flex-direction: column;
|
flex-direction: column;
|
||||||
align-items: center; /* Wyśrodkowanie elementów w poziomie */
|
align-items: stretch;
|
||||||
justify-content: flex-start; /* Ustalamy początek na górze */
|
/* Wyśrodkowanie elementów w poziomie */
|
||||||
|
justify-content: flex-start;
|
||||||
|
/* Ustalamy początek na górze */
|
||||||
min-height: 100vh;
|
min-height: 100vh;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Styl nawigacji */
|
/* Header */
|
||||||
nav {
|
.header-content {
|
||||||
background: #d32f2f;
|
|
||||||
padding: 0px;
|
|
||||||
display: flex;
|
|
||||||
justify-content: center; /* Wyśrodkowanie linków */
|
|
||||||
width: 100%;
|
width: 100%;
|
||||||
|
display: flex;
|
||||||
|
justify-content: center;
|
||||||
|
align-items: center;
|
||||||
|
padding: 20px 0;
|
||||||
|
background: var(--section-color);
|
||||||
color: white;
|
color: white;
|
||||||
|
font-size: 15px;
|
||||||
|
z-index: -2;
|
||||||
|
position: relative;
|
||||||
|
margin-top: 60px;
|
||||||
|
/* box-shadow: 0px -5px 10px 2px rgba(0, 0, 0, 0.347); */
|
||||||
}
|
}
|
||||||
|
|
||||||
nav a, nav button {
|
|
||||||
color: white;
|
.header-content h1 {
|
||||||
text-decoration: none;
|
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);
|
||||||
|
|
||||||
|
padding: 2.3rem 1rem;
|
||||||
|
height: 1.5rem;
|
||||||
|
position: fixed;
|
||||||
|
top: 0;
|
||||||
|
left: 0;
|
||||||
|
width: 100%;
|
||||||
|
z-index: 999;
|
||||||
|
display: flex;
|
||||||
|
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;
|
||||||
|
}
|
||||||
|
|
||||||
|
.logo {
|
||||||
|
display: flex;
|
||||||
|
align-items: center;
|
||||||
|
}
|
||||||
|
|
||||||
|
.logo-text {
|
||||||
|
font-size: 1.5rem;
|
||||||
font-weight: bold;
|
font-weight: bold;
|
||||||
background: none;
|
color: var(--barca-gold);
|
||||||
|
}
|
||||||
|
|
||||||
|
.logo-icon {
|
||||||
|
font-size: 2.8em;
|
||||||
|
}
|
||||||
|
|
||||||
|
.logo-link {
|
||||||
|
text-decoration: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.nav-links {
|
||||||
|
display: flex;
|
||||||
|
gap: 0rem;
|
||||||
|
list-style: none;
|
||||||
|
height: 100%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.nav-links li a {
|
||||||
|
display: block;
|
||||||
|
color: white;
|
||||||
|
/* dopasowane do .navbar padding */
|
||||||
|
font-weight: 500;
|
||||||
border: none;
|
border: none;
|
||||||
cursor: pointer;
|
cursor: pointer;
|
||||||
margin: 0 15px; /* Odstęp między elementami */
|
align-items: center;
|
||||||
|
text-decoration: none;
|
||||||
|
border-radius: var(--border-radius);
|
||||||
|
padding: 10px;
|
||||||
|
height: 100%;
|
||||||
|
transition: 100ms ease;
|
||||||
|
position: relative;
|
||||||
|
}
|
||||||
|
|
||||||
|
.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:nth-child(5) a::before {
|
||||||
|
content: "⚽";
|
||||||
|
}
|
||||||
|
.nav-links li:nth-child(6) a::before {
|
||||||
|
content: "🏆";
|
||||||
|
}
|
||||||
|
.nav-links li:nth-child(7) 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 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 {
|
||||||
|
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;
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (max-width: 1090px) {
|
||||||
|
/* .base-header .navbar:not(:has(.show))
|
||||||
|
{
|
||||||
|
margin-bottom: 400px;
|
||||||
|
} */
|
||||||
|
|
||||||
|
|
||||||
|
.nav-links {
|
||||||
|
position: absolute;
|
||||||
|
flex-direction: column;
|
||||||
|
top: 57px;
|
||||||
|
right: 0px;
|
||||||
|
padding: 0rem;
|
||||||
|
gap: 0;
|
||||||
|
height: auto;
|
||||||
|
backdrop-filter: blur(4px);
|
||||||
|
width: 30%;
|
||||||
|
justify-content: center;
|
||||||
|
box-shadow: 0px 0px 5px 5px rgba(0, 0, 0, 0.105);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.nav-links li {
|
||||||
|
width: 100%;
|
||||||
|
margin: 0;
|
||||||
|
display: flex;
|
||||||
|
justify-content: center;
|
||||||
|
}
|
||||||
|
|
||||||
|
.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 li button
|
||||||
|
{
|
||||||
|
background-color: none;
|
||||||
|
width: 45px;
|
||||||
|
border-radius: 50%;
|
||||||
|
}
|
||||||
|
.nav-links li button::before,.nav-links li button::after
|
||||||
|
{
|
||||||
|
background-color: none
|
||||||
|
;
|
||||||
|
}
|
||||||
|
.nav-links li button:hover
|
||||||
|
{
|
||||||
|
transform: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.nav-links.show {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.hamburger {
|
||||||
|
display: block;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
@media (max-width: 1000px)
|
||||||
|
{
|
||||||
|
.header-content
|
||||||
|
{
|
||||||
|
flex-direction: column;
|
||||||
|
}
|
||||||
|
.header-content .profile-image
|
||||||
|
{
|
||||||
|
display: flex;
|
||||||
|
justify-content: center;
|
||||||
|
width: 100%;
|
||||||
|
}
|
||||||
|
.header-content .profile-image img{
|
||||||
|
width: 100%;
|
||||||
|
}
|
||||||
|
.about-section-image
|
||||||
|
{
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
@media (max-width: 600px){
|
||||||
|
.section__matches
|
||||||
|
{
|
||||||
|
font-size: 10px;
|
||||||
|
}
|
||||||
|
.section__matches th{
|
||||||
|
padding: 3px;
|
||||||
|
}
|
||||||
|
.club-stats-grid
|
||||||
|
{
|
||||||
|
grid-template-columns: 1fr 1fr !important;
|
||||||
|
}
|
||||||
|
.club-stats-grid .stat-box
|
||||||
|
{
|
||||||
|
width: 100%;
|
||||||
|
}
|
||||||
|
.section-stats-center .section-stats .stats
|
||||||
|
{
|
||||||
|
display: flex;
|
||||||
|
flex-direction: column;
|
||||||
|
align-items: center;
|
||||||
|
}
|
||||||
|
.section-stats-center .section-stats .stats .stat-box
|
||||||
|
{
|
||||||
|
width: 100%;
|
||||||
|
padding: 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/* Wyśrodkowanie głównej zawartości */
|
/* Wyśrodkowanie głównej zawartości */
|
||||||
main {
|
main {
|
||||||
padding: 0px;
|
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%;
|
width: 100%;
|
||||||
max-width: 980px; /* Maksymalna szerokość treści */
|
color: var(--barca-gold);
|
||||||
text-align: center; /* Wyśrodkowanie tekstu */
|
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 */
|
/* Styl dla tabeli */
|
||||||
@@ -48,7 +552,8 @@ table {
|
|||||||
margin-top: 20px;
|
margin-top: 20px;
|
||||||
}
|
}
|
||||||
|
|
||||||
th, td {
|
th,
|
||||||
|
td {
|
||||||
padding: 10px;
|
padding: 10px;
|
||||||
border-bottom: 1px solid #ccc;
|
border-bottom: 1px solid #ccc;
|
||||||
text-align: center;
|
text-align: center;
|
||||||
@@ -60,79 +565,318 @@ th, td {
|
|||||||
height: 100px;
|
height: 100px;
|
||||||
border-radius: 50%;
|
border-radius: 50%;
|
||||||
display: block;
|
display: block;
|
||||||
margin: 0 auto; /* Wyśrodkowanie obrazka */
|
margin: 0 auto;
|
||||||
|
/* Wyśrodkowanie obrazka */
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Styl dla trybu ciemnego */
|
.section__matches
|
||||||
body.dark-mode {
|
{
|
||||||
background: #121212;
|
background-color: white;
|
||||||
color: #e0e0e0;
|
width: 80%;
|
||||||
|
border-radius: var(--border-radius);
|
||||||
|
max-width: 1000px;
|
||||||
|
margin-bottom: 50px;
|
||||||
|
}
|
||||||
|
.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;
|
||||||
}
|
}
|
||||||
|
|
||||||
body.dark-mode nav {
|
.section__matches td:last-child
|
||||||
background: #333;
|
{
|
||||||
}
|
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;
|
||||||
|
}
|
||||||
|
|
||||||
body.dark-mode table {
|
/* Styl dla trybu polskiego */
|
||||||
color: #e0e0e0;
|
body.poland-mode {
|
||||||
}
|
background-color: var(--polska-section-color);
|
||||||
|
}
|
||||||
|
|
||||||
body.dark-mode h1 {
|
body.poland-mode .navbar {
|
||||||
color: #eaeaea;
|
background: linear-gradient(to bottom, #bd4148, #dc1414);
|
||||||
}
|
}
|
||||||
|
|
||||||
body.dark-mode header button {
|
body.poland-mode .logo {
|
||||||
background-color: #444;
|
color: var(--polska-white)
|
||||||
color: #eaeaea;
|
}
|
||||||
}
|
|
||||||
|
|
||||||
body.dark-mode header button:hover {
|
body.poland-mode .logo-text {
|
||||||
background-color: #666;
|
|
||||||
}
|
|
||||||
|
|
||||||
body.dark-mode ul li {
|
|
||||||
background-color: #333;
|
|
||||||
}
|
|
||||||
|
|
||||||
body.dark-mode ul li:hover {
|
|
||||||
background-color: #444;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Przyciski i elementy */
|
|
||||||
header button {
|
|
||||||
padding: 10px 15px;
|
|
||||||
border: none;
|
|
||||||
background-color: #007bff;
|
|
||||||
color: white;
|
color: white;
|
||||||
font-size: 16px;
|
|
||||||
cursor: pointer;
|
|
||||||
border-radius: 5px;
|
|
||||||
transition: background-color 0.3s;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
header button:hover {
|
body.poland-mode .nav-links li a {
|
||||||
background-color: #0056b3;
|
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: white;
|
||||||
|
}
|
||||||
|
|
||||||
|
body.poland-mode .stat-box {
|
||||||
|
border-color: white;
|
||||||
|
background: linear-gradient(to bottom, #ff0000,#231212);
|
||||||
|
}
|
||||||
|
|
||||||
|
body.poland-mode .stat-box h3 {
|
||||||
|
color: white;
|
||||||
|
}
|
||||||
|
body.poland-mode .club-stats h2{
|
||||||
|
background: linear-gradient(to bottom, #ff0000,#231212);
|
||||||
|
border: 4px solid white;
|
||||||
|
color: white;
|
||||||
|
}
|
||||||
|
body.poland-mode .about-section {
|
||||||
|
background-color: var(--polska-section-color);
|
||||||
|
color: white;
|
||||||
|
}
|
||||||
|
|
||||||
|
body.poland-mode .about-section article h3 {
|
||||||
|
background-color: var(--polska-red-dark);
|
||||||
|
color: white;
|
||||||
|
}
|
||||||
|
|
||||||
|
body.poland-mode .about-section article h4 {
|
||||||
|
background-color: #ffcaca;
|
||||||
|
color: black;
|
||||||
|
border-radius: 5px;
|
||||||
|
}
|
||||||
|
body.poland-mode .general-stats-section h2 {
|
||||||
|
background: var(--polska-section-color);
|
||||||
|
}
|
||||||
|
body.poland-mode .general-stats-section .grid article:nth-child(1){background-color: var(--polska-red-dark);}
|
||||||
|
body.poland-mode .general-stats-section .grid article:nth-child(2){background-color: var(--yellow-highlight);}
|
||||||
|
body.poland-mode .general-stats-section .grid article:nth-child(3){background-color: var(--barca-blue);}
|
||||||
|
body.poland-mode .about-section-image::after{
|
||||||
|
background:var(--polska-red-dark);
|
||||||
|
}
|
||||||
|
/* Przyciski i elementy */
|
||||||
|
|
||||||
|
|
||||||
/* Style dla listy meczów */
|
/* Style dla listy meczów */
|
||||||
ul {
|
.section-stats {
|
||||||
list-style: none;
|
background: linear-gradient(135deg, #002147, #A50044);
|
||||||
padding: 0;
|
color: white;
|
||||||
display: flex;
|
border-radius: 20px;
|
||||||
flex-direction: column;
|
box-shadow: 0 4px 15px rgba(0, 0, 0, 0.3);
|
||||||
align-items: center; /* Wyśrodkowanie listy */
|
padding: 2rem 2rem;
|
||||||
|
max-width: 1000px;
|
||||||
|
margin: 0 auto;
|
||||||
|
text-align: center;
|
||||||
|
margin-bottom: 10px;
|
||||||
|
width: 100%;
|
||||||
|
}
|
||||||
|
.section-stats-center
|
||||||
|
{
|
||||||
|
display: grid;
|
||||||
|
grid-template-columns: 1fr 1fr;
|
||||||
|
gap: 30px;
|
||||||
|
justify-content: center;
|
||||||
|
}
|
||||||
|
@media (max-width: 1400px) {
|
||||||
|
|
||||||
|
.section-stats-center
|
||||||
|
{
|
||||||
|
grid-template-columns: 1fr !important;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
.section-stats h2 {
|
||||||
|
font-size: 2rem;
|
||||||
|
margin-bottom: 1rem;
|
||||||
|
color: var(--barca-red);
|
||||||
}
|
}
|
||||||
|
|
||||||
ul li {
|
.stats {
|
||||||
background-color: #eaeaea;
|
display: flex;
|
||||||
margin-bottom: 10px;
|
justify-content: space-around;
|
||||||
padding: 10px;
|
text-align: center;
|
||||||
border-radius: 5px;
|
margin-top: 2rem;
|
||||||
transition: background-color 0.3s;
|
gap: 2rem;
|
||||||
width: 90%; /* Szerokość li z marginesem */
|
}
|
||||||
max-width: 800px; /* Maksymalna szerokość elementu */
|
|
||||||
}
|
|
||||||
|
|
||||||
ul li:hover {
|
.stat-box {
|
||||||
background-color: #d1d1d1;
|
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;
|
||||||
|
}
|
||||||
|
.choose-club
|
||||||
|
{
|
||||||
|
margin: 10px;
|
||||||
|
padding: 20px;
|
||||||
|
display: flex;
|
||||||
|
gap: 20px;
|
||||||
|
justify-content: space-around;
|
||||||
|
}
|
||||||
|
|
||||||
|
.choose-club button {
|
||||||
|
width: 100px;
|
||||||
|
border: none;
|
||||||
|
|
||||||
|
background-color:transparent;
|
||||||
|
border-radius: 50%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.choose-club button img {
|
||||||
|
width: 100%;
|
||||||
|
height: 100%;
|
||||||
|
background-color:transparent;
|
||||||
|
transition: transform 100ms ease;
|
||||||
|
}
|
||||||
|
|
||||||
|
.choose-club button img:hover {
|
||||||
|
transform: scale(1.3,1.3) translateY(-10px);
|
||||||
|
}
|
||||||
|
.club-stats h2{
|
||||||
|
color: var(--barca-gold);
|
||||||
|
text-align: center;
|
||||||
|
border: 5px solid var(--barca-red);
|
||||||
|
background-color: var(--barca-blue);
|
||||||
|
padding: 20px;
|
||||||
|
border-radius: var(--border-radius);
|
||||||
|
}
|
||||||
|
.stat-box
|
||||||
|
{
|
||||||
|
padding: 20px;
|
||||||
|
background-color: var(--barca-blue);
|
||||||
|
display: grid;
|
||||||
|
grid-template-rows: 1fr 1fr;
|
||||||
|
text-align: center;
|
||||||
|
}
|
||||||
|
.stat-box-special
|
||||||
|
{text-align: center;
|
||||||
|
display: block;
|
||||||
|
font-size: 40px;
|
||||||
|
color: var(--barca-gold);
|
||||||
|
}
|
||||||
|
.club-stats-grid
|
||||||
|
{
|
||||||
|
display: grid;
|
||||||
|
margin-bottom: 50px;
|
||||||
|
gap: 10px;
|
||||||
|
grid-template-columns: 1fr 1fr 1fr;
|
||||||
|
grid-template-rows: 1fr 1fr 1fr;
|
||||||
|
}
|
||||||
|
select
|
||||||
|
{
|
||||||
|
color: white;
|
||||||
|
padding: 20px;
|
||||||
|
margin: 10px;
|
||||||
|
font-size: 24px;
|
||||||
|
background-color: var(--barca-blue);
|
||||||
|
border-radius: 10px;
|
||||||
|
border: 2px solid white;
|
||||||
|
}
|
||||||
@@ -1,56 +1,77 @@
|
|||||||
<!DOCTYPE html>
|
<!DOCTYPE html>
|
||||||
<html lang="pl">
|
<html lang="pl">
|
||||||
|
|
||||||
<head>
|
<head>
|
||||||
<meta charset="UTF-8">
|
<meta charset="UTF-8">
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
||||||
<title>{% block title %}Lewandowski Stats{% endblock %}</title>
|
<title>{% block title %}Lewandowski Stats{% endblock %}</title>
|
||||||
<link rel="stylesheet" href="{{ url_for('static', filename='style.css') }}">
|
<link rel="stylesheet" href="{{ url_for('static', filename='style.css') }}">
|
||||||
<meta property="og:title" content="Robert Lewandowski Stats">
|
<meta property="og:title" content="Robert Lewandowski Stats">
|
||||||
<meta property="og:type" content="website" >
|
<meta property="og:type" content="website">
|
||||||
<meta property="og:url" content="https://lewy.7o7.cx/" >
|
<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: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" content="{{ url_for('static', filename='lewandowski.jpg') }}">
|
||||||
<meta property="og:image:height" content = "143">
|
<meta property="og:image:height" content="143">
|
||||||
<meta property="og:image:width" content = "100">
|
<meta property="og:image:width" content="100">
|
||||||
</head>
|
</head>
|
||||||
|
|
||||||
<body>
|
<body>
|
||||||
<nav>
|
<header class="base-header">
|
||||||
<a href="/">🏠 Strona główna</a> |
|
<nav class="navbar">
|
||||||
<a href="/mecze">📅 Mecze</a> |
|
<a class="logo-link" href="/"><div class="logo-text">Robert Lewandowski</div></a>
|
||||||
<a href="/statystyki">📊 Statystyki</a> |
|
<ul class="nav-links">
|
||||||
<button id="theme-toggle" onclick="toggleTheme()">🌙 / 🌞</button>
|
<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="/club">Kluby</a></li>
|
||||||
|
<li><a href="/representation">Reprezentacja</a></li>
|
||||||
|
<li><a href="/trophies">Trofea</a></li>
|
||||||
|
<li><a href="/compare">Porównaj</a></li>
|
||||||
|
<li><button id="theme-toggle" onclick="toggleTheme()"></button></li>
|
||||||
|
</ul>
|
||||||
|
<div class="hamburger">☰</div>
|
||||||
</nav>
|
</nav>
|
||||||
|
|
||||||
<header>
|
|
||||||
<div class="header-content">
|
<div class="header-content">
|
||||||
<center><img src="{{ url_for('static', filename='lewandowski.jpg') }}" alt="Robert Lewandowski" class="profile-image"></center>
|
<div class="profile-image">
|
||||||
<h1>Statystyki Roberta Lewandowskiego</h1>
|
<img src="{{ url_for('static', filename='lewandowski_no_bg.png') }}" alt="Robert Lewandowski">
|
||||||
|
<div class="profile-image-cover"></div>
|
||||||
</div>
|
</div>
|
||||||
|
<h1>Statystyki <br><span class="header-content-special"> Roberta <br> Lewandowskiego</span></h1>
|
||||||
|
</div>
|
||||||
|
<div></div>
|
||||||
</header>
|
</header>
|
||||||
|
|
||||||
<main>
|
<main>
|
||||||
{% block content %}{% endblock %}
|
{% block content %}{% endblock %}
|
||||||
</main>
|
</main>
|
||||||
|
<script>
|
||||||
|
const hamburger = document.querySelector('.hamburger');
|
||||||
|
const navLinks = document.querySelector('.nav-links');
|
||||||
|
hamburger.addEventListener('click', () => {
|
||||||
|
navLinks.classList.toggle('show');
|
||||||
|
});
|
||||||
|
</script>
|
||||||
<script>
|
<script>
|
||||||
function toggleTheme() {
|
function toggleTheme() {
|
||||||
const currentMode = document.body.classList.contains('dark-mode') ? 'dark' : 'light';
|
const currentMode = document.body.classList.contains('poland-mode') ? 'poland' : 'fcb';
|
||||||
const newMode = currentMode === 'light' ? 'dark' : 'light';
|
const newMode = currentMode === 'fcb' ? 'poland' : 'fcb';
|
||||||
document.body.classList.toggle('dark-mode');
|
document.body.classList.toggle('poland-mode');
|
||||||
localStorage.setItem('theme', newMode);
|
localStorage.setItem('theme', newMode);
|
||||||
}
|
}
|
||||||
|
|
||||||
window.onload = function () {
|
window.onload = function () {
|
||||||
const savedTheme = localStorage.getItem('theme');
|
const savedTheme = localStorage.getItem('theme');
|
||||||
if (savedTheme === 'dark') {
|
if (savedTheme === 'poland') {
|
||||||
document.body.classList.add('dark-mode');
|
document.body.classList.add('poland-mode');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<!--!>Footer<-->
|
<!--!>Footer<-->
|
||||||
<hr style='width: 50%'/>
|
<hr style='width: 50%' />
|
||||||
{% block footer %}{% endblock %}
|
{% block footer %}{% endblock %}
|
||||||
|
|
||||||
</body>
|
</body>
|
||||||
|
|
||||||
</html>
|
</html>
|
||||||
64
FlaskWebProject/FlaskWebProject/templates/club.html
Normal file
@@ -0,0 +1,64 @@
|
|||||||
|
{% extends "base.html" %}
|
||||||
|
|
||||||
|
{% block title %}Strona Główna{% endblock %}
|
||||||
|
|
||||||
|
{% block content %}
|
||||||
|
<section class="choose-club">
|
||||||
|
<a href="{{ url_for('clubs', club='FC Barcelona') }}">
|
||||||
|
<button><img src="{{ url_for('static', filename='FC_Barcelona.png') }}"></button>
|
||||||
|
</a>
|
||||||
|
<a href="{{ url_for('clubs', club='Bayern Monachium') }}">
|
||||||
|
<button><img src="{{ url_for('static', filename='FC_Bayern.png') }}"></button>
|
||||||
|
</a>
|
||||||
|
<a href="{{ url_for('clubs', club='Borussia Dortmund') }}">
|
||||||
|
<button><img src="{{ url_for('static', filename='Borussia_Dortmund.png') }}"></button>
|
||||||
|
</a>
|
||||||
|
<!--Jak nie będzie statysytk dla lecha to usunać-->
|
||||||
|
<a href="{{ url_for('clubs', club='Lech Poznan') }}">
|
||||||
|
<button><img src="{{ url_for('static', filename='Lech_Poznan.png') }}"></button>
|
||||||
|
</a>
|
||||||
|
</section>
|
||||||
|
|
||||||
|
<!-- Wyświetlanie danych tylko dla wybranego klubu -->
|
||||||
|
{% for stats in clubs %}
|
||||||
|
{% if stats.club == selected_club %}
|
||||||
|
<section class="club-stats">
|
||||||
|
<h2>Statystyki dla {{selected_club}}</h2>
|
||||||
|
<div class="wybrany{{selected_club}}"></div>
|
||||||
|
<div class="club-stats-grid">
|
||||||
|
<div class="stat-box">
|
||||||
|
<p>Gole:</p> <span class="stat-box-special"> {{ stats.goals }} </span>
|
||||||
|
</div>
|
||||||
|
<div class="stat-box">
|
||||||
|
<p>Asysty:</p> <span class="stat-box-special"> {{ stats.assist }} </span>
|
||||||
|
</div>
|
||||||
|
<div class="stat-box">
|
||||||
|
<p>Występy:</p> <span class="stat-box-special"> {{ stats.goals }} </span>
|
||||||
|
</div>
|
||||||
|
<div class="stat-box">
|
||||||
|
<p>Łączny czas gry:</p> <span class="stat-box-special"> {{ stats.goals }}</span>
|
||||||
|
</div>
|
||||||
|
<div class="stat-box">
|
||||||
|
<p>Hat-tricki:</p> <span class="stat-box-special"> {{ stats.goals }}</span>
|
||||||
|
</div>
|
||||||
|
<div class="stat-box">
|
||||||
|
<p>Zwycięstwa:</p> <span class="stat-box-special"> {{ stats.goals }}</span>
|
||||||
|
</div>
|
||||||
|
<div class="stat-box">
|
||||||
|
<p>Porażki:</p> <span class="stat-box-special"> {{ stats.goals }}</span>
|
||||||
|
</div>
|
||||||
|
<div class="stat-box">
|
||||||
|
<p>Żółte kartki:</p> <span class="stat-box-special"> {{ stats.goals }}</span>
|
||||||
|
</div>
|
||||||
|
<div class="stat-box">
|
||||||
|
<p>Czerwone kartki:</p> <span class="stat-box-special"> {{ stats.goals }}</span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</section>
|
||||||
|
{% endif %}
|
||||||
|
{% endfor %}
|
||||||
|
{% endblock %}
|
||||||
|
|
||||||
|
{% block footer %}
|
||||||
|
{{ commit_in_html | safe }}
|
||||||
|
{% endblock %}
|
||||||
68
FlaskWebProject/FlaskWebProject/templates/compare.html
Normal file
@@ -0,0 +1,68 @@
|
|||||||
|
{% extends "base.html" %}
|
||||||
|
|
||||||
|
{% block title %}Statystyki{% endblock %}
|
||||||
|
|
||||||
|
{% block content %}
|
||||||
|
<select onchange="location = this.value;">
|
||||||
|
<option disabled selected>Wybierz zawodnika</option>
|
||||||
|
<option value="{{ url_for('compare', player='Leo Messi') }}">Leo Messi</option>
|
||||||
|
<option value="{{ url_for('compare', player='Ronaldo') }}">Cristiano Ronaldo</option>
|
||||||
|
<option value="{{ url_for('compare', player='Neymar') }}">Neymar</option>
|
||||||
|
</select>
|
||||||
|
|
||||||
|
{%for player in player2 %}
|
||||||
|
{% if player.name == selected_player %}
|
||||||
|
<section class="section-stats">
|
||||||
|
<h2>Gole</h2>
|
||||||
|
<div class="stats">
|
||||||
|
<div class="stat-box">
|
||||||
|
<h3>{{ all_time_stats.goals }}</h3>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
<div class="stat-box">
|
||||||
|
<h3>{{ player.goals}}</h3>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
|
||||||
|
<h2>Asysty</h2>
|
||||||
|
<div class="stats">
|
||||||
|
<div class="stat-box">
|
||||||
|
<h3>{{ all_time_stats.assists }}</h3>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
<div class="stat-box">
|
||||||
|
<h3>{{ player.assists}}</h3>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<h2>Wystąpienia</h2>
|
||||||
|
<div class="stats">
|
||||||
|
<div class="stat-box">
|
||||||
|
<h3>{{ all_time_stats.assists }}</h3>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
<div class="stat-box">
|
||||||
|
<h3>{{ player.assists}}</h3>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<h2>Minuty zagrane</h2>
|
||||||
|
<div class="stats">
|
||||||
|
<div class="stat-box">
|
||||||
|
<h3>{{ all_time_stats.assists }}</h3>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
<div class="stat-box">
|
||||||
|
<h3>{{ player.assists}}</h3>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</section>
|
||||||
|
{% endif %}
|
||||||
|
{% endfor%}
|
||||||
|
|
||||||
|
{% endblock %}
|
||||||
@@ -3,13 +3,56 @@
|
|||||||
{% block title %}Strona Główna{% endblock %}
|
{% block title %}Strona Główna{% endblock %}
|
||||||
|
|
||||||
{% block content %}
|
{% block content %}
|
||||||
<h2>Witaj na stronie poświęconej statystykom Roberta Lewandowskiego!</h2>
|
<div class="main-index">
|
||||||
<p>Tu znajdziesz najnowsze informacje o meczach, golach, asystach i innych statystykach.</p>
|
<h2>Witaj na stronie poświęconej <br> statystykom Roberta Lewandowskiego!</h2>
|
||||||
<div>
|
<p>Tu znajdziesz najnowsze informacje o meczach, golach, asystach i innych statystykach.</p>
|
||||||
<h3>Ogólne statystyki:</h3>
|
<section class="about-section">
|
||||||
<p>Gole: {{ goals }}</p>
|
<article class="article__how-it-works">
|
||||||
<p>Asysty: {{ assists }}</p>
|
<h3>Jak to działa?</h3>
|
||||||
<p>Liczba meczów: {{ matches }}</p>
|
<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="/club">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>
|
</div>
|
||||||
{% endblock %}
|
{% endblock %}
|
||||||
|
|
||||||
|
|||||||
@@ -3,8 +3,21 @@
|
|||||||
{% block title %}Lista meczów{% endblock %}
|
{% block title %}Lista meczów{% endblock %}
|
||||||
|
|
||||||
{% block content %}
|
{% block content %}
|
||||||
<h2>📅 Mecze Roberta</h2>
|
<select>
|
||||||
<table>
|
<option disabled selected>Wybierz rok</option>
|
||||||
|
<option value="{{ url_for('compare', player='Leo Messi') }}">2024/2025</option>
|
||||||
|
<option value="{{ url_for('compare', player='Ronaldo') }}">2023/2024</option>
|
||||||
|
<option value="{{ url_for('compare', player='Neymar') }}">2022/2023</option>
|
||||||
|
<option value="{{ url_for('compare', player='Neymar') }}">2021/2022</option>
|
||||||
|
<option value="{{ url_for('compare', player='Neymar') }}">2020/2021</option>
|
||||||
|
<option value="{{ url_for('compare', player='Neymar') }}">2019/2020</option>
|
||||||
|
<option value="{{ url_for('compare', player='Neymar') }}">2018/2019</option>
|
||||||
|
<option value="{{ url_for('compare', player='Neymar') }}">2017/2018</option>
|
||||||
|
<option value="{{ url_for('compare', player='Neymar') }}">2016/2017</option>
|
||||||
|
</select>
|
||||||
|
<section class="section__matches">
|
||||||
|
<h2>📅 Mecze Roberta</h2>
|
||||||
|
<table>
|
||||||
<tr>
|
<tr>
|
||||||
<th>Data</th>
|
<th>Data</th>
|
||||||
<th>Przeciwnik</th>
|
<th>Przeciwnik</th>
|
||||||
@@ -21,5 +34,6 @@
|
|||||||
<td>{{ match.minutes }}</td>
|
<td>{{ match.minutes }}</td>
|
||||||
</tr>
|
</tr>
|
||||||
{% endfor %}
|
{% endfor %}
|
||||||
</table>
|
</table>
|
||||||
|
</section>
|
||||||
{% endblock %}
|
{% endblock %}
|
||||||
|
|||||||
@@ -0,0 +1,39 @@
|
|||||||
|
{% extends "base.html" %}
|
||||||
|
|
||||||
|
{% block title %}Statystyki{% endblock %}
|
||||||
|
|
||||||
|
{% block content %}
|
||||||
|
<section class="club-stats club-stats-poland">
|
||||||
|
<h2>Statystyki w reprezentacji Polski</h2>
|
||||||
|
<div class="wybrany{{selected_club}}"></div>
|
||||||
|
<div class="club-stats-grid">
|
||||||
|
<div class="stat-box">
|
||||||
|
<p>Gole:</p> <span class="stat-box-special"> {{ nation_stats.goals }} </span>
|
||||||
|
</div>
|
||||||
|
<div class="stat-box">
|
||||||
|
<p>Asysty:</p> <span class="stat-box-special"> {{ nation_stats.assist }} </span>
|
||||||
|
</div>
|
||||||
|
<div class="stat-box">
|
||||||
|
<p>Występy:</p> <span class="stat-box-special"> {{ nation_stats.goals }} </span>
|
||||||
|
</div>
|
||||||
|
<div class="stat-box">
|
||||||
|
<p>Łączny czas gry:</p> <span class="stat-box-special"> {{ nation_stats.goals }}</span>
|
||||||
|
</div>
|
||||||
|
<div class="stat-box">
|
||||||
|
<p>Hat-tricki:</p> <span class="stat-box-special"> {{ nation_stats.goals }}</span>
|
||||||
|
</div>
|
||||||
|
<div class="stat-box">
|
||||||
|
<p>Zwycięstwa:</p> <span class="stat-box-special"> {{ nation_stats.goals }}</span>
|
||||||
|
</div>
|
||||||
|
<div class="stat-box">
|
||||||
|
<p>Porażki:</p> <span class="stat-box-special"> {{ nation_stats.goals }}</span>
|
||||||
|
</div>
|
||||||
|
<div class="stat-box">
|
||||||
|
<p>Żółte kartki:</p> <span class="stat-box-special"> {{ nation_stats.goals }}</span>
|
||||||
|
</div>
|
||||||
|
<div class="stat-box">
|
||||||
|
<p>Czerwone kartki:</p> <span class="stat-box-special"> {{ nation_stats.goals }}</span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</section>
|
||||||
|
{% endblock %}
|
||||||
@@ -3,10 +3,104 @@
|
|||||||
{% block title %}Statystyki{% endblock %}
|
{% block title %}Statystyki{% endblock %}
|
||||||
|
|
||||||
{% block content %}
|
{% block content %}
|
||||||
<h2>Statystyki Roberta Lewandowskiego</h2>
|
<div class="section-stats-center">
|
||||||
<ul>
|
|
||||||
<li>Gole: {{ stats.goals }}</li>
|
<section class="section-stats">
|
||||||
<li>Asysty: {{ stats.assists }}</li>
|
<h2>Ogólne statystyki</h2>
|
||||||
<li>Mecze: {{ stats.matches }}</li>
|
<div class="stats">
|
||||||
</ul>
|
<div class="stat-box">
|
||||||
|
<h3>{{ all_time_stats.goals }}</h3>
|
||||||
|
<p>Gole</p>
|
||||||
|
</div>
|
||||||
|
<div class="stat-box">
|
||||||
|
<h3>{{ all_time_stats.assists }}</h3>
|
||||||
|
<p>Asysty</p>
|
||||||
|
</div>
|
||||||
|
<div class="stat-box">
|
||||||
|
<h3>{{ all_time_stats.matches }}</h3>
|
||||||
|
<p>Występy</p>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</section>
|
||||||
|
<section class="section-stats">
|
||||||
|
<h2>Klubowe statystyki</h2>
|
||||||
|
<div class="stats">
|
||||||
|
<div class="stat-box">
|
||||||
|
<h3>{{ club_stats.goals }}</h3>
|
||||||
|
<p>Gole</p>
|
||||||
|
</div>
|
||||||
|
<div class="stat-box">
|
||||||
|
<h3>{{ club_stats.assists }}</h3>
|
||||||
|
<p>Asysty</p>
|
||||||
|
</div>
|
||||||
|
<div class="stat-box">
|
||||||
|
<h3>{{ club_stats.matches }}</h3>
|
||||||
|
<p>Występy</p>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</section>
|
||||||
|
<section class="section-stats">
|
||||||
|
<h2>Reprezentacja statystyki</h2>
|
||||||
|
<div class="stats">
|
||||||
|
<div class="stat-box">
|
||||||
|
<h3>{{ nation_stats.goals }}</h3>
|
||||||
|
<p>Gole</p>
|
||||||
|
</div>
|
||||||
|
<div class="stat-box">
|
||||||
|
<h3>{{ nation_stats.assists }}</h3>
|
||||||
|
<p>Asysty</p>
|
||||||
|
</div>
|
||||||
|
<div class="stat-box">
|
||||||
|
<h3>{{ nation_stats.matches }}</h3>
|
||||||
|
<p>Występy</p>
|
||||||
|
</div>
|
||||||
|
</section>
|
||||||
|
<section class="section-stats">
|
||||||
|
<h2>Mistrzostwa świata</h2>
|
||||||
|
<div class="stats">
|
||||||
|
<div class="stat-box">
|
||||||
|
<h3>{{ worldcup.goals }}</h3>
|
||||||
|
<p>Gole</p>
|
||||||
|
</div>
|
||||||
|
<div class="stat-box">
|
||||||
|
<h3>{{ worldcup.assists }}</h3>
|
||||||
|
<p>Asysty</p>
|
||||||
|
</div>
|
||||||
|
<div class="stat-box">
|
||||||
|
<h3>{{ worldcup.matches }}</h3>
|
||||||
|
<p>Występy</p>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</section>
|
||||||
|
<section class="section-stats">
|
||||||
|
<h2>EURO</h2>
|
||||||
|
<div class="stats">
|
||||||
|
<div class="stat-box">
|
||||||
|
<h3>{{ euro.goals }}</h3>
|
||||||
|
<p>Gole</p>
|
||||||
|
</div>
|
||||||
|
<div class="stat-box">
|
||||||
|
<h3>{{ euro.assists }}</h3>
|
||||||
|
<p>Asysty</p>
|
||||||
|
</div>
|
||||||
|
<div class="stat-box">
|
||||||
|
<h3>{{ euro.matches }}</h3>
|
||||||
|
<p>Występy</p>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</section>
|
||||||
|
<section class="section-stats">
|
||||||
|
<h2>Kartki</h2>
|
||||||
|
<div class="stats">
|
||||||
|
<div class="stat-box">
|
||||||
|
<h3>{{ cards.yellow }}</h3>
|
||||||
|
<p>Żółte</p>
|
||||||
|
</div>
|
||||||
|
<div class="stat-box">
|
||||||
|
<h3>{{ cards.red }}</h3>
|
||||||
|
<p>Czerwone</p>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</section>
|
||||||
{% endblock %}
|
{% endblock %}
|
||||||
28
FlaskWebProject/FlaskWebProject/templates/trophies.html
Normal file
@@ -0,0 +1,28 @@
|
|||||||
|
{% extends "base.html" %}
|
||||||
|
|
||||||
|
{% block title %}Statystyki{% endblock %}
|
||||||
|
|
||||||
|
{% block content %}
|
||||||
|
<section class="section__matches">
|
||||||
|
<h2>📅 Trofea</h2>
|
||||||
|
<table>
|
||||||
|
<tr>
|
||||||
|
<th>Nazwa</th>
|
||||||
|
<th>Data/Sezon</th>
|
||||||
|
</tr>
|
||||||
|
{% for trophy in trophy %}
|
||||||
|
|
||||||
|
<tr>
|
||||||
|
<td>{{ trophy.name }}</td>
|
||||||
|
{% if trophy.year == NULL %}
|
||||||
|
<td>{{ trophy.sezon }}</td>
|
||||||
|
{% endif %}
|
||||||
|
{% if trophy.sezon == NULL %}
|
||||||
|
<td>{{ trophy.year }}</td>
|
||||||
|
{% endif %}
|
||||||
|
</tr>
|
||||||
|
{% endfor %}
|
||||||
|
</table>
|
||||||
|
</section>
|
||||||
|
|
||||||
|
{% endblock %}
|
||||||