Ugrás a tartalomhoz

Modul:TeamBracket

Ellenőrzött
A Wikipédiából, a szabad enciklopédiából

TeamBracket[mi ez?] • [dokumentáció: mutat, szerkeszt] • [tesztek: létrehozás]

Ez a modul az egyenes kieséses rendszerű tornák ágrajzainak vizuális megjelenítését valósítja meg. Általánosan a {{64TeamBracket}}(?), {{32TeamBracket}}(?), {{16TeamBracket}}(?), {{8TeamBracket}}(?), {{4TeamBracket}}(?) sablonok használhatók.

Használata

[szerkesztés]
{{#invoke: TeamBracket | main
| rounds      =
| RD1-group1  =

| RD1         =
| RD1-seed1   =
| RD1-team1   =
| RD1-score1  =
 ...
}}

Paraméterek

[szerkesztés]
Paraméter Leírása
rounds a fordulók száma. Az 1 érték 2 szereplős ágrajzot, a 2 érték 4 szereplős ágrajzot, a 3 érték 8 szereplős ágrajzot, a 4 érték 16 szereplős ágrajzot, az 5 érték 32 szereplős ágrajzot..., stb. jelenít meg.
maxround A megjelenített fordulók maximális száma. A paramétert nem veszi figyelembe, ha kevesebb, mint a rounds paraméterben megadott érték
seed-width A kiemelések (seed) cellák szélessége. Az egyszerű számokat pixelben kell megadni (pl.: 25 a 25px értékhez vagy 2em a 2em értékhez vagy auto az automatikus mérethez.
team-width A csapatnevek (team) cellák szélessége. Az egyszerű számokat pixelben kell megadni (pl.: 200 a 200px értékhez vagy 15em a 15em értékhez vagy auto az automatikus mérethez.
score-width Az eredmény (score) cellák szélessége. Az egyszerű számokat pixelben kell megadni (pl.: 25 a 25px értékhez vagy 2em a 2em értékhez vagy auto az automatikus mérethez.
compact A yes megadásával az ágrajz tömörebb formátumú, a "group" paraméterek, illetve annak helyei nem jelennek meg.
nowrap A yes érték megadásával a hosszú nevek azonos sorba kerülnek, nem lesz sortörés
seeds A no érték megadásával a kiemelés cellái nem jelennek meg, a yes megadásával a kiemelés cellái mindig megjelennek.
autoseeds A yes érték esetén a kiemelések hagyományos rend szerinti számozása az 1. fordulóban automatikusan kitöltődik.
byes Kiemelt résztvevők esetén a használatával opcionálissá válnak az első 1, 2, ... forduló adatai.
sets vagy legs a szettek/mérkőzések száma körönként (a körönkénti különböző számú szett vagy mérkőzésszám esetén a / jellel történik az elhatárolás)
Példák 4 fordulónál
|sets=3/3/3/5/3 : A szettek száma az 1., 2., 3. körben 3, a 4. körben (utolsó forduló / döntő) 5, a bronzmérkőzésen 3.
|sets=3/3/3/5 : A szettek száma az 1., 2., 3. körben 3, a 4. körben (utolsó forduló / döntő) és a bronzmérkőzésen 5.
|legs=2/2/2/1 : A mérkőzések száma az 1., 2., 3. körben 2, a 4. körben (utolsó forduló / döntő) 1.
|legs=1/1/1/3 : A mérkőzések száma az 1., 2., 3. körben 1, a 4. körben (utolsó forduló / döntő) 3.
aggregate A sets vagy legs érték esetén összesítésként a mérkőzések kimenetelének összege jelenik meg (pl. két 3–2-es győzelem esetén az összesítés 2–0, azaz 2 nyert mérkőzés és 0 nyert mérkőzés). A score érték esetén összesítésként a szettek/mérkőzésen szerzett eredmények összege jelenik meg (pl. két 3–2-es győzelem esetén az összesítés 6–4, azaz 6 szerzett pont és 4 szerzett pont). A yes vagy y érték esetén az -agg utótagos paraméterrel egyedileg lehet beírni az összesített eredményt, automatikus számolás nélkül. Csak akkor működik, ha a fordulóban kettő vagy több szett/mérkőzés van. Az automatikus számolás felülírható az -agg utótagos paraméterekkel.
boldwinner A győztes, a kiemelése és az eredménye automatikusan vastagbetűvel jelenik meg. A high érték esetén a magasabb érték (pl.: gólszám, pontszám) a low érték esetén az alacsonyabb érték (pl.: időeredmény) jelenti a győztest. A modul az összes olyan karaktert nem veszi figyelembe, amely nem szám, majd így hasonlítja össze a két értéket.
1 (5) és 1 (4) érték esetén a 15 és 14 értéket hasonlítja össze.
6<sup>9</sup> és 7<sup>11</sup> érték esetén a 69 és 711 értéket hasonlítja össze.
boldseed A boldwinner alkalmazása esetén a no érték beállításával a győztes kiemelése nem lesz vastagbetűs, csak a győztes és az eredménye.
hideomittedscores Az 1 érték megadása esetén az összes kihagyott eredmény cellája nem jelenik meg (kihagyottnak az számít, ha a sablonban a paraméternév sincs beírva). A második szett vagy mérkőzés és az azt követő eredmények celláinak elrejtéséhez a 2 értéket kell használni.
sepwidth A cellák szegélyvastagságának felülírása 1 vagy 2 értékkel. Alapértelmezésben a compact (tömör) formátum beállítása 1, a normál (nem tömör) formátum beállítása 2.
headings A no érték esetén a fejléc nem jelenik meg.
RDn Az n-edik forduló megnevezése. Az alapértelmezett értékek: "m. forduló", ..., "Negyeddöntők", "Elődöntők", és "Döntő", ahol m a forduló sorszáma.
RDnb vagy 3rd A "Bronzmérkőzés" megnevezése, ahol n az ágrajz utolsó fordulója. Az RDnb helyett a 3rd is használható. A Bronzmérkőzés akkor jelenik meg, ha 1) az RDnb vagy 3rd paraméter ki van töltve, vagy 2) a megnevezés kitöltésének hiányában legalább az egyik csapat neve (RDnb-teamm vagy 3rd-teamm paraméter) ki van töltve.
RDn-groupm Az m csoport megnevezése az n-edik fordulóban. Minden fordulóban minden négy csapatra vonatkoztatva megadható egy csoportnév.
RDn-seedm Az m csapat kiemelése az n-edik fordulóban. Az 1. fordulóban ez az érték alapértelmezés szerint a versenyek hagyományos kiosztása. Ha üres, akkor a cella nem jelenik meg. Az 1. forduló kiemeléseinek elrejtéséhez az értékeket kifejezetten üresre kell állítani.
RDn-teamm Az m csapat neve az n-edik fordulóban.
RDn-scorem Az m csapat eredménye az n-edik fordulóban.
RDn-scorem-s Az m csapat eredménye az n-edik fordulóban és az s szettben (vagy mérkőzésen, több mérkőzés esetén). Alternatívaként a forduló utolsó pontszáma is megadható az -agg utótagos paraméterekben.
RD1-omit Az 1. fordulóban egyedileg kiválasztatott csapathelyek (mérkőzésekhelyek) elrejtése. Például 1 / 2 / 5 / 6 érték esetén a csapat1, csapat2, csapat5, és csapat6 mérkőzéseinek helyei nem jelennek meg. A sorszámozást ugyanakkor 1-től kell használni.
RD-shade A fejléc háttérszíne az RDn fordulói szövegénél
RDn-shadem-s A cella háttérszíne az n-edik fordulóban az m csapat s szett eredményénél (vagy mérkőzésnél, több mérkőzés esetén).
RDn-RDn+1-path A 0 érték esetén az ágak nem jelennek meg az n és az n+1 forduló között.
float Az ágrajz elhelyezése az oldalon. A left balra, a right jobbra, a center vagy centre középre helyezi.
clear Set to no to prevent "clearing" the left/right side of the page before floating to the left/right. This parameter is only valid with |float=left or |float=right.

Példák

[szerkesztés]

A kiemelés nem jelenik meg

[szerkesztés]
{{#invoke: TeamBracket | main
| rounds    = 2
| seeds     = no
}}
Elődöntők Döntő
    
 
 
 
 
 
 

Tömör

[szerkesztés]
{{#invoke: TeamBracket | main
| rounds    = 2
| compact   = yes
}}
Elődöntők Döntő
 
   
   
 

Bronzmérkőzés

[szerkesztés]
{{#invoke: TeamBracket | main
| rounds    = 2
| seeds     = no
| RD2b      = Bronzmérkőzés
}}
Elődöntők Döntő
    
 
 
 
 
 
  Bronzmérkőzés
 
 

Csoportok

{{#invoke: TeamBracket | main
| autoseeds  = y
| rounds     = 3
| RD1-group1 = Pacific
| RD1-group2 = Mountain
| RD2-group1 = West
}}
Negyeddöntők Elődöntők Döntő
         
1  
8  
 
Pacific
 
5  
4  
 
West
 
3  
6  
 
Mountain
 
7  
2  

Szettek

[szerkesztés]
{{#invoke: TeamBracket | main
| autoseeds  = y
| rounds     = 3
| sets       = 3 / 5 / 5
}}
Negyeddöntők Elődöntők Döntő
                   
1  
8  
 
 
5  
4  
 
 
3  
6  
 
 
7  
2  

Összesítés

[szerkesztés]
{{#invoke: TeamBracket | main
| autoseeds  = y
| rounds     = 3
| legs       = 2
| aggregate  = y
}}
Negyeddöntők Elődöntők Döntő
               
1  
8  
 
 
5  
4  
 
 
3  
6  
 
 
7  
2  

Egyéb opciók

headings
|headings = no: a fejléc (fordulók nevei) nem jelennek meg
sepwidth
|sepwidth = 2: a cellák elhatárolása 2 pixeles vonalakkal
boldwinner
|boldwinner = high: a győztes automatikus formázása, a magasabb érték győz
boldseed
|boldseed = no: a |boldwinner paraméterrel együtt használható, no érték esetén a kiemelések cellái nem lesznek vastagbetűsek
hideomittedscores
|hideomittedscores = 1: A sablonból is kihagyott eredmény paraméterek esetén a kihagyott eredmények cellái nem jelennek meg
{{#invoke: TeamBracket | main
|rounds=3|byes=1|sets=5|headings=no|sepwidth=2|boldwinner=high|boldseed=no|hideomittedscores = 1

|RD1-seed3=4|RD1-team3=játékos 4|RD1-score3-1=6<sup>9</sup>|RD1-score3-2=6|RD1-score3-3=4|RD1-score3-4=3
|RD1-seed4=5|RD1-team4=játékos 5|RD1-score4-1=7<sup>11</sup>|RD1-score4-2=3|RD1-score4-3=6|RD1-score4-4=6

|RD1-seed7=3|RD1-team7=játékos 3|RD1-score7-1=6|RD1-score7-2=7|RD1-score7-3=7
|RD1-seed8=6|RD1-team8=játékos 6|RD1-score8-1=4|RD1-score8-2=5|RD1-score8-3=5

|RD2-seed1=1|RD2-team1=játékos 1|RD2-score1-1=6|RD2-score1-2=6|RD2-score1-3=5|RD2-score1-4=6
|RD2-seed2=5|RD2-team2=játékos 5|RD2-score2-1=0|RD2-score2-2=4|RD2-score2-3=7|RD2-score2-4=3

|RD2-seed3=2|RD2-team3=játékos 2|RD2-score3-1=2|RD2-score3-2=6|RD2-score3-3=7<sup>7</sup>|RD2-score3-4=6<sup>4</sup>|RD2-score3-5=4
|RD2-seed4=3|RD2-team4=játékos 3|RD2-score4-1=6|RD2-score4-2=4|RD2-score4-3=6<sup>3</sup>|RD2-score4-4=7<sup>7</sup>|RD2-score4-5=6

|RD3-seed1=1|RD3-team1=játékos 1
|RD3-seed2=3|RD3-team2=játékos 3
}}
                     
1 játékos 1 6 6 5 6
5 játékos 5 0 4 7 3
4 játékos 4 69 6 4 3
5 játékos 5 711 3 6 6
1 játékos 1
3 játékos 3
2 játékos 2 2 6 77 64 4
3 játékos 3 6 4 63 77 6
3 játékos 3 6 7 7
6 játékos 6 4 5 5
maxround
|maxround = 2: Az alábbi példában egy 4 fordulós (16 szereplős) ágrajzban csak az első két forduló jelenik meg. Jellemzően akkor használható, ha a selejtezőből a főtáblára jutást ilyen módon bonyolítják le.
:Felső ág
{{16TeamBracket-Compact-Tennis3-Byes
| RD1=Selejtező, 1. forduló
| RD2=Selejtező, 2. forduló
| maxround=2
| boldwinner = yes |boldseed = no

| RD1-seed01=37
| RD1-team01=név
| RD1-score01-1=6| RD1-score01-2=6| RD1-score01-3=
| RD1-seed02=44
| RD1-team02=név
| RD1-score02-1=1| RD1-score02-2=4| RD1-score02-3=

| RD1-seed15=41
| RD1-team15=név
| RD1-score15-1=6<sup>6</sup>| RD1-score15-2=6| RD1-score15-3=6
| RD1-seed16=40
| RD1-team16=név
| RD1-score16-1=7<sup>8</sup>| RD1-score16-2=3| RD1-score16-3=2

| RD2-seed01=37
| RD2-team01=név
| RD2-seed02=32
| RD2-team02=név

| RD2-seed03=25
| RD2-team03=név
| RD2-seed04=36
| RD2-team04=név

| RD2-seed05=33
| RD2-team05=név
| RD2-seed06=28
| RD2-team06=név

| RD2-seed07=29
| RD2-team07=név
| RD2-seed08=41
| RD2-team08=név
}}
:Alsó ág
{{16TeamBracket-Compact-Tennis3-Byes
| RD1=Selejtező, 1. forduló
| RD2=Selejtező, 2. forduló
| maxround=2
| boldwinner = yes |boldseed = no

| RD1-seed01=39
| RD1-team01=név
| RD1-score01-1=6| RD1-score01-2=7| RD1-score01-3=
| RD1-seed02=42
| RD1-team02=név
| RD1-score02-1=4| RD1-score02-2=5| RD1-score02-3=

| RD1-seed15=43
| RD1-team15=név
| RD1-score15-1=7<sup>8</sup>| RD1-score15-2=5| RD1-score15-3=6
| RD1-seed16=38
| RD1-team16=név
| RD1-score16-1=6| RD1-score16-2=7| RD1-score16-3=4

| RD2-seed01=39
| RD2-team01=név
| RD2-seed02=30
| RD2-team02=név

| RD2-seed03=27
| RD2-team03=név
| RD2-seed04=34
| RD2-team04=név

| RD2-seed05=35
| RD2-team05=név
| RD2-seed06=26
| RD2-team06=név

| RD2-seed07=31
| RD2-team07=név
| RD2-seed08=43
| RD2-team08=név
}}
Felső ág
Selejtező, 1. forduló Selejtező, 2. forduló
37 név 6 6
44 név 1 4 37 név
32 név
25 név
36 név
33 név
28 név
29 név
41 név 66 6 6 41 név
40 név 78 3 2
Alsó ág
Selejtező, 1. forduló Selejtező, 2. forduló
39 név 6 7
42 név 4 5 39 név
30 név
27 név
34 név
35 név
26 név
31 név
43 név 78 5 6 43 név
38 név 6 7 4
--
-- This module implements many bracket templates
--

local p = {}
local args = {}
local rows = {}
local mask = {}
local rounds
local maxround
local legs = {}
local compact
local byes
local hideSeeds
local showSeeds
local hideHeadings
local showThird
local offsetThird
local compactFinal
local sepwidth
local aggsep
local aggregate
local boldwinner
local boldseed
local hideomittedscores
local RD1seedmap = {}
local tcats = ''

local function isnotblank(s)
	return s and s ~= ''
end

local function isblank(s)
	return (not s) or (s == '')
end

local function sumScores(s1, s2)
	s1 = mw.ustring.gsub(s1 or '', '^[\'%s]*([%d%.]*).-$', '%1')
	s2 = mw.ustring.gsub(s2 or '', '^[\'%s]*([%d%.]*).-$', '%1')
	if s1 ~= '' and s2 ~= '' then
		return tonumber(s1) + tonumber(s2)
	end
	return s1
end

local function scoreCompare(s1,s2,highwin)
	local ps1 = mw.ustring.gsub(s1 or '', '^[\'%s]*([%d%.]*)[\'%s]*%([\'%s]*([%d%.]*)[\'%s]*%).-$', '%2')
	local ps2 = mw.ustring.gsub(s2 or '', '^[\'%s]*([%d%.]*)[\'%s]*%([\'%s]*([%d%.]*)[\'%s]*%).-$', '%2')
	s1 = mw.ustring.gsub(s1 or '', '^[\'%s]*([%d%.]*).-$', '%1')
	s2 = mw.ustring.gsub(s2 or '', '^[\'%s]*([%d%.]*).-$', '%1')
	
	if s1 ~= '' and s2 ~= '' then
		s1 = tonumber(s1)
		s2 = tonumber(s2)
		if s1 and s2 then
			if (s1 == s2) then
				ps1 = tonumber(ps1)
				ps2 = tonumber(ps2)
				if ps1 and ps2 then
					s1 = ps1
					s2 = ps2
				end
			end
			if highwin then
				return ((s1 > s2) and 1) or ((s1 < s2) and 2) or 0
			else
				return ((s2 > s1) and 1) or ((s2 < s1) and 2) or 0
			end
		end
	end
	return 0
end

local function parseArgs(frame)
	local fargs = frame.args
	local pargs = frame:getParent().args;

	local r = tonumber(fargs.rounds or '') or tonumber(pargs.rounds or '') or 2
	local teams = math.pow(2, r)
	local rdstr = 'RD' .. tostring(r)
	local rdbstr = 'RD' .. tostring(r) .. 'b'
	local rdp1str = 'RD' .. tostring(r+1)

	for i=1,2 do
		local targs = (i == 1) and pargs or fargs
		for k,v in pairs(targs) do
			if type(k) == 'string' then
				if k:find('^[R3][Dr][d1-9]b?%-[a-z][a-z]*00*') then
					k = mw.ustring.gsub(k, '^([R3][Dr][d1-9]b?%-[a-z][a-z]*)00*', '%1')
					if (teams < 10) then 
						tcats = tcats .. '[[Kategória:TeamBracket modul használata elavult szintaxissal|P]]'
					end
				end
				if k:find('^' .. rdp1str) then
					k = mw.ustring.gsub(k, '^' .. rdp1str, '3rd')
					tcats = tcats .. '[[Kategória:TeamBracket modul használata elavult szintaxissal|3]]'
				elseif k:find('^' .. rdbstr) then
					k = mw.ustring.gsub(k, '^' .. rdbstr, '3rd')
				elseif k:find('^' .. rdstr .. '%-[a-z][a-z]*3') then
					k = mw.ustring.gsub(k, '^' .. rdstr .. '(%-[a-z][a-z]*)3', '3rd%11')
				elseif k:find('^' .. rdstr .. '%-[a-z][a-z]*4') then
					k = mw.ustring.gsub(k, '^' .. rdstr .. '(%-[a-z][a-z]*)4', '3rd%12')
				elseif  k:find('^Consol') then
					k = mw.ustring.gsub(k, '^Consol', '3rd')
					tcats = tcats .. '[[Kategória:TeamBracket modul használata elavult szintaxissal|3]]'
				elseif k:find('^group[0-9]') then
					tcats = tcats .. '[[Kategória:TeamBracket modul használata elavult szintaxissal|G]]'
				end
			end
			args[k] = v
		end
	end

	if (args['byes'] and (args['byes'] == 'yes' or args['byes'] == 'y')) then
		tcats = tcats .. '[[Kategória:TeamBracket modul használata elavult szintaxissal|B]]'
	end
end

local function parseSeedmap(s)
	s = mw.text.split((s or '0') .. '/', '[%s]*/[%s]*')
	local teams = math.pow(2, rounds)
	for r=1,teams do
		RD1seedmap[r] = 1
	end
	for r=1,#s do
		if tonumber(s[r] or 'x') then
			RD1seedmap[tonumber(s[r])] = 0
		end
	end
	local c = 1
	for r=1,teams do
		if RD1seedmap[r] > 0 then
			RD1seedmap[r] = c
			c = c + 1
		end
	end
end

local function parseLegs(s)
	s = mw.text.split((s or '1') .. '/', '[%s]*/[%s]*')
	if aggregate == 'n' or aggregate == 'no' or aggregate == '0' then
		aggregate = ''
	end
	local n = showThird and (rounds + 1) or (rounds)
	local lastlegs = nil
	for r=1,n do
		if s[r] ~= nil and s[r] ~= '' and tonumber(s[r]) then
			legs[r] = tonumber(s[r])
		elseif lastlegs then
			legs[r] = lastlegs
		else
			legs[r] = 1
		end
		lastlegs = legs[r]
		if legs[r] > 1 and aggregate ~= '' then
			legs[r] = legs[r] + 1
		end
	end
end

local function getSeeds()
	local seeds = {1, 2}
	local count = 2
	local before = false
	for r = 2, rounds do
		local max = math.pow(2, r)
		for i = 1, count do
			local pos = i * 2
			if before then pos = pos - 1 end
			table.insert(seeds, pos, max - seeds[i * 2 - 1] + 1)
			before = not before
		end
		count = count * 2
	end
	return seeds
end

local function addTableRow(tbl)
	return tbl:tag('tr')
end

local function addBlank(i, css, rowspan, colspan)
	local row = rows[i]
	rowspan = rowspan or 1
	local jmax = i + rowspan - 1
	for j = i, jmax do
		if rows[j] == nil then
			rowspan = rowspan - 1
		elseif row == nil then
			row = rows[j]
		end
	end
	local cell = row and row:tag('td') or mw.html.create('td')
	if rowspan and rowspan > 1 then
		cell:attr('rowspan', rowspan)
	end
	if colspan and colspan > 1 then
		cell:attr('colspan', colspan)
	end
	if css then
		cell:css(css)
	end
	return cell
end

local function addBorders(cell, topcell, seedorteam, extrasep)
	if sepwidth > 1 then topcell = true end
	if seedorteam then
		cell:css('border', '1px solid #aaa')
			:css('border-top-width', topcell and '1px' or '0')
	else
		cell:css('border-color', '#aaa')
			:css('border-style', 'solid')
			:css('border-top-width', topcell and '1px' or '0')
			:css('border-left-width', (extrasep and '1px') or ((sepwidth > 1) and '1px') or '0')
			:css('border-right-width', '1px')
			:css('border-bottom-width', '1px')
	end
end

local function addHeading(row, r, text, pad)
	pad = (pad == nil or pad < 0) and 0 or pad
	row:tag('td')
		:attr('colspan', tonumber(hideSeeds and '1' or '2') + legs[r] + pad)
		:css('text-align', 'center')
		:css('border', '1px solid #aaa')
		:css('background-color', args['RD-shade'] or '#f2f2f2')
		:wikitext(text)
		:newline()
end

local function getWidth(param, default)
	local arg = args[param .. '-width']
	if isblank(arg) then
		arg = default
	end
	if tonumber(arg) ~= nil then
		arg = arg .. 'px'
	end
	return arg
end

local function getTeamArgName(round, type, team)
	if round > rounds then
		return string.format('3rd-%s%d', type, team)
	else
		if (round == 1) then
			team = RD1seedmap[team]
			if team == 0 then
				return 'NIL'
			end
		end
		return string.format('RD%d-%s%d', round, type, team)
	end
end

local function getShadeArg(round, team, s)
	local argname = getTeamArgName(round, 'shade', team) .. (s and ('-' .. s) or '')
	local value = args[argname]
	if isblank(value) then
		return '#f9f9f9'
	end
	return value
end

local function getScoreArg(round, team, s)
	local argname = getTeamArgName(round, 'score', team) .. (s and ('-' .. s) or '')
	local value = args[argname]
	return value
end

local function getTeamArg(round, type, team)
	local argname = getTeamArgName(round, type, team)
	local value = args[argname]
	if isblank(value) then
		return ''
	end
	if mw.ustring.find(value, '[%s]*<[%s/]*[Bb][Rr][%s/]*>[%s ]*&[Nn][Bb][Ss][Pp];[%s]*') then
		tcats = tcats .. '[[Kategória:TeamBracket modul használata nbsp karakterrel]]'
	end
	return mw.ustring.gsub(value, '[%s]*<[%s/]*[Bb][Rr][%s/]*>[%s ]*&[Nn][Bb][Ss][Pp];[%s]*', '<br/>')
end

local function isHidden(r, team)
	return isblank( getTeamArg(r, 'team', team) )
end

local function getRoundName(round)
	local name = args['RD' .. round]
	if isnotblank(name) then
		return name
	end
	local roundFromLast = rounds - round + 1
	if roundFromLast == 1 then
		return "Döntő"
	elseif roundFromLast == 2 then
		return "Elődöntők"
	elseif roundFromLast == 3 then
		return "Negyeddöntők"
	else
		return round .. ". forduló"
	end
end

local function addPath(index, round, top, left, w)
	local prop = top and 'border-bottom-width' or 'border-top-width'
	if left and round == 1 then
		if compact then
			addBlank(index)
		else
			addBlank(index, {['height'] = '7px'})
			addBlank(index+1, {['height'] = '7px'})
		end
		return nil
	else
		local cell = addBlank(index, 
			{['border-width'] = '0',
			['border-style'] = 'solid',
			['border-color'] = 'black'}, (not compact) and 2 or 1)
		if left or round < maxround and not left then
			cell:css(prop, w or '2px')
		end
		return cell
	end
end

local function renderTeam(row, round, team, top, otherbye, pad)
	pad = (pad == nil or pad < 0) and 0 or pad
	tcs = pad + 1
	local seedCell
	local seedArg = getTeamArg(round, 'seed', team)
	-- seed value for the paired team
	local otherteam = team % 2 == 0 and team-1 or team+1
	local pairSeedArg = otherbye and '' 
		or getTeamArg(round, 'seed', otherteam)
	-- show seed if seed is defined for either or both
	local showSeed = showSeeds
		or isnotblank(seedArg)
		or isnotblank(pairSeedArg)
	if showSeed and (not hideSeeds) then
		seedCell = row:tag('td')
			:css('text-align', 'center')
			:css('background-color', '#f2f2f2')
			:attr('rowspan', (not compact) and '2' or nil)
			:wikitext(seedArg)
			:newline()
		addBorders(seedCell, top or otherbye, true, false)
	end

	local teamArg = getTeamArg(round, 'team', team)
	if isblank(teamArg) then
		teamArg = '&nbsp;'
	end
	
	if not showSeed and (not hideSeeds) then
		tcs = tcs + 1
	end

	local teamCell = row:tag('td')
		:css('background-color', '#f9f9f9')
		:css('padding', '0 2px')
		:attr('rowspan', (not compact) and '2' or nil)
		:attr('colspan', (tcs > 1) and tcs or nil)
		:wikitext(teamArg)
		:newline()
	addBorders(teamCell, top or otherbye, true, false)

	local scoreCells = {}
	local wins, otherwins = 0, 0
	local sumscore, othersumscore = 0, 0
	local teamcolspan = tcs
	local hassum = false
	for s = 1, legs[round] do
		local fw = nil
		local agg = legs[round] > 1 and s == legs[round] and true or false
		local score1 = (agg and getScoreArg(round, team, 'agg') or nil) or 
			getScoreArg(round, team, s) or ((legs[round] == 1) and getScoreArg(round, team)) or nil
		local score2 = (agg and getScoreArg(round, otherteam, 'agg') or nil) or 
			getScoreArg(round, otherteam, s) or ((legs[round] == 1) and getScoreArg(round, otherteam)) or nil
		local showscore = true
		if agg and aggregate ~= '' and score1 == nil and hassum then
			score1 = (aggregate == 'score')	and sumscore 
				or ((aggregate == 'legs' or aggregate == 'sets') and wins)
				or nil
		end
		if agg and aggregate ~= '' and score2 == nil and hassum then
			score2 = (aggregate == 'score')	and othersumscore
				or ((aggregate == 'legs' or aggregate == 'sets') and otherwins)
				or nil
		end
		if score1 == nil and score2 == nil then
			if hideomittedscores > 0 and s >= hideomittedscores then
				teamcolspan = teamcolspan + 1
				showscore = false
			end
		else
			hassum = true
		end
		if showscore then
			local winner = scoreCompare(score1, score2, boldwinner ~= 'low')
			sumscore = sumScores(sumscore, score1)
			othersumscore = sumScores(othersumscore, score2)
			if winner == 1 then
				if boldwinner ~= '' or (agg and (aggregate == 'score' or aggregate == 'legs' or aggregate == 'sets')) then 
					if agg and (aggregate == 'legs' or aggregate == 'sets') and (wins <= (legs[round] - 1)/2) then
					else
						fw = 'bold'
					end
				end
				if not (agg and (aggregate == 'score' or aggregate == 'legs' or aggregate == 'sets')) then wins = wins + 1 end
			elseif winner == 2 then
				if not (agg and (aggregate == 'score' or aggregate == 'legs' or aggregate == 'sets')) then otherwins = otherwins + 1 end
			end
			scoreCells[s] = row:tag('td')
				:css('text-align', 'center')
				:css('background-color', getShadeArg(round, team, s))
				:css('font-weight', fw)
				:attr('rowspan', (not compact) and '2' or nil)
				:wikitext(score1)
				:newline()
			addBorders(scoreCells[s], top or otherbye, false, s > 1 and s == legs[round] and aggsep or nil)
		end
	end
	if teamcolspan > 1 then
		teamCell:attr('colspan', teamcolspan)
	end
	if boldwinner ~= '' and wins > otherwins then
		if (aggregate == 'legs' or aggregate == 'sets') and (wins <= (legs[round] - 1)/2) then
		else
			if seedCell then
				if boldseed == 'no' then
				else
				seedCell:css('font-weight', 'bold')
				end
			end
			if teamCell then
				teamCell:css('font-weight', 'bold')
			end
		end
	end
end

local function renderRound(count, r)
	local teams = math.pow(2, rounds - r + 1)
	local step = count / teams
	local topTeam = true -- is top row in match-up
	local topPair = true -- is top match-up in pair of match-ups
	local team = 1
	local group = 1

	for i = 1, count, step do
		local offset, height, blank

		local hideteam = false
		local otherhideteam = false
		local hideleftpath = false
		local hiderightpath = false
		if r <= byes then
			hideteam = isHidden(r, team)
			otherhideteam = isHidden(r, team % 2 == 0 and team-1 or team+1)
		end
		if (r == 1) and (RD1seedmap[team] <= 0) then
				hideteam = true
		end
		if (r > 1) and (r <= (byes + 1)) then
			hideleftpath = isHidden(r-1, 2*team-1) and isHidden(r-1, 2*team)
		end
		if (r == 2) and (RD1seedmap[2*team-1] <= 0 and RD1seedmap[2*team] <= 0) then
			hideleftpath = true
		end
		if compactFinal and (r == rounds) then
			hideleftpath = true
		end
		if (tonumber(args['RD' .. (r-1) .. '-RD' .. (r) .. '-path']) or 2) == 0 then
			hideleftpath = true
		end
		if (tonumber(args['RD' .. (r) .. '-RD' .. (r + 1) .. '-path']) or 2) == 0 then
			hiderightpath = true
		end

		-- empty space above or below
		if compact then
			offset = topTeam and i or i + 1
			height = step - 1
		-- leave room for groups for teams other than first and last
		elseif team == 1 or team == teams then
			offset = topTeam and i or i + 2
			height = step - 2
		else
			offset = topTeam and i + 1 or i + 2
			height = step - 3
		end
		if showThird and (r == rounds) and (not topTeam) then
			height = offset - offsetThird
		end
		if compactFinal and (r == (maxround - 1)) then
			if team == 2 then
				height = height - 3
			end
			if team == 3 then
				height = height - 1
				offset = offset + 1
				addBlank(offset-3, nil, 1, tonumber(hideSeeds and '2' or '3') + legs[r])
				addBlank(offset-4)
				addHeading(rows[offset-4], r + 1, getRoundName(r+1), legs[r] - legs[r+1])
				local b = addBlank(offset-4, {
					['border-color'] = 'black',
					['border-style']= 'solid',
					['border-width']= '0'}, 2)
				b:css('border-right-width', '2px')
			end
		end
		if height > 0 then
			local pad = 0
			local betweenTeams = (topTeam == false and topPair == true) or (topTeam == true and topPair == false)
			if compactFinal and (r == maxround - 1) then
				betweenTeams = false
			end
			if compactFinal and (r == maxround - 1) and legs[r+1] > legs[r] then
				pad = legs[r+1] - legs[r]
			end
			if compact and betweenTeams then
				addBlank(offset, nil, height, 1)
				if topPair then
					blank = addBlank(offset, nil, 2*height, tonumber(hideSeeds and '1' or '2') + legs[r] + pad)
					if args['RD' .. r .. '-group' .. group] then
						blank:wikitext(args['RD' .. r .. '-group' .. group])
						blank:css('text-align', 'center')
					end
					group = group + 1
				end
				blank = addBlank(offset, 
				{['border-width'] = '0',
				['border-style'] = 'solid',
				['border-color'] = 'black'},
				height, 1)
			else
				blank = addBlank(offset, 
				{['border-width'] = '0',
				['border-style'] = 'solid',
				['border-color'] = 'black'},
				height, tonumber(hideSeeds and '3' or '4') + legs[r] + pad)
			end
		end
		-- add bracket
		local j = topTeam and i + step - (compact and 1 or 2) or i
		-- add left path
		addPath(j, r, topTeam, true, hideleftpath and '0' or '2px')
		if hideteam then
			addBlank(j, nil, (not compact) and 2 or nil, tonumber(hideSeeds and '1' or '2') + legs[r])
		elseif rows[j] then
			if compactFinal and (r == maxround) then
				renderTeam(rows[j], r, team, topTeam, otherhideteam, legs[r-1] - legs[r])
			elseif compactFinal and (r == maxround - 1) then
				renderTeam(rows[j], r, team, topTeam, otherhideteam, legs[r+1] - legs[r])
			else
				renderTeam(rows[j], r, team, topTeam, otherhideteam)
			end
		end
		local rightPath = addPath(j, r, topTeam, false, (hiderightpath or hideteam) and '0' or '2px')
		if not topTeam then topPair = not topPair end
		if not topPair and r < maxround and (not (hiderightpath or hideteam)) then
			if blank then blank:css('border-right-width', '2px') end
			rightPath:css('border-right-width', '2px')
		end
		if compactFinal and (r == maxround) then
			local prop = (team == 1) and 'border-bottom-width' or 'border-top-width'
			rightPath:css('border-right-width', '2px')
				:css(prop, '2px')
		end
		team = team + 1
		topTeam = not topTeam
	end
end

local function renderGroups(count, round)
	local roundFromLast = rounds - round + 1
	local groups = math.pow(2, roundFromLast - 2)
	local step = count / groups
	local group = 1
	local offset = 0
	local team = 0
	local wdef = (tonumber(args['RD' .. (round) .. '-RD' .. (round + 1) .. '-path']) or 2) .. 'px'
	local w = wdef

	for r = 1,round do
		offset = offset + (hideSeeds and 3 or 4) + legs[r]
	end
	for i = step / 2, count, step do
		local name = 'RD' .. round .. '-group' .. group
		addBlank(i, {['height'] = '7px'})
		addBlank(i+1, {['height'] = '7px'})
		addBlank(i, {['text-align'] = 'center'}, 2, offset-2)
			:wikitext(args[name])
			:newline()
		if (round <= byes) then
			team = i/(step/2)
			w = isHidden(round, 2*team-1) and isHidden(round, 2*team) and '0' or wdef
		end
		if (round < maxround) then
			addBlank(i, {
				['border-color'] = 'black',
				['border-style'] = 'solid', 
				['border-width'] = '0 ' .. w .. ' 0 0'})
		else
			addBlank(i)
		end
		if (round <= byes) then
			team = team + 1
			w = isHidden(round, 2*team-1) and isHidden(round, 2*team) and '0' or wdef
		end
		if (round < maxround) then
			addBlank(i+1, {
				['border-color'] = 'black',
				['border-style'] = 'solid', 
				['border-width'] = '0 ' .. w .. ' 0 0'})
		else
			addBlank(i+1)
		end
		group = group + 1
	end
end

local function getThirdOffset()
	local offset = (compact and 1 or 3) * (math.pow(2, rounds) - math.pow(2, rounds-3)) - (compact and 2 or 4)
	if rounds < 4 then
		offset = compact and 8 or 17
		if rounds < 3 then
			offset = compact and 6 or 10
			if rounds < 2 then
				offset = compact and 4 or 7
			end
		end
	end
	return offset
end

local function renderThird(count)
	local k = offsetThird
	local row = rows[k]
	local blank
	if rounds < 2 then
		blank = addBlank(k-1, {['height'] = '7px'})
	end
	blank = addBlank(k, rounds < 2 and {['height'] = '7px'} or nil)
	addHeading(row, rounds + 1, args['3rd'] or 'Bronzmérkőzés')
	if rounds < 2 then
		for i = 1,(compact and 1 or 2) do
			blank = addBlank(k+i, {['height'] = '7px'})
		end
	end
	k = k + (compact and 2 or 3)
	for i = 1,2 do
		row = rows[k]
		blank = addBlank(k, rounds < 2 and {['height'] = '7px'} or nil)
		if row then
			renderTeam(row, rounds + 1, i, i == 1, false)
		end
		if rounds < 2 and not compact then
			blank = addBlank(k+1, {['height'] = '7px'})
		end
		k = k + (compact and 1 or 2)
	end
end

local function maskRows(tbl, count, offsetcount)
	local rmin = 1
	local rmax = count
	for i = rmin, rmax do
		mask[i] = false
	end
	if showThird then
		for i = offsetThird,(offsetThird+ (compact and 3 or 5)) do
			rmax = (i > rmax) and i or rmax
			mask[i] = true
		end
	end
	for r = 1, maxround do
		local teams = math.pow(2, rounds - r + 1)
		local step = count / teams
		local topTeam = true -- is top row in match-up
		local team = 1

		for i = 1, count, step do
			local offset, height, blank
			local hideteam = false
			if r <= byes then
				hideteam = isHidden(r, team)
			end
			if (r == 1) and (RD1seedmap[team] <= 0) then
				hideteam = true
			end
			if not hideteam then
				local j = topTeam and i + step - (compact and 1 or 2) or i
				mask[j] = true
			end
			team = team + 1
			topTeam = not topTeam
		end
	end
	
	for r = 1, maxround do
		local roundFromLast = rounds - r + 1
		local groups = math.pow(2, roundFromLast - 2)
		local step = count / groups
		local group = 1
		for i = step / 2, count, step do
			if args['RD' .. r .. '-group' .. group] then
				mask[i] = true
				mask[i+1] = true
			end
			group = group + 1
		end
	end
	local mmin, mmax = rmax, rmin
	for i = rmin, rmax do
		if mask[i] == true then
			mmin = (i < mmin) and i or mmin
			mmax = (i > mmax) and i or mmax
		end
	end
	for i = mmin, mmax do
		rows[i] = addTableRow(tbl)
	end
end

local function renderTree(tbl)
	-- create 3 or 1 rows for every team
	local count = math.pow(2, rounds) * (compact and 1 or 3)
	local offsetcount = 2 * (compact and 1 or 3) + (compact and 2 or 3)
	offsetThird = getThirdOffset()
	maskRows(tbl, count, offsetcount)
	if showThird then
		for i = (count+1), (offsetcount + offsetThird) do
			if (rounds > 1) then
				local blank = addBlank(i, nil, 1, tonumber(hideSeeds and '3' or '4') + legs[1])
				if compact and (rounds > 2) then
					blank = addBlank(i, nil, 1, tonumber(hideSeeds and '3' or '4') + legs[1])
				end
			end
		end
	end
	if not compact then
		-- fill rows with groups
		for r = 1, rounds - 1 do
			renderGroups(count, r)
		end
	end
	-- fill rows with bracket
	for r = 1, maxround do
		renderRound(count, r)
	end
	if showThird then
		renderThird(count, compact)
	end
end

local function renderHeadings(tbl)
	local titleRow = addTableRow((not hideHeadings) and tbl or mw.html.create('table'))
	local widthRow = addTableRow(tbl)
	for r = 1, (compactFinal and (maxround-1) or maxround) do
		titleRow:tag('td')
		widthRow:tag('td'):css('width', r > 1 and '5px' or '1px')
		if compactFinal and r == (maxround-1) then
			addHeading(titleRow, r, getRoundName(r), legs[r+1] - legs[r])
		else
			addHeading(titleRow, r, getRoundName(r) )
		end
		local seedCell
		if (not hideSeeds) then
			seedCell = widthRow:tag('td'):css('width', getWidth('seed', '25px'))
		end
		local teamCell = widthRow:tag('td'):css('width', getWidth('team', '150px'))
		local scoreCells = {}
		local legsr = legs[r]
		if compactFinal and r == (maxround-1) then
			legsr = legs[r+1] > legs[r] and legs[r+1] or legs[r]
		end
		for s = 1, legsr do
			scoreCells[s] = widthRow:tag('td'):css('width', getWidth('score', '25px'))
		end
		titleRow:tag('td')
		widthRow:tag('td'):css('width', r < rounds and '5px' or '1px')

		if compact then
			teamCell:css('height', '7px')
		else
			if seedCell then
				seedCell:wikitext('&nbsp;')
			end
			teamCell:wikitext('&nbsp;')
			for s = 1, legs[r] do
				scoreCells[s]:wikitext('&nbsp;')
			end
		end
	end
end

function p.main(frame)
	parseArgs(frame)
	rounds = tonumber(args.rounds) or 2
	maxround = tonumber(args.maxround) or rounds
	local teams = math.pow(2, rounds)
	compact = (args['compact'] and (args['compact'] == 'yes' or args['compact'] == 'y'))
	compactFinal = ((rounds > 4) and compact and args['compact-final'] and (args['compact-final'] == 'yes' or args['compact-final'] == 'y'))
	sepwidth = tonumber(args['sepwidth'] or ((args.sets or args.legs) and 1) or (compact and 1) or 2) or 1
	aggregate = (args['aggregate'] or ''):lower()
	aggsep = args['aggsep'] or args['aggregate'] or nil
	boldwinner = args['boldwinner'] or args['bold_winner'] or ''
	boldseed = args['boldseed'] or args['bold_seed'] or ''
	local autoSeeds = (args['autoseeds'] and (args['autoseeds'] == 'yes' or args['autoseeds'] == 'y'))
	hideSeeds = (args['seeds'] and (args['seeds'] == 'no' or args['seeds'] == 'n'))
	showSeeds = (args['seeds'] and (args['seeds'] == 'yes' or args['seeds'] == 'y'))
	byes = (args['byes'] and (args['byes'] == 'yes' or args['byes'] == 'y') and 1) or (tonumber(args['byes'] or '0') or 0)
	hideomittedscores = (args['hideomittedscores'] and (args['hideomittedscores'] == 'yes' or args['hideomittedscores'] == 'y') and 1) or (tonumber(args['hideomittedscores'] or '0') or 0)
	hideHeadings = (args['headings'] and (args['headings'] == 'no' or args['headings'] == 'n'))
	showThird = isnotblank(args['3rd']) or isnotblank(args['3rd-team1']) or isnotblank(args['3rd-team2'])
	local align = (args['float'] or args['align'] or ''):lower()
	local clear = args['clear'] or 'none'
	parseSeedmap(args['RD1-omit'])
	parseLegs(args.sets or args.legs)
	
	if autoSeeds then
		-- set default seeds for round 1
		local seeds = getSeeds()
		for i = 1, table.getn(seeds) do
			local argname = getTeamArgName(1, 'seed', i)
			if not args[argname] then
				args[argname] = seeds[i]
			end
		end
	end

	-- create the table
	local tbl = mw.html.create('table')
		:css('border-style', 'none')
		:css('font-size', '90%')
		:css('border-collapse', 'separate')
		:css('border-spacing', '0')
		:attr('cellpadding', '0')

	if (args['nowrap'] and (args['nowrap'] == 'yes' or args['nowrap'] == 'y')) then
		tbl:css('white-space', 'nowrap')
	end
	
	if align == 'right' then
		tbl:css('float', 'right')
		if clear ~= 'none' and clear ~= 'no' and clear ~= 'n' then
			tbl:css('clear', 'right')
		end
		tbl:css('margin', '1em 0 1em 2em')
	elseif align == 'left' then
		tbl:css('float', 'left')
		if clear ~= 'none' and clear ~= 'no' and clear ~= 'n' then
			tbl:css('clear', 'left')
		end
		tbl:css('margin', '1em 2em 1em 0')
	elseif align == 'center' or align == 'centre' then
		tbl:css('margin', '1em auto')
	else
		tbl:css('margin', '1em 2em 1em 1em')
	end

	renderHeadings(tbl)
	renderTree(tbl)
	if (args['wide'] and (args['wide'] == 'y' or args['wide'] == 'yes')) then
		return '<div class="noresize" style="overflow:auto">' .. tostring(tbl) .. '</div>' .. tcats
	end
	return tostring(tbl) .. tcats
end

function p.teamBracket(frame)
	return p.main(frame)
end

return p