Przejdź do zawartości

Moduł:Wyniki rund

Z Wikipedii, wolnej encyklopedii
 Dokumentacja modułu [zobacz] [edytuj] [historia] [odśwież]

To moduł do generowania wyników meczów dla serii sportowych, takich jak dwumecz. Moduł może obsługiwać pojedyncze mecze do nieograniczonej liczby meczów. Chociaż został zaprojektowany dla piłki nożnej, można go używać w przypadku dowolnego sportu, w którym występuje seria między drużynami.

Użycie

[edytuj kod]

W najprostszej formie do utworzenia tabeli potrzeba tylko kilku parametrów.

{{#invoke:Wyniki rund|main|flag=n
|pierwszy klub|wynik|drugi klub|wynik pierwszego meczu|wynik drugiego meczu
}}
{{#invoke:Wyniki rund|main
|pierwszy klub|flaga|wynik|drugi klub|flaga|wynik pierwszego meczu|wynik drugiego meczu
}}

Poniżej znajduje się lista parametrów szablonu. Wszystkie parametry są opcjonalne.

Parametr Opis Typ Domyślny
flag Przy ustawieniu wartości na {n,no,0,false}, tabela nie wyświetla flag. tekst
legs Określa liczbę meczów, które będą wyświetlane w tabeli. Przy ustawieniu wartości na {n,no,0,false}, tabela nie wyświetli żadnych meczów i zostanie sformatowana w celu wyświetlania wyniku w jednym meczu.

Przykład 1

[edytuj kod]
Użycie
{{#invoke:Wyniki rund|main|legs=5
|[[Arsenal F.C.|Arsenal]]|ENG|6–8|[[FC Bayern Munich|Bayern Munich]]|GER|2–2|0–1|2–2|0–1|2–2
|[[Atlético Madrid]]|ESP|10–11|[[Borussia Dortmund]]|GER|2–1|2–4|2–1|2–4|2–1
|[[Real Madrid CF|Real Madrid]]|ESP|11–11 (4–3 k)|[[Manchester City F.C.|Manchester City]]|ENG|3–3|1–1|3–3|1–1|3–3 (dogr)
|[[Paris Saint-Germain F.C.|Paris Saint-Germain]]|FRA|14–11|[[FC Barcelona|Barcelona]]|ESP|2–3|4–1|2–3|4–1|2–3
}}
Wynik
Drużyna 1Agg.Tooltip Aggregate scoreDrużyna 2Pierwszy
mecz
Drugi
mecz
Trzeci
mecz
Czwarty
mecz
Piąty
mecz
Arsenal Anglia6–8Niemcy Bayern Munich2–20–12–20–12–2
Atlético Madrid Hiszpania10–11Niemcy Borussia Dortmund2–12–42–12–42–1
Real Madrid Hiszpania11–11 (4–3 k.)Anglia Manchester City3–31–13–31–13–3 (dogr.)
Paris Saint-Germain Francja14–11Hiszpania Barcelona2–34–12–34–12–3

Przykład 2

[edytuj kod]
Użycie
{{#invoke:Wyniki rund|main|legs=n
|[[Arsenal F.C.|Arsenal]]|ENG|2–3|[[FC Bayern Munich|Bayern Munich]]|GER
|[[Atlético Madrid]]|ESP|4–5|[[Borussia Dortmund]]|GER
|[[Real Madrid CF|Real Madrid]]|ESP|4–4 (d) (4–3 k)|[[Manchester City F.C.|Manchester City]]|ENG
|[[Paris Saint-Germain F.C.|Paris Saint-Germain]]|FRA|6–4|[[FC Barcelona|Barcelona]]|ESP
}}
Wynik
Drużyna 1WynikDrużyna 2
Arsenal Anglia2–3Niemcy Bayern Munich
Atlético Madrid Hiszpania4–5Niemcy Borussia Dortmund
Real Madrid Hiszpania4–4 (dogr.) (4–3 k.)Anglia Manchester City
Paris Saint-Germain Francja6–4Hiszpania Barcelona
liczba 2
bold_winner Aby wyłączyć, należy ustawić wartość {n,no,0,false}. Moduł automatycznie pogrubia zwycięską drużynę w meczu. Pierwszy priorytet ma zwycięska drużyna z wynikiem podanym w nawiasach (co jest używane do oznaczania wyników rzutów karnych). W przeciwnym razie zostanie użyty wynik regularny. Jeśli łączna liczba punktów jest taka sama dla dwumeczów i nie podano wyniku rzutów karnych, w celu określenia zwycięskiej drużyny zostanie zastosowana zasada bramek na wyjeździe |away_goals= (chyba że użyto jej do wyłączenia tej funkcji). We wszystkich innych przypadkach, jeśli nie można określić zwycięzcy na podstawie danych wejściowych, żadna z drużyn w danym meczu nie zostanie pogrubiona. tekst {y,yes,1,true}
color_winner Aby włączyć, należy ustawić wartość {y,yes,1,true}. Automatycznie nadaje zwycięskiej drużynie kolor tła zielony (#BBF3BB). Pierwszy priorytet ma zwycięska drużyna wyniku wymienionego w nawiasach (co jest używane do oznaczania wyniku rzutów karnych). W przeciwnym razie zostanie użyty wynik regularny. Jeśli łączna liczba punktów jest taka sama dla dwumeczów i nie podano wyników rzutów karnych, w celu określenia zwycięskiej drużyny zostanie zastosowana zasada bramek na wyjeździe |away_goals= (chyba że użyto jej do wyłączenia tej funkcji). We wszystkich innych przypadkach, jeśli nie można określić zwycięzcy na podstawie danych wejściowych, żadna z drużyn nie zostanie pokolorowana. Gdy ten parametr jest włączony w przypadku remisów w jednym meczu, komórka wyniku automatycznie otrzyma tło w kolorze żółtym (#FFFFBB) . tekst {n,no,0,false}
matches_style Gdy ustawiony jest FBR dla rywalizacji w jednym meczu, automatycznie zmienia kolor tła komórek wyników na podstawie wyniku meczu.

Zwycięstwa gospodarzy są wyświetlane na zielono (#BBF3BB), remisy na żółto (#FFFFBB), a wygrane gości na czerwono (#FFBBBB). Legenda kolorów zostanie również dodana poniżej tabeli, a nagłówki kolumn drużyn zostaną zmienione na „Dom” i „Wyjazd” (jak zrobiono z |h_a=, co czyni ten parametr zbędnym, gdy FBR jest włączony). Działa to podobnie jak w Moduł:Wyniki sportowe.

tekst
solid_cell Przy ustawieniu wartości na {y,yes,1,true} wszystkie komórki o wartości null otrzymają kolor tła w kolorze szarym (#BBBBBB) . tekst {n,no,0,false}
small_text Moduł automatycznie generuje mały tekst dla meczów (lub kolumnę wyników dla pojedynczych remisów), gdy nie ma wyniku meczu. Ma to na celu umożliwienie prawidłowego formatowania przyszłych meczów, które zazwyczaj zawierają datę spotkania w zmniejszonym rozmiarze czcionki. tekst {y,yes,1,true}
collapsed Aby włączyć, należy ustawić wartość na {y,yes,1,true}. Jeśli ustawione, tabela zostanie zwinięta przy użyciu mw-collapsed . W rezultacie tabela zostanie rozciągnięta na całą szerokość strony.

Przykład 3

[edytuj kod]
Użycie
{{#invoke:Wyniki rund|main|collapsed=y
|[[Arsenal F.C.|Arsenal]]|ENG|2–3|[[FC Bayern Munich|Bayern Munich]]|GER|2–2|0–1
|[[Atlético Madrid]]|ESP|4–5|[[Borussia Dortmund]]|GER|2–1|2–4
}}
Wynik
Drużyna 1Agg.Tooltip Aggregate scoreDrużyna 2Pierwszy
mecz
Drugi
mecz
Arsenal Anglia2–3Niemcy Bayern Munich2–20–1
Atlético Madrid Hiszpania4–5Niemcy Borussia Dortmund2–12–4
tekst {n,no,0,false}
center_table Przy ustawieniu wartości na {y,yes,1,true}, tabela jest centrowana w poziomie na stronie. Nie działa, jeśli |collapsed jest ustawione. tekst
caption Dodaje podpis do tabeli.

Przykład 4

[edytuj kod]
Użycie
{{#invoke:Wyniki rund|main|caption=To jest podpis
|[[Arsenal F.C.|Arsenal]]|ENG|2–3|[[FC Bayern Munich|Bayern Munich]]|GER|2–2|0–1
|[[Atlético Madrid]]|ESP|4–5|[[Borussia Dortmund]]|GER|2–1|2–4
}}
Wynik
To jest podpis
Drużyna 1Agg.Tooltip Aggregate scoreDrużyna 2Pierwszy
mecz
Drugi
mecz
Arsenal Anglia2–3Niemcy Bayern Munich2–20–1
Atlético Madrid Hiszpania4–5Niemcy Borussia Dortmund2–12–4
tekst
title Dodaje tytuł do tabeli w formie nagłówka tabeli obejmującego wszystkie kolumny i umieszczonego nad standardowymi nagłówkami kolumn.

Przykład 5

[edytuj kod]
Użycie
{{#invoke:Wyniki rund|main|title=To jest tytuł
|[[Arsenal F.C.|Arsenal]]|ENG|2–3|[[FC Bayern Munich|Bayern Munich]]|GER|2–2|0–1
|[[Atlético Madrid]]|ESP|4–5|[[Borussia Dortmund]]|GER|2–1|2–4
}}
Wynik
To jest tytuł
Drużyna 1Agg.Tooltip Aggregate scoreDrużyna 2Pierwszy
mecz
Drugi
mecz
Arsenal Anglia2–3Niemcy Bayern Munich2–20–1
Atlético Madrid Hiszpania4–5Niemcy Borussia Dortmund2–12–4
tekst
id Dodaje kotwicę na górze tabeli, która umożliwia bezpośrednie linkowanie do tabeli. tekst
section Umożliwia nadanie tabeli niestandardowej nazwy na potrzeby transkluzji. ​​Jest to przydatne, gdy na tej samej stronie w tagach transkluzji <onlyinclude>...</onlyinclude> znajduje się wiele wystąpień tego modułu, co umożliwia selektywne wywoływanie określonych tabel na innej stronie.

Na przykład, jeżeli artykuł „Przykład” ma ten moduł umieszczony pomiędzy tagami <onlyinclude>...</onlyinclude>, to tabelę tą z |section=1runda można dołączyć do innych artykułów za pomocą {{:Przykład|transcludesection=1runda}} lub {{Przykład|transcludesection=1runda}}.

tekst
first_row Na potrzeby transkluzji ustawia pierwszy rekord tabeli. liczba
last_row Na potrzeby transkluzji ustawia ostatni rekord tabeli. liczba
show_country Po ustawieniu na kod kraju, tylko wiersze zawierające drużynę z towarzyszącym kodem kraju będą wyświetlane w końcowym wyniku.

Przykład 6

[edytuj kod]
Użycie
{{#invoke:Wyniki rund|main|show_country=ENG
|[[Arsenal F.C.|Arsenal]]|ENG|2–3|[[FC Bayern Munich|Bayern Munich]]|GER|2–2|0–1
|[[Atlético Madrid]]|ESP|4–5|[[Borussia Dortmund]]|GER|2–1|2–4
|[[Real Madrid CF|Real Madrid]]|ESP|4–4 (4–3 k)|[[Manchester City F.C.|Manchester City]]|ENG|3–3|1–1 (dogr)
|[[Paris Saint-Germain F.C.|Paris Saint-Germain]]|FRA|6–4|[[FC Barcelona|Barcelona]]|ESP|2–3|4–1
}}
Wynik
Drużyna 1Agg.Tooltip Aggregate scoreDrużyna 2Pierwszy
mecz
Drugi
mecz
Arsenal Anglia2–3Niemcy Bayern Munich2–20–1
Real Madrid Hiszpania4–4 (4–3 k.)Anglia Manchester City3–31–1 (dogr.)
tekst
fill_blanks Przy ustawieniu wartości na {y,yes,1,true} dodaje symbol zastępczy flagi obok nazwy zespołu, gdy parametry flagi są obecne w tabeli, ale parametr dla danego zespołu jest pusty. Nie będzie to miało wpływu, jeśli |flag=false. tekst {n,no,0,false}
nowrap Przy ustawieniu wartości na {y,yes,1,true} dodaje wartość nowrap do stylu tabeli. tekst {n,no,0,false}
font_size Zmienia rozmiar czcionki tabeli na zadany procent. Znak procentu jest opcjonalny. Ze względu na dostępność, wartości mniejsze niż 85% zostaną przekonwertowane na 85%. liczba 100
team_width Ustawia wartość dla szerokości dwóch kolumn zespołu. liczba 250
score_width Ustawia wartość dla szerokości kolumn wyników. liczba 80
away_goals Przy ustawieniu wartości na {n,no,0,false}, moduł nie zastosuje reguły bramek wyjazdowych w przypadku dwumeczów, w których łączny wynik jest równy. W przeciwnym razie moduł domyślnie użyje reguły bramek wyjazdowych, aby wyłonić zwycięzcę. tekst {y,yes,1,true}
team1 Dodaje niestandardowy nagłówek dla pierwszej kolumny zespołu. tekst Drużyna 1
team2 Dodaje niestandardowy nagłówek dla drugiej kolumny zespołu. tekst Drużyna 2
h_a Przy ustawieniu wartości na {y,yes,1,true}. Zmienia domyślne nagłówki kolumn dla drużyn na Gospodarz i Gość. Jeśli |team1= i/lub |team2= jest ustawione, parametry te zastąpią nagłówki ustawione przez |h_a=. tekst
aggregate Dodaje niestandardowy nagłówek dla kolumny z wynikiem łącznym. tekst Wynik
legN Dodaje niestandardowy nagłówek dla kolumny N-tej (np. |leg1= dla kolumny pierwszej, |leg3= dla kolumny trzeciej itd.). Domyślnie jest to <ordinal> mecz (np. Pierwszy mecz dla kolumny pierwszej, Trzeci mecz dla kolumny trzeciej itd.).

Przykład 7

[edytuj kod]
Użycie
{{#invoke:Wyniki rund|main|leg1=Game 1|leg2=Second Leg
|[[Arsenal F.C.|Arsenal]]|ENG|2–3|[[FC Bayern Munich|Bayern Munich]]|GER|2–2|0–1
|[[Atlético Madrid]]|ESP|4–5|[[Borussia Dortmund]]|GER|2–1|2–4
|[[Real Madrid CF|Real Madrid]]|ESP|4–4 (4–3 k)|[[Manchester City F.C.|Manchester City]]|ENG|3–3|1–1 (dogr)
|[[Paris Saint-Germain F.C.|Paris Saint-Germain]]|FRA|6–4|[[FC Barcelona|Barcelona]]|ESP|2–3|4–1
}}
Wynik
Drużyna 1Agg.Tooltip Aggregate scoreDrużyna 2Pierwszy
mecz
Drugi
mecz
Arsenal Anglia2–3Niemcy Bayern Munich2–20–1
Atlético Madrid Hiszpania4–5Niemcy Borussia Dortmund2–12–4
Real Madrid Hiszpania4–4 (4–3 k.)Anglia Manchester City3–31–1 (dogr.)
Paris Saint-Germain Francja6–4Hiszpania Barcelona2–34–1
tekst <ordinal> mecz
leg_prefix Zmienia format nagłówków kolumn wyników z <ordinal> mecz na <leg_prefix> N. Dowolny ciąg można określić za pomocą parametru, aby dodać go jako niestandardowy prefiks. Po ustawieniu wartości parametru na {y,yes,1,true} format nagłówków będzie domyślnie ustawione na Mecz N. Jeśli |legN= jest ustawione, zastąpi on nagłówek kolumny wyników meczu N, zastępując niestandardowy prefiks.

Przykład 8

[edytuj kod]
Użycie
{{#invoke:Wyniki rund|main|flag=n|legs=7|leg_prefix=Game|aggregate=Series
|[[Golden State Warriors]]|3–4|[[Cleveland Cavaliers]]|104–89|110–77|90–120|108–97|97–112|101–115|89–93
}}
Wynik
Drużyna 1SeriesDrużyna 2Game 1Game 2Game 3Game 4Game 5Game 6Game 7
Golden State Warriors3–4Cleveland Cavaliers104–89110–7790–120108–9797–112101–11589–93

Przykład 9

[edytuj kod]
Użycie
{{#invoke:Wyniki rund|main|leg_prefix=y
|[[Arsenal F.C.|Arsenal]]|ENG|2–3|[[FC Bayern Munich|Bayern Munich]]|GER|2–2|0–1
|[[Atlético Madrid]]|ESP|4–5|[[Borussia Dortmund]]|GER|2–1|2–4
|[[Real Madrid CF|Real Madrid]]|ESP|4–4 (4–3 k)|[[Manchester City F.C.|Manchester City]]|ENG|3–3|1–1 (dogr)
|[[Paris Saint-Germain F.C.|Paris Saint-Germain]]|FRA|6–4|[[FC Barcelona|Barcelona]]|ESP|2–3|4–1
}}
Wynik
Drużyna 1Agg.Tooltip Aggregate scoreDrużyna 2Mecz 1Mecz 2
Arsenal Anglia2–3Niemcy Bayern Munich2–20–1
Atlético Madrid Hiszpania4–5Niemcy Borussia Dortmund2–12–4
Real Madrid Hiszpania4–4 (4–3 k.)Anglia Manchester City3–31–1 (dogr.)
Paris Saint-Germain Francja6–4Hiszpania Barcelona2–34–1
tekst <ordinal> mecz
leg_suffix Dodaje niestandardowy sufiks po liczbie porządkowej dla nagłówków kolumn wyników meczów. Jeśli legN jest ustawione, zastąpi on nagłówek kolumny N z niestandardowym sufiksen. Ponadto |leg_prefix= ma pierwszeństwo przed |leg_suffix=.

Przykład 10

[edytuj kod]
Użycie
{{#invoke:Wyniki rund|main|leg_suffix=match
|[[Arsenal F.C.|Arsenal]]|ENG|2–3|[[FC Bayern Munich|Bayern Munich]]|GER|2–2|0–1
|[[Atlético Madrid]]|ESP|4–5|[[Borussia Dortmund]]|GER|2–1|2–4
|[[Real Madrid CF|Real Madrid]]|ESP|4–4 (4–3 k)|[[Manchester City F.C.|Manchester City]]|ENG|3–3|1–1 (dogr)
|[[Paris Saint-Germain F.C.|Paris Saint-Germain]]|FRA|6–4|[[FC Barcelona|Barcelona]]|ESP|2–3|4–1
}}
Wynik
Drużyna 1Agg.Tooltip Aggregate scoreDrużyna 2Pierwszy
match
Drugi
match
Arsenal Anglia2–3Niemcy Bayern Munich2–20–1
Atlético Madrid Hiszpania4–5Niemcy Borussia Dortmund2–12–4
Real Madrid Hiszpania4–4 (4–3 k.)Anglia Manchester City3–31–1 (dogr.)
Paris Saint-Germain Francja6–4Hiszpania Barcelona2–34–1
tekst mecz
headingN Dodaje niestandardowy nagłówek obejmujący wszystkie kolumny powyżej N-tego wiersza tabeli (np. |heading1= powyżej pierwszego wiersza, |heading20= powyżej dwudziestego wiersza itd.).

Przykład 11

[edytuj kod]
Użycie
{{#invoke:Wyniki rund|main|nowrap=y|legs=n|h_a=y|heading1=Półfinał|heading3=Finał
|[[Reprezentacja Polski w piłce nożnej mężczyzn|Polska]]|POL|5–1|[[Reprezentacja Estonii w piłce nożnej mężczyzn|Estonia]]|EST
|[[Reprezentacja Walii w piłce nożnej mężczyzn|Walia]]|WAL|4–1|[[Reprezentacja Finlandii w piłce nożnej mężczyzn|Finlandia]]|FIN
|[[Reprezentacja Walii w piłce nożnej mężczyzn|Walia]]|WAL|0–0 (dogr) (4-5 k)|[[Reprezentacja Polski w piłce nożnej mężczyzn|Polska]]|POL
}}
Wynik
GospodarzWynikGość
Półfinał
Polska Polska5–1Estonia Estonia
Walia Walia4–1Finlandia Finlandia
Finał
Walia Walia0–0 (dogr.) (4–5 k.)Polska Polska
tekst
note_agg_N Tworzy przypis dla wyniku N-tego wiersza tabeli. Parametr może zawierać albo zawartość notatki, albo odwołanie do innej notatki.

Przykład 12

[edytuj kod]
Użycie
{{#invoke:Wyniki rund|main|nowrap=y|legs=n
|[[Arsenal F.C.|Arsenal]]|ENG|2–3|[[FC Bayern Munich|Bayern Munich]]|GER
|[[Atlético Madrid]]|ESP|4–5|[[Borussia Dortmund]]|GER
|[[Real Madrid CF|Real Madrid]]|ESP|4–4 (4–3 k)|[[Manchester City F.C.|Manchester City]]|ENG
|[[Paris Saint-Germain F.C.|Paris Saint-Germain]]|FRA|6–4|[[FC Barcelona|Barcelona]]|ESP

|note_agg_1=Mecz rozgrywany bez kibiców.
|note_agg_4=agg_1
}}
Wynik
Drużyna 1WynikDrużyna 2
Arsenal Anglia2–3[i]Niemcy Bayern Munich
Atlético Madrid Hiszpania4–5Niemcy Borussia Dortmund
Real Madrid Hiszpania4–4 (4–3 k.)Anglia Manchester City
Paris Saint-Germain Francja6–4[i]Hiszpania Barcelona
Uwagi:
  1. a b c Mecz rozgrywany bez kibiców.
tekst
note_legX_N Tworzy przypis dla X-tego wyniku N-tego wiersza tabeli. Parametr może zawierać albo zawartość notatki, albo odwołanie do innej notatki.

Przykład 13

[edytuj kod]
Użycie
{{#invoke:Wyniki rund|main
|[[Arsenal F.C.|Arsenal]]|ENG|2–3|[[FC Bayern Munich|Bayern Munich]]|GER|2–2|0–1
|[[Atlético Madrid]]|ESP|4–5|[[Borussia Dortmund]]|GER|2–1|2–4
|[[Real Madrid CF|Real Madrid]]|ESP|4–4 (4–3 p)|[[Manchester City F.C.|Manchester City]]|ENG|3–3|1–1 (d)
|[[Paris Saint-Germain FC|Paris Saint-Germain]]|FRA|[[Walkower|w/o]]|'''[[FC Barcelona|Barcelona]]'''|ESP|2–3|Canc.

|note_leg1_2=Mecz rozgrywany bez kibiców.
|note_agg_4=Barcelona odniosła zwycięstwo walkowerem po tym, jak Paris Saint-Germain odmówiła rozegrania meczu rewanżowego.
|note_leg2_4=agg_4
}}
Wynik
Drużyna 1Agg.Tooltip Aggregate scoreDrużyna 2Pierwszy
mecz
Drugi
mecz
Arsenal Anglia2–3Niemcy Bayern Munich2–20–1
Atlético Madrid Hiszpania4–5Niemcy Borussia Dortmund2–1[i]2–4
Real Madrid Hiszpania4–4 (4–3 k.)Anglia Manchester City3–31–1 (dogr.)
Paris Saint-Germain Francjaw/o[ii]Hiszpania Barcelona2–3Canc.[ii]
Uwagi:
  1. a b Mecz rozgrywany bez kibiców.
  2. a b c Barcelona odniosła zwycięstwo walkowerem po tym, jak Paris Saint-Germain odmówiła rozegrania meczu rewanżowego.
tekst

Inne funkcje

[edytuj kod]

Wyniki poszczególnych etapów i wyniki łączne

[edytuj kod]

W przypadku wyników częściowych i łącznych wszystkie typy myślników zostaną zamienione na :.

Ponadto moduł automatycznie konwertuje tekst w nawiasach (w odniesieniu do tego, jak ustalono dopasowania) na wikilinks. Obsługiwane są następujące elementy:

  • (X:Y k), (X:Y p), (X:Y pen) lub (X:Y pso)(X:Y [[Seria rzutów karnych|k.]])
  • (d) lub (dogr)([[dogrywka|dogr.]])
  • (a) lub (agr)([[Zasada przewagi bramek zdobytych w meczach wyjazdowych|a]])

Wynik null/nil

[edytuj kod]

Jeśli komórka jednego z wyników zawiera tylko null, komórka będzie zawierać myślnik . Jeśli |solid_cell=y, komórka pozostanie pusta i otrzyma kolor tła szary (#BBBBBB).

Jeśli komórka jednego z wyników zawiera tylko nil, komórka nie zostanie wygenerowana.

Funkcje te są przydatne w przypadku rund rozgrywek, w których liczba meczów jest nierówna, na przykład gdy po dwóch meczach może odbyć się mecz powtórkowy lub barażowy.

Trzy apostrofy ''' do ręcznego pogrubienia

[edytuj kod]

Szablon automatycznie pogrubia zwycięskie drużyny (chyba że |bold_winner=n), jednak w niektórych sytuacjach moduł nie będzie w stanie określić zwycięzcy. Albo niektórzy użytkownicy mogą uznać za niepożądane, aby moduł automatycznie pogrubiał zwycięzcę. W takich przypadkach można użyć ręcznego pogrubienia, aby wskazać zwycięską drużynę. Jest to proste do zrobienia umieszczając trzy apostrofy przed i po nazwie drużyny. Jeśli |bold_winner=n jest wyłączone, drużyna, która jest ręcznie pogrubiona, zastąpi drużynę zwycięską zgodnie z ustaleniami modułu. Jeśli |color_winner=y również ustawione, komórka drużyny, która jest ręcznie pogrubiona, również będzie kolorowa.

Tę metodę można stosować w połączeniu z poniższą metodą, stosując pięć apostrofów po każdej stronie nazwy zespołu, aby pogrubić i pokolorować komórkę.

(Uwaga: Użycie trzech apostrofów zostało nieznacznie zmodyfikowane na potrzeby tego modułu w celu pogrubienia komórki. Dlatego nie można selektywnie pogrubić części parametrów zespołu, pozostawiając inne części tego parametru niepogrubione.)

Dwa apostrofy '' do kolorowania ręcznego

[edytuj kod]

Szablon pozwala na automatyczne kolorowanie komórek zwycięskich drużyn za pomocą |color_winner=y, w niektórych sytuacjach (takich jak mecze z remisem na wyjeździe) moduł nie będzie w stanie określić zwycięzcy. Albo niektórzy użytkownicy mogą uznać za niepożądane używanie |color_winner= do automatycznego kolorowania zwycięzcy. W takich przypadkach można użyć ręcznego kolorowania, aby wskazać zwycięską drużynę w remisie. Jeśli |color_winner=y jest ustawione, komórka drużyny, która jest ręcznie pokolorowana, zastąpi zwycięską drużynę zgodnie z ustaleniami modułu. Jeśli |bold_winner=n jest wyłączone, komórka drużyny, która jest ręcznie pokolorowana, zostanie również pogrubiona.

Tę metodę można stosować w połączeniu z powyższą metodą , używając pięciu apostrofów po każdej stronie drużyny, aby pokolorować i pogrubić komórkę.

Dwa apostrofy otaczające wynik łączny (lub wynik w przypadku remisu w jednym meczu) można również wykorzystać do ręcznego oznaczenia remisu.

(Uwaga: Podczas gdy dwa apostrofy otaczające obie strony tekstu są zwykle używane do dodawania kursywy w wikitekście, użycie zostało tutaj zmodyfikowane, aby umożliwić prosty sposób kolorowania komórki. Dlatego nie jest możliwe kursywa nazw drużyn ani łącznych wyników przy użyciu tego formatowania.)

Błędy

[edytuj kod]

Błędy należy zgłaszać na stronie Wikipedia:Kawiarenka/Kwestie techniczne.

Parametry szablonu (strukturyzacja VE)

[edytuj kod]

Zobacz też

[edytuj kod]


-- Module to build tables for aggregated match results in sports
-- See documentation for details

local p = {}
local ordinalpl = {'Pierwszy','Drugi','Trzeci','Czwarty','Piąty','Szósty','Siódmy','Ósmy','Dziewiąty','Dziesiąty'}

-- Function to parse and expand a template with given parameters
local function expandTemplate(frame, templateName, params)
    return frame:expandTemplate{ title = templateName, args = params }
end

-- Function to check the existence of flagTemplate
local function templateExists(templateName)
    local title = mw.title.new('Szablon:' .. templateName)
    return title and title.exists
end

-- Function to process country codes and variants, dividing parameters by the " " sign
local function processIcon(iconString)
    if not iconString or iconString:match("^%s*$") then
        return nil, nil  -- Return nil for both iconCode and variant if the input is empty or only whitespace
    elseif iconString:find(' ') then
        local parts = mw.text.split(iconString, ' ', true)
        local iconCode = parts[1]
        local variant = parts[2]
        return iconCode, variant
    else
        return iconString, nil  -- Return the input string as iconCode if no " " is present
    end
end

-- Function to determine the correct ordinal suffix for a given number for the heading
local function ordinal(n)
    local last_digit = n % 10
    local last_two_digits = n % 100
    if last_digit == 1 and last_two_digits ~= 11 then
        return n .. 'st'
    elseif last_digit == 2 and last_two_digits ~= 12 then
        return n .. 'nd'
    elseif last_digit == 3 and last_two_digits ~= 13 then
        return n .. 'rd'
    else
        return n .. 'th'
    end
end

-- Function to replace wiki links with their display text or link text
local function replaceLink(match)
    local pipePos = match:find("|")
    if pipePos then
        return match:sub(pipePos   1, -3) -- Return text after the '|'
    else
        return match:sub(3, -3) -- Return text without the brackets
    end
end

-- Function to clean and process the aggregate score for comparison
local function cleanScore(score)
    -- Return an empty string if score is nil or empty to avoid errors
    if not score or score:match("^%s*$") then
        return ''
    end

    -- Replace wiki links
    score = score:gsub("%[%[.-%]%]", replaceLink)

    -- Remove MediaWiki's unique placeholder sequences for references
    score = score:gsub('\127%\'"`UNIQ.-QINU`"%\'\127', '')

    -- Remove superscript tags and their contents
    score = score:gsub('<sup.->.-</sup>', '')

    -- Convert dashes to a standard format
    score = score:gsub('[–—―‒−] ', '-')

    -- Convert : to a standard format
    score = score:gsub(':', '-')

    -- Strip all characters except numbers, dashes and parentheses
    return score:gsub('[^0-9%-()] ', '')
end

-- Function to determine the winner based on scores within parentheses (first) or regular format (second)
local function determineWinner(cleanAggregate, team1, team2, boldWinner, colorWinner, aggregate, isFBRStyle, legs, leg1Score, leg2Score, disableAwayGoals, skipAutoWinner, aggFormat)
    local team1Winner, team2Winner = false, false
    local score1, score2
    local manualBold = false
    local manualColor = false
    local isDraw = false

    -- Handling for manual bolding
    if team1 and type(team1) == 'string' then
        manualBold1 = team1:find("'''") and not (team1:gsub("'''", ""):match("^%s*$"))
        team1 = team1:gsub("'''", "")
    end
    if team2 and type(team2) == 'string' then
        manualBold2 = team2:find("'''") and not (team2:gsub("'''", ""):match("^%s*$"))
        team2 = team2:gsub("'''", "")
    end

    if manualBold1 then
        team1Winner = true
        manualBold = true
    end
    if manualBold2 then
        team2Winner = true
        manualBold = true
    end

    -- Handling for manual coloring of team or aggregate cells
    if team1 and type(team1) == 'string' then
        manualColor1 = team1:find("''") and not (team1:gsub("''", ""):match("^%s*$"))
        team1 = team1:gsub("''", "")
    end
    if team2 and type(team2) == 'string' then
        manualColor2 = team2:find("''") and not (team2:gsub("''", ""):match("^%s*$"))
        team2 = team2:gsub("''", "")
    end
    if aggregate then
        if aggFormat == 'bold' or aggFormat == 'both' then
            aggregate = "<b>" .. aggregate .. "</b>"
        end
        manualColorDraw = aggFormat == 'italic' or aggFormat == 'both'
    end

    if manualColor1 then
        if not team1Winner then
            team1Winner = true
        end
        manualColor = true
    end
    if manualColor2 then
        if not team2Winner then
            team2Winner = true
        end
        manualColor = true
    end
    if manualColorDraw then
        isDraw = true
        manualColor = true
    end

    -- Regular winner determination logic if manual bolding or coloring is not conclusive
    if not team1Winner and not team2Winner and not isDraw and not skipAutoWinner and (boldWinner or colorWinner or isFBRStyle) then
        local parenthetical = cleanAggregate:match('%((%d %- %d )%)')
        local outsideParenthetical = cleanAggregate:match('^(%d %- %d )')
        if parenthetical then -- Prioritize checking score inside parenthetical
            score1, score2 = parenthetical:match('(%d )%- (%d )')
        elseif outsideParenthetical then
            score1, score2 = outsideParenthetical:match('(%d )%- (%d )')
        end

        if score1 and score2 then
            score1 = tonumber(score1)
            score2 = tonumber(score2)

            if score1 > score2 then
                team1Winner = true
            elseif score1 < score2 then
                team2Winner = true
            elseif score1 == score2 and legs == 2 and not disableAwayGoals then
                -- Apply away goals rule
                local cleanLeg1 = cleanScore(leg1Score):gsub('[()]', '')
                local cleanLeg2 = cleanScore(leg2Score):gsub('[()]', '')
                local _, team2AwayGoals = cleanLeg1:match('(%d )%- (%d )')
                local team1AwayGoals = cleanLeg2:match('(%d )%- (%d )')

                if team1AwayGoals and team2AwayGoals then
                    team1AwayGoals, team2AwayGoals = tonumber(team1AwayGoals), tonumber(team2AwayGoals)

                    if team1AwayGoals > team2AwayGoals then
                        team1Winner = true
                    elseif team2AwayGoals > team1AwayGoals then
                        team2Winner = true
                    end
                end
            end

            if (colorWinner or isFBRStyle) and legs == 0 then
                isDraw = not team1Winner and not team2Winner
            end
        end
    end

    return team1, team2, team1Winner, team2Winner, manualBold, manualColor, isDraw, aggregate
end

-- Function to process score bold/italic formatting
function processScore(s)
    if not s or s == "" then
        return "", false
    end

    local scoreFormat = false

    -- Check for 5  apostrophes (both bold and italic)
    if s:match("''''' ") then
        scoreFormat = "both"
        s = s:gsub("'' ", "")
        return s, scoreFormat
    end

    -- Check for 3  apostrophes (bold)
    if s:match("''' ") then
        scoreFormat = "bold"
        s = s:gsub("'' ", "")
        return s, scoreFormat
    end

    -- Check for 2 apostrophes (italic)
    if s:match("''") then
        scoreFormat = "italic"
        s = s:gsub("'' ", "")
        return s, scoreFormat
    end

    -- If no matches found, return original string and false
    return s, scoreFormat
end

-- Function to check if any parameter in a given row is non-nil and non-empty
local function anyParameterPresent(startIndex, step, args)
    -- Check regular parameters
    for index = startIndex, startIndex   step - 1 do
        if args[index] and args[index]:match("^%s*(.-)%s*$") ~= "" then
            return true
        end
    end

    -- Check aggregate note
    local rowIndex = math.floor((startIndex - 1) / step)   1
    local aggNote = args['note_agg_' .. rowIndex]
    if aggNote and aggNote:match("^%s*(.-)%s*$") ~= "" then
        return true
    end

    -- Check leg notes
    local numLegs = step - (noFlagIcons and 3 or 5)  -- Calculate number of legs
    for leg = 1, numLegs do
        local legNote = args['note_leg' .. leg .. '_' .. rowIndex]
        if legNote and legNote:match("^%s*(.-)%s*$") ~= "" then
            return true
        end
    end

    return false
end

-- Function to check whether to reduce font size for upcoming matches
local function checkSmallText(str)
    -- Check for font size or small/big HTML tags
    if str:match("font%s?%-?size") or str:match("<small>") or str:match("<big>") then
        return false
    end

    -- Remove MediaWiki's unique placeholder sequences for references
    str = str:gsub('\127%\'"`UNIQ.-QINU`"%\'\127', '')

    -- Remove superscript tags and their contents
    str = str:gsub('<sup.->.-</sup>', '')

    -- Check for walkover-related strings (never shown in small text)
    if str:lower():match("walkower") or str:lower():match("w%.o%.") or str:lower():match("w/o") then
        return false
    end

    -- Replace wiki links with their display text or link text
    str = str:gsub("%[%[.-%]%]", replaceLink)

    -- Remove all text inside parentheses
    str = str:gsub("%b()", "")

    -- Exit if string contains only en/em dash
    if str == "—" or str == "–" then
        return false
    end

    -- Convert dashes to a standard format
    str = str:gsub('[–—―‒−] ', '-')

    -- Remove opening and closing HTML tags
    str = str:gsub("</?%w [^>]*>", "")

    -- Remove apostrophes
    str = str:gsub("'' ", "")

    -- Remove all whitespace
    str = str:gsub("%s ", "")

    -- Remove all whitespace
    str = str:gsub(":", "-")

    -- Check if the string matches only a scoreline
    if str:match("^%d -%d $") then
        return false
    else
        return true
    end
end

-- Function to format the dashes and winning notes for aggregate/leg score parameters, and divide the score from references/notes/superscripts
local function format_and_extract_score(s, addSpan)
    if not s then return '', '' end -- Return empty strings if input is nil

    local function format_dash(pattern)
        s = mw.ustring.gsub(s, '^' .. pattern, '%1–%2')
        s = mw.ustring.gsub(s, '%(' .. pattern, '(%1–%2')
    end

    -- Format dashes
    format_dash('%s*([%d%.] )%s*[–—―‒−%-]%s*([%d%.] )')
    format_dash('%s*([%d%.] )%s*&[MmNn][Dd][Aa][Ss][Hh];%s*([%d%.] )')
    format_dash('%s*(%[%[[^%[%]]*%|[%d%.] )%s*[–—―‒−%-]%s*([%d%.] )')
    format_dash('%s*(%[[^%[%]%s]*%s [%d%.] )%s*[–—―‒−%-]%s*([%d%.] )')
    format_dash('%s*(%[%[[^%[%]]*%|[%d%.] )%s*&[MmNn][Dd][Aa][Ss][Hh];%s*([%d%.] )')
    format_dash('%s*(%[[^%[%]%s]*%s [%d%.] )%s*&[MmNn][Dd][Aa][Ss][Hh];%s*([%d%.] )')

    -- Extract end text
    local supStart = s:find('<sup')
    local placeholderStart = s:find('\127%\'"`UNIQ')

    -- Function to find the first parenthesis outside of wikilinks
    local function find_paren_outside_wikilinks(s)
        local pos = 1
        while true do
            pos = s:find('%(', pos)
            if not pos then break end
            
            local beforeParen = s:sub(1, pos - 1)
            local openLinks = select(2, beforeParen:gsub('%[%[', '')) - select(2, beforeParen:gsub('%]%]', ''))
            
            if openLinks == 0 then
                return pos
            end

            pos = pos   1
        end
        return nil
    end

    local parenStart = find_paren_outside_wikilinks(s)

    local startPositions = {}
    if supStart then table.insert(startPositions, supStart) end
    if placeholderStart then table.insert(startPositions, placeholderStart) end
    if parenStart then table.insert(startPositions, parenStart) end

    local scoreMatch, endText
    if #startPositions > 0 then
        local startPos = math.min(unpack(startPositions))
        
        -- Find the last non-whitespace character before startPos
        local scoreEnd = s:sub(1, startPos - 1):match(".*%S") or ""
        scoreEnd = #scoreEnd

        -- Extract the score and endText
        scoreMatch = s:sub(1, scoreEnd)
        endText = s:sub(scoreEnd   1)
    else
        -- If no match found, return the entire score
        scoreMatch = s
        endText = ""
    end

    -- Format winning notes in brackets (only if endText is not empty)
    if endText ~= "" then
        if addSpan then
            endText = mw.ustring.gsub(endText, '(%(%d %s*[–:]%s*%d )%s [KkPp]%.?[EeSs]?%.?[NnOo]?%.?%)', '<span class="nowrap"><small>%1 [[Seria rzutów karnych|k.]]</small>)</span>')
            endText = mw.ustring.gsub(endText, '%([Dd]%.?[Oo]?%.?[Gg]?%.?[Rr]?%.?%)', '<span class="nowrap">(<small>[[dogrywka|dogr.]]</small>)</span>')
        else
            endText = mw.ustring.gsub(endText, '(%(%d %s*[–:]%s*%d )%s [KkPp]%.?[EeSs]?%.?[NnOo]?%.?%)', '<small>%1 [[Seria rzutów karnych|k.]]</small>)')
            endText = mw.ustring.gsub(endText, '%([Dd]%.?[Oo]?%.?[Gg]?%.?[Rr]?%.?%)', '(<small>[[dogrywka|dogr.]]</small>)')
        end
        endText = mw.ustring.gsub(endText, '%([Aa]%.?[Gg]?%.?[Rr]?%.?%)', '(<small>[[Zasada przewagi bramek zdobytych w meczach wyjazdowych|a]]</small>)')
    end

    return scoreMatch, endText
end

-- Function to clean team names and generate links
local function cleanAndGenerateLinks(team1, team2, score, isSecondLeg)
    local function cleanTeam(str, defaultName)
        if str and str ~= "" then
        	str = str:gsub('<sup.->.-</sup>', '')
            str = str:gsub("</?%w [^>]*>", "")
            str = str:gsub('\127%\'"`UNIQ.-QINU`"%\'\127', '')
            str = str:gsub("%[%[[Ff]ile:[^%]] %]%]", "")
            str = str:gsub("%[%[[Pp]lik:[^%]] %]%]", "")
            str = str:gsub("%[%[[Ii]mage:[^%]] %]%]", "")
            str = str:gsub("%[%[[Ii]mg:[^%]] %]%]", "")
            str = str:gsub("%[%[.-%]%]", replaceLink)
            str = str:gsub("%s*&nbsp;%s*", "")
            str = str:match("^%s*(.-)%s*$")  -- Remove leading and trailing whitespace
            return str ~= "" and str or defaultName
        end
        return defaultName
    end

    team1 = cleanTeam(team1, "Team 1")
    team2 = cleanTeam(team2, "Team 2")

    if score and score:match("%S") then
        local linkScore = score
        if score:find('%[') then
            linkScore = score:match('^([%d%.] –[%d%.] )')
            if not linkScore then
                return score
            end
        end

        if linkScore then
            local link
            if isSecondLeg then
                link = "[[#" .. team2 .. "-" .. team1 .. "|" .. linkScore .. "]]"
            else
                link = "[[#" .. team1 .. "-" .. team2 .. "|" .. linkScore .. "]]"
            end
            return link .. score:sub(#linkScore   1)
        end
    end

    return score
end

-- Function to process notes for aggregate and leg scores
local function processNote(frame, notes, noteKey, noteText, endText, rowIndex, rand_val, noteGroup)
    if not noteText then return endText, notes end
    if noteText:match("^%s*<sup") or noteText:match("^\127%\'%\"`UNIQ") then
        return noteText .. endText, notes
    end

    local function createInlineNote(name)
        return frame:extensionTag{
            name = 'ref',
            args = {
                name = name,
                group = noteGroup
            }
        }
    end

    -- Check if noteText is a reference to another note
    local referenced_note = noteText:match("^(agg_%d )$") or noteText:match("^(leg%d _%d )$")
    if referenced_note then
        local referenced_note_id = '"table_note_' .. referenced_note .. '_' .. rand_val .. '"'
        return endText .. createInlineNote(referenced_note_id), notes
    end

    local note_id = '"table_note_' .. noteKey .. '_' .. rowIndex .. '_' .. rand_val .. '"'
    if not notes[note_id] then
        notes[note_id] = noteText
    end

    return endText .. createInlineNote(note_id), notes
end

-- Function to generate the footer if necessary
local function createFooter(frame, notes, noteGroup, isFBRStyle, displayNotes, externalNotes, legs)
    local needFooter = (isFBRStyle and legs == 0) or displayNotes or (next(notes) ~= nil)

    if not needFooter then
        return ''  -- Return an empty string if no footer is needed
    end

    local divContent = mw.html.create('div')
        :addClass('sports-series-notes')

    if isFBRStyle and legs == 0 then
        divContent:wikitext('Legenda: <span class="legend-text-W">&#160;</span> = wygrana gospodarza; '
				..'<span class="legend-text-R">&#160;</span> = remis; '
				..'<span class="legend-text-P">&#160;</span> = wygrana gości.')
    end

    if (next(notes) ~= nil and not externalNotes) or displayNotes then
        divContent:wikitext((isFBRStyle and legs == 0) and "<br />Uwagi:" or "Uwagi:")
    end

    local footer = tostring(divContent)

    if next(notes) ~= nil or displayNotes then
        local noteDefinitions = {}
        for noteId, noteText in pairs(notes) do
            if type(noteId) == 'string' and noteId:match('^"table_note') then
                table.insert(noteDefinitions, frame:extensionTag{
                    name = 'ref',
                    args = {
                        name = noteId,
                        group = noteGroup
                    },
                    content = noteText
                })
            end
        end

        if externalNotes then
            local hiddenRefs = mw.html.create('span')
                :addClass('sports-series-hidden')
                :wikitext(table.concat(noteDefinitions))
            if isFBRStyle and legs == 0 then
                footer = footer .. tostring(hiddenRefs)
            else
                footer = tostring(hiddenRefs)
            end
        else
            local reflistArgs = {
                group = noteGroup
            }
            footer = footer .. frame:extensionTag{
                name = 'references',
                args = reflistArgs
            }
        end
    end

    return footer
end

-- Main function that processes input and returns the wikitable
function p.main(frame)
    local args = require('Module:Arguments').getArgs(frame, {trim = true})
    local yesno = require('Module:Yesno')

    -- Check for section transclusion
    local tsection = frame:getParent().args['transcludesection'] or frame:getParent().args['section'] or ''
    local bsection = args['section'] or ''
    if tsection ~= '' and bsection ~= '' then
        if tsection ~= bsection then
            return ''  -- Return an empty string if sections don't match
        end
    end

    local root = mw.html.create()
    local templatestyles = frame:extensionTag{
        name = 'templatestyles',
        args = { src = 'Moduł:Wyniki rund/styles.css' }
    }
    root:wikitext(templatestyles)

    local flagYesno = yesno(args.flag)
    local showFlags = flagYesno ~= false
    local noFlagIcons = not showFlags
    local fillBlanks = yesno(args.fill_blanks)
    local generateLinks = yesno(args.generate_links)
    local solidCell = yesno(args.solid_cell) or args.solid_cell == 'grey' or args.solid_cell == 'gray'
    local baselink = frame:getParent():getTitle()
    local currentPageTitle = mw.title.getCurrentTitle().fullText
    if currentPageTitle == baselink then baselink = '' end
    local notes = {}
    local noteGroup = args.note_group or 'mini'
    local noteListValue = yesno(args.note_list)
    local displayNotes = noteListValue == true
    local externalNotes = noteListValue == false
    math.randomseed(os.clock() * 10^8)  -- Initialize random number generator
    local rand_val = math.random()

    -- Process the font size parameter
    local fontSize
    if args.font_size then
        -- Remove trailing '%' if present and convert to number
        fontSize = tonumber((args.font_size:gsub('%s*%%$', '')))
        if fontSize then
            fontSize = math.max(fontSize, 85)  -- Ensure font size is at least 85
        end
    end

    -- Process flag parameter to determine flag template and variant
    local flagTemplate = 'flaga'
    local flagSize = args.flag_size
    if showFlags then
        if args.flag and args.flag ~= '' and not flagYesno then
            flagTemplate = args.flag:gsub('^Szablon:', '')
            if not templateExists(flagTemplate) then
                flagTemplate = 'flag icon'
            end
        end

        if flagSize and not flagSize:match('px$') then
            flagSize = flagSize .. 'px'
        end
    end

    -- Determine whether line should be displayed
    local showCountry = args.show_country
    local function shouldShowRow(team1Icon, team2Icon)
        if not showCountry or noFlagIcons then
            return true
        end
        return team1Icon == showCountry or team2Icon == showCountry
    end

    local legs = 2
    if args.legs then
        if yesno(args.legs) == false or args.legs == '1' then
            legs = 0
        else
            legs = tonumber(args.legs) and math.max(tonumber(args.legs), 2) or 2
        end
    end
    local teamWidth = (tonumber(args['team_width']) and args['team_width'] .. 'px') or '250px'
    local scoreWidth = (tonumber(args['score_width']) and args['score_width'] .. 'px') or '80px'
    local boldWinner = args.bold_winner == nil or yesno(args.bold_winner, true)
    local colorWinner = yesno(args.color_winner)
    local matchesStyle = args.matches_style
    local isFBRStyle = matchesStyle and matchesStyle:upper() == "FBR"
    local isHA = yesno(args.h_a) or (isFBRStyle and legs == 0)
    local disableAwayGoals = yesno(args.away_goals) == false
    local disableSmallText = yesno(args.small_text) == false
    local noWrapValue = yesno(args.nowrap)
    local noWrap = noWrapValue == true
    local disableNoWrap = noWrapValue == false
    local aggFormat

    local tableClass = 'wikitable sports-series'
    local doCollapsed = yesno(args.collapsed)
    if doCollapsed then
        tableClass = tableClass .. ' mw-collapsible mw-collapsed'
    end
    if yesno(args.center_table) and not doCollapsed then
        tableClass = tableClass .. ' center-table'
    end
    if fontSize then
        table:css('font-size', fontSize .. '%')
    end

    -- Create the table element
    local table = root:tag('table')
        :addClass(tableClass)
        :cssText(tableStyle)
    if args.id then
        table:attr('id', args.id)  -- Optional id parameter to allow anchor to table
    end
    if noWrap then
        table:attr('data-nowrap', 'y')
    elseif not disableNoWrap then
        table:attr('data-nowrap', 'n')
    end

    -- Add a caption to table if the "caption" parameter is passed
    if args.caption then
        table:tag('caption'):wikitext(args.caption)
    end

    -- Count number of columns
    local colCount = 3   legs

    -- Add a title row above column headings if the "title" parameter is passed
    if args.title then
        local titleRow = table:tag('tr'):addClass('title-row')
        titleRow:tag('th')
            :attr('colspan', colCount)
            :attr('scope', 'colgroup')
            :wikitext(args.title)
    end

    -- Create the header row with team and score columns
    local header = table:tag('tr')
    local defaultTeam1 = isHA and 'Gospodarz' or 'Drużyna 1'
    local defaultTeam2 = isHA and 'Gość' or 'Drużyna 2'
    header:tag('th'):attr('scope', 'col'):css('width', teamWidth):wikitext(args['team1'] or defaultTeam1)
    header:tag('th'):attr('scope', 'col'):css('width', scoreWidth):wikitext(args['aggregate'] or legs == 0 and 'Wynik' or '[[Aggregate score|<abbr title="Aggregate score">Agg.</abbr>]]<span class="sports-series-sr-only">Tooltip Aggregate score</span>')
    header:tag('th'):attr('scope', 'col'):css('width', teamWidth):wikitext(args['team2'] or defaultTeam2)

    -- Add columns for each leg if applicable
    if legs > 0 then
        for leg = 1, legs do
            local legHeading = args['Mecz' .. leg]

            -- Check if "legN" parameter is present
            if not legHeading then
                if args.leg_prefix then
                    legHeading = yesno(args.leg_prefix) and ('Mecz ' .. leg) or (args.leg_prefix .. ' ' .. leg)
                elseif args.leg_suffix and not yesno(args.leg_suffix) then
                    legHeading = ordinalpl[leg] .. '<br />' .. args.leg_suffix
                else
                    legHeading = ordinalpl[leg] .. '<br />mecz'
                end
            end

            header:tag('th'):attr('scope', 'col'):css('width', scoreWidth):wikitext(legHeading)
        end
    end

    local step = (noFlagIcons and 3 or 5)   legs  -- Determine the step size based on the presence of flag icons
    local i = tonumber(args.first_row) and 1   (math.max(tonumber(args.first_row),1) - 1) * step or 1
    local j = tonumber(args.last_row) and 1   math.max(tonumber(args.last_row),1) * step or 0
    local isRow = (j == 0) or (i <= j)
    while anyParameterPresent(i, step, args) and isRow do
        local rowIndex = math.floor((i - 1) / step)   1
        local aggNote = args['note_agg_' .. rowIndex]
        local headingParam = args['heading' .. rowIndex]

        local team1, team2, aggregateScore, aggregateEndText, legEndText, team1Icon, team2Icon, team1Variant, team2Variant
        local team1Winner, team2Winner, manualBold, manualColor, isDraw = false, false, false, false, false
        local leg1Score, leg2Score = false, false

        -- Process rows from input
        team1 = args[i]
        if noFlagIcons then
            aggregateScore = args[i 1]
            team2 = args[i 2]
        else
            team1Icon, team1Variant = processIcon(args[i 1])
            aggregateScore = args[i 2]
            team2 = args[i 3]
            team2Icon, team2Variant = processIcon(args[i 4])
        end

        -- Check if the line should be shown based on both teams
        if shouldShowRow(team1Icon, team2Icon) then
            -- Add a heading above a given row in the table
            if headingParam and not showCountry then
                local headingRow = table:tag('tr'):addClass('heading-row')
                headingRow:tag('td')
                    :attr('colspan', colCount)
                    :wikitext('<strong>' .. headingParam .. '</strong>')
            end

            local row = table:tag('tr')

            -- Name the 1st/2nd leg scores for two-legged ties
            if legs == 2 then
                if noFlagIcons then
                    leg1Score = args[i 3]
                    leg2Score = args[i 4]
                else
                    leg1Score = args[i 5]
                    leg2Score = args[i 6]
                end
            end

            -- Clean the aggregate score
            local cleanAggregate = cleanScore(aggregateScore)
            aggregateScore, aggFormat = processScore(aggregateScore)
            -- Format anchor links for aggregate score
            local aggParen = cleanAggregate:match("%(.*%(")
            local aggSpan = (disableNoWrap or (not noWrap and not disableNoWrap and aggParen))
            aggregateScore, aggregateEndText = format_and_extract_score(aggregateScore, aggSpan)
            aggregateEndText, notes = processNote(frame, notes, 'agg', aggNote, aggregateEndText, rowIndex, rand_val, noteGroup)
            if generateLinks and legs == 0 then
                aggregateScore = cleanAndGenerateLinks(team1, team2, aggregateScore, false)
            end

            local skipAutoWinner = legs == 0 and aggregateScore ~= '' and checkSmallText(aggregateScore)

            -- Determine the winning team on aggregate
            team1, team2, team1Winner, team2Winner, manualBold, manualColor, isDraw, aggregateScore = determineWinner(cleanAggregate, team1, team2, boldWinner, colorWinner, aggregateScore, isFBRStyle, legs, leg1Score, leg2Score, disableAwayGoals, skipAutoWinner, aggFormat)

            -- Function to create flag template parameters
            local function getFlagParams(icon, variant)
                local params = {icon, variant = variant}
                if flagSize then
                    params.size = flagSize
                end
                return params
            end

            -- Generate text to display for each team
            local team1Text = noFlagIcons and (team1 or '') or ((team1Icon ~= "" and team1Icon ~= nil) and ((team1 or '') .. '&nbsp;' .. expandTemplate(frame, flagTemplate, getFlagParams(team1Icon, team1Variant))) or (team1 or ''))
            local team2Text = noFlagIcons and (team2 or '') or ((team2Icon ~= "" and team2Icon ~= nil) and (expandTemplate(frame, flagTemplate, getFlagParams(team2Icon, team2Variant)) .. '&nbsp;' .. (team2 or '')) or (team2 or ''))

            -- When set by user, adds blank flag placeholder next to team names
            if fillBlanks and showFlags then
            	local flagDimensions = flagSize or "25x17px"
            	local placeholderFlag = string.format('<span class="flagicon">[[File:Flag placeholder.svg|%s|link=]]</span>', flagDimensions)
                if not team1Icon or team1Icon == "" then
                    team1Text = team1Text .. '&nbsp;' .. placeholderFlag
                end
                if not team2Icon or team2Icon == "" then
                    team2Text = placeholderFlag .. '&nbsp;' .. team2Text
                end
            end

            local aggregateContent
            if not disableSmallText and skipAutoWinner then
                aggregateContent = '<span class="sports-series-small">' .. aggregateScore .. '</span>' .. aggregateEndText
            else
                aggregateContent = aggregateScore .. aggregateEndText
            end

            -- Create aggregate score cell with conditional styling
            local aggregateClass = ''
            if isFBRStyle and legs == 0 then
                if team1Winner then
                    aggregateClass = 'fbr-home-win'
                elseif team2Winner then
                    aggregateClass = 'fbr-away-win'
                elseif isDraw then
                    aggregateClass = 'draw'
                end
            elseif isDraw then
                aggregateClass = 'draw'
            end
            if not disableNoWrap and (not noWrap and aggParen) then
                aggregateClass = (aggregateClass ~= '' and aggregateClass .. ' ' or '') .. 'allow-wrap'
            end

            -- Create rows for aggregate score and team names, bolded if set by user
            row:tag('td'):addClass(team1Winner and (colorWinner or manualColor) and 'winner' or nil):wikitext((team1Winner and (boldWinner or manualBold) and team1Text ~= '') and ('<strong>' .. team1Text .. '</strong>') or team1Text)
            row:tag('td'):addClass(aggregateClass ~= '' and aggregateClass or nil):wikitext(aggregateContent)
            row:tag('td'):addClass(team2Winner and (colorWinner or manualColor) and 'winner' or nil):wikitext((team2Winner and (boldWinner or manualBold) and team2Text ~= '') and ('<strong>' .. team2Text .. '</strong>') or team2Text)

            -- Add columns for each leg score if applicable
            if legs > 0 then
                for leg = 1, legs do
                    local legIndex = i   4   leg   (noFlagIcons and -2 or 0)
                    local legScore = args[legIndex]
                    local legNote = args['note_leg' .. leg .. '_' .. rowIndex]
                    if legScore ~= "nil" then
                        if legScore == "null" then
                            if solidCell then
                                row:tag('td'):addClass('solid-cell')
                            else
                                legScore = '—'
                            end
                        end

                        if legScore ~= "null" then
                            -- Format anchor links for leg scores
                            local cleanLeg = cleanScore(legScore)
                            local legFormat
                            legScore, legFormat = processScore(legScore)
                            local legParen = cleanLeg:match("%(.*%(")
                            local legSpan = (disableNoWrap or (not noWrap and not disableNoWrap and legParen))
                            legScore, legEndText = format_and_extract_score(legScore, legSpan)
                            legEndText, notes = processNote(frame, notes, 'leg' .. leg, legNote, legEndText, rowIndex, rand_val, noteGroup)
                            if generateLinks and not aggregateContent:lower():find("bye") then
                                if leg == 1 then
                                    legScore = cleanAndGenerateLinks(team1, team2, legScore, false)
                                elseif leg == 2 then
                                    legScore = cleanAndGenerateLinks(team1, team2, legScore, true)
                                end
                            end
                            if legFormat == 'bold' or legFormat == 'both' then legScore = '<b>' .. legScore .. '</b>' end
                            if legFormat == 'italic' or legFormat == 'both' then legScore = '<i>' .. legScore .. '</i>' end
                            local legContent
                            if not disableSmallText and legScore ~= '' and checkSmallText(legScore) then
                                legContent = '<span class="sports-series-small">' .. legScore .. '</span>' .. legEndText
                            else
                                legContent = legScore .. legEndText
                            end
                            local legClass = ''
                            if not disableNoWrap and (not noWrap and legParen) then
                                legClass = 'allow-wrap'
                            end
                            -- Write cells for legs
                            row:tag('td'):addClass(legClass ~= '' and legClass or nil):wikitext(legContent)
                        end
                    end
                end
            end
        end

        i = i   step
        isRow = (j == 0) or (i < j)
    end

    -- Generate footer text
    local footerText = createFooter(frame, notes, noteGroup, isFBRStyle, displayNotes, externalNotes, legs)
    root:wikitext(footerText)

    local tableCode = tostring(root)

    -- Rewrite anchor links for the entire table
    if baselink ~= '' then
        tableCode = mw.ustring.gsub(tableCode, '(%[%[)(#[^%[%]]*%|)', '%1' .. baselink .. '%2')
    end
    local escapedTitle = currentPageTitle:gsub("([%(%)%.%%% %-%*%?%[%^%$])", "%%%1")
    local titlePattern = '%[%[' .. escapedTitle .. '(#[^%[%]]*%|)'
    tableCode = mw.ustring.gsub(tableCode, titlePattern, '[[%1')

    return tableCode
end

return p