Permanently protected module
From Wikipedia, the free encyclopedia


-- Implements [[Template:Football box collapsible]]

local p = {}



local labels = {

	'penalties' = '[[Penalty shoot-out (association football)|Penalties]]',

	'shootout' = '[[Penalty shoot-out (association football)#North American experiments|Shootout]]',

	'pen' = '[[Penalty shoot-out (association football)|p]]',

	'so' = '[[Penalty shoot-out (association football)|SO]]',

	'aet' = '[[Overtime (sports)#Association football|a.e.t.]]',

	'agg' = '[[Playoff format#Total points series (aggregate)|agg.]]',

	'stadium' = 'Stadium:', 

	'attendance' = 'Attendance:',

	'referee' = 'Referee:',

	'assistantreferees' = 'Assistant referees:',

	'assistantreferee2' = '<span style="visibility:hidden">Assistant referees:</span>',

	'fourthofficial' = 'Fourth official:',

	'fifthofficial' = 'Fifth official:',

	'goallineassistants' = 'Goal-line assistants:',

	'goallineassistant2' = '<span style="visibility:hidden">Goal-line assistants:</span>',

	'motm' = 'Man of the Match:',

	'potm' = 'Player of the Match:',

	'mvp' = 'MVP:',

	'note' = 'Note:',

	'seealso' = 'See also:'

}

local colors = {

	"W" = "BBF3BB",

	"L" = "FFBBBB",

	"T" = "D" , "D" = "FFFFBB",

	"SW" = "PW", "PW" = "BBF3FF",

	"V" = "P", "P" = "BBBBBB"

}



local tracking, preview



local function checkarg(k,v)

	if k and type(k) == 'string' then

		if k == 'id' or k == 'team1' or k == 'team2' or k == 'class' or 

			k == 'nobars' or k == 'size' or 

			k == 'result' or k == 'bg' or k == 'format' or k == 'date' or k == 'scorenote' or

			k == 'round' or k == 'score' or k == 'aet' or k == 'aggregatescore' or 

			k == 'penaltyscore' or k == 'location' or k == 'stadium' or 

			k == 'time' or k == 'goals1' or k == 'report' or k == 'goals2' or 

			k == 'attendance' or k == 'referee' or k == 'assistantreferees' or 

			k == 'assistantreferee2' or k == 'fourthofficial' or 

			k == 'fifthofficial' or k == 'goallineassistants' or 

			k == 'goallineassistant2' or k == 'potm' or k == 'motm' or 

			k == 'mvp' or k == 'penalties1' or k == 'penalties2' or k == 'note' or 

			k == 'shootoutscore' or k == 'shootout1' or k == 'shootout2' or

			k == 'seealso' or k == 'stack' or k == 'section' or k == 'transcludedsection' then

			-- valid and not tracked

		else

			-- invalid

			local vlen = mw.ustring.len(k)

			k = mw.ustring.sub(k, 1, (vlen < 25) and vlen or 25) 

			k = mw.ustring.gsub(k, '[^%w%-_ ]', '?')

			table.insert(tracking, '[[Category:Pages using football box collapsible with unknown parameters|' .. k .. ']]')

			table.insert(preview, '"' .. k .. '"')

		end

	end

end



local function isnotempty(s)

	return s and s:match( '^%s*(.-)%s*$' ) ~= ''

end



local function trim(s)

	if isnotempty(s) then

		s = s:match('^[\'"%s]*(.-)[\'"%s]*$')

		return isnotempty(s) and s or nil

	end

	return nil

end



local function bold(s)

	if isnotempty(s) then

		return "'''" .. s .. "'''"

	end

	return ""

end



local function italic(s)

	if isnotempty(s) then

		return "''" .. s .. "''"

	end

	return ""

end



local function small(s)

	if isnotempty(s) then

		return '<small>' .. s .. '</small>'

	end

	return ''

end



local function nowrap(s)

	if isnotempty(s) then

		return '<span style="white-space:nowrap">' .. s .. '</span>'

	end

	return ''

end



local function background(frame, c, r, bg)

	local data = colors

	local res = datar:upper()]

	if res then

		res = '#' .. (datares or res)

	elseif isnotempty(bg) then

		res = '#' .. bg

	else

		res = 'transparent'

	end

	return res

end



local function teamname(team)

    local prefix, suffix, b = "", "", "'''";



    if mw.ustring.sub(team,1,3) ~= b and mw.ustring.sub(team,-3) ~= b then

        prefix = '<span class="fn org">' .. b .. ' ';

        suffix = ' ' .. b .. "</span>";

    else

        if mw.ustring.sub(team,1,3) == b then

            prefix = '<span class="fn org">';

            team = mw.ustring.sub(team,4);

        else

            prefix = '<span class="fn org">' .. b;

        end



        if mw.ustring.sub(team,-3) == b then

            suffix = "</span>";

            team = mw.ustring.sub(team,1,mw.ustring.len(team)-3);

        else

            suffix = b .. "</span>";

        end

    end

        

    return prefix .. team .. suffix;

end



local function score(s, a, ag, p, so)

	s = nowrap(bold(s ~= '' and s or 'v'))

	if a ~= '' then

		s = s .. small(' (' .. labels'aet' .. ')')

	end

	if ag ~= '' then

		s = s .. '<br>' .. small(' (' .. bold(ag) .. ' ' .. labels'agg' .. ')')

	end

	if p ~= '' then

		s = s .. '<br>' .. small(' (' .. bold(p) .. ' ' .. labels'pen' .. ')')

	elseif so ~= '' then

		s = s .. '<br>' .. small(' (' .. bold(so) .. ' ' .. labels'so' .. ')')

	end

	return s

end

 

local function fmtlist(s)

	s = mw.ustring.gsub(s or '', '%[%[ *([%?-]) *%]%]', '%1')

	s = mw.ustring.gsub(s, '%[%[ *[%?-] *| *(.-) *%]%]', '%1')

	if mw.ustring.sub(s, 1, 1) == '*' then

		-- could also expand plainlist here

		return mw.getCurrentFrame():extensionTag{

			name = 'templatestyles', args = { src = 'Plainlist/styles.css' }

		} .. tostring(  mw.html.create('div'):addClass('plainlist'):newline():wikitext(s))

	end

	return s

end



local function makelink(s,t)

	if s:match('^[Hh][Tt][Tt][Pp][Ss]?:[^ ]*$') then

		return '[' .. s .. ' ' .. t .. ']'

	end

	return s

end



function p.main(frame)

	-- Exit early if we are using section transclusion for a different section

	local tsection = frame:getParent().args'transcludesection' or frame:getParent().args'section' or ''

	local bsection = frame.args'section' or ''

	if( tsection ~= '' and bsection ~= '' ) then

		if( tsection ~= bsection ) then

			return ''

		end

	end



	local args = (frame.args'team1' or frame.args'team2']) and frame.args or frame:getParent().args

	local id = trim(args'id'])

	local bars = (args'nobars' == nil) or (args'bars' == '')

	local class = trim(args'class' or 'mw-collapsible mw-collapsed') or ''

	local width1 = {['1' = '28%', '1.1' = '22%', '1.2' = '28%', 'default' = '19%'}

	local width2 = {['1' = '19%', '1.1' = '25%', '1.2' = '19%', 'default' = '23%'}

	local width3 = {['1' =  '8%', '1.1' =  '8%', '1.2' =  '8%', 'default' = '12%'}

	local width4 = {['1' = '19%', '1.1' = '19%', '1.2' = '26%', 'default' = '23%'}

	local width5 = {['1' = '26%', '1.1' = '26%', '1.2' = '19%', 'default' = '23%'}

	local location = nil

	local extra = {}

	local notes = {}

	

	tracking, preview = {}, {}

    for k, v in pairs(args) do

    	if v ~= '' then

    		checkarg(k,v)

    	end

	end

	

	if args'class' then

		if args'class' == 'collapsible' or args'class' == 'mw-collapsible' or args'class' == 'uncollapsed' then 

			--valid

		elseif args'class' == '' then

			table.insert(tracking,'[[Category:Pages using football box collapsible with blank class parameter]]')

		else

			table.insert(tracking,'[[Category:Pages using football box collapsible with class parameter]]')

		end

	end

	

	if isnotempty(args'stack']) then

		table.insert(tracking, '[[Category:Pages using football box collapsible with unsupported stack parameter]]')

	end

	

	-- required parameters

	for i, k in ipairs({'team1', 'team2'}) do

		if argsk == nil then argsk = '{{{' .. k .. '}}}' end

	end

	-- vcard for stadium

	if isnotempty(args'stadium']) then

		args'stadium' = tostring(mw.html.create('span'):addClass('location'):wikitext(args'stadium']))

	end



	-- placement of stadium and location information

	if isnotempty(args'location']) then

		location = args'location'

		if isnotempty(args'stadium']) then

			table.insert(extra, labels'stadium' .. ' ' .. args'stadium'])

		end

	elseif isnotempty(args'stadium']) then

		location = args'stadium'

	end



	-- remaining extra information

	for i, k in ipairs({'attendance', 'referee', 'assistantreferees', 

		'assistantreferee2', 'fourthofficial', 'fifthofficial', 

		'goallineassistants', 'goallineassistant2', 'potm', 'motm', 'mvp'}) do

		if isnotempty(argsk]) then

			table.insert(extra, labelsk .. ' ' .. argsk])

		end

	end

	

	-- score

	local scorestr = ''

	if args'score1' or args'score2' then

		scorestr = (args'score1' or '0') .. '&ndash;' .. (args'score2' or '0')

	elseif args'score' then

		scorestr = args'score'

	end

	if args'scorenote' then

		scorestr = scorestr .. '<br>' .. args'scorenote'

	end

	

	-- notes

	if isnotempty(args'note']) then

		table.insert(notes, "''" .. labels'note' .. " " .. args'note' .. "''")

	end

	if isnotempty(args'seealso']) then

		table.insert(notes, "''" .. labels'seealso' .. " " .. args'seealso' .. "''")

	end



	-- check if this is a one row table

	if class == '' or class == 'uncollapsed' then

		class = ''

	elseif #extra > 0 or #notes > 0 or isnotempty(args'time']) or isnotempty(args'report']) or 

		isnotempty(args'goals1']) or isnotempty(args'goals2']) or

		isnotempty(args'penalties1']) or isnotempty(args'penalties2']) or

		isnotempty(args'shootout1']) or isnotempty(args'shootout2']) then

	elseif class == 'collapsible collapsed' or class == 'mw-collapsible mw-collapsed' then

		class = ''

	end

	

	-- Start box

	local root = 

		mw.html.create('div')

			:addClass('vevent')

			:attr('id', id)

	root:tag('span')

		:addClass('summary')

		:css('display', 'none')

		:wikitext(args'team1' .. ' v ' .. args'team2'])

	root:newline()

	

	-- Start table

    local rClassName = 'vevent tmpl-football-box-collapsible'

    local rbg = background(frame, 'default', args'result' or '', args'bg' or '')

    if rbg == 'transparent' then

      rClassName = rClassName .. ' tmpl-football-box-collapsible-transparent'

    end



	local rtable = root:tag('table')

		:attr('cellspacing', 0)

		:addClass(class ~= '' and class or nil)

		:addClass(rClassName)

		:css('border-top', bars and '1px solid #999' or nil)

		:css('border-bottom', bars and '1px solid #999' or nil)

		:css('margin-bottom', bars and '-1px' or nil)

		:css('width', args'size' or '100%')

		:css('background', rbg):css('color', '#202122')



	local row = rtable:tag('tr'):css('vertical-align', 'top')

	-- date and round

	local cell = row:tag('td')

		:css('width', width1args'format' or 'default' or width1'default'])

	if isnotempty(args'date']) then

		cell:tag('span')

			:css('white-space', 'nowrap')

			:css('float', 'right')

			:css('margin-left', '0.5em')

			:wikitext(args'date'])

		cell:wikitext(' ')

	end

	if isnotempty(args'round']) then

		cell:wikitext(small(args'round']))

	end

	-- team1

	row:tag('td')

		:css('width', width2args'format' or 'default' or width2'default'])

		:css('text-align', 'right')

		:addClass('vcard attendee')

		:wikitext(teamname(args'team1']))

	-- score

	row:tag('td')

		:css('width', width3args'format' or 'default' or width3'default'])

		:css('text-align', 'center')

		:wikitext(score(scorestr, args'aet' or '', args'aggregatescore' or '', args'penaltyscore' or '', args'shootoutscore' or ''))

	-- team2

	row:tag('td')

		:css('width', width4args'format' or 'default' or width4'default'])

		:addClass('vcard attendee')

		:wikitext(teamname(args'team2']))

	-- location, stadium

	row:tag('td')

		:css('width', width5args'format' or 'default' or nil)

		:css('font-size', location and '85%' or nil)

		:wikitext(location)



	if #extra > 0 or isnotempty(args'time']) or isnotempty(args'report']) or 

		isnotempty(args'goals1']) or isnotempty(args'goals2']) then

		local row = rtable:tag('tr'):css('vertical-align','top'):css('font-size','85%')

		-- time

		row:tag('td')

			:css('text-align', isnotempty(args'time']) and 'right' or nil)

			:wikitext(args'time'])

		row:newline()	

		-- goals1

		row:tag('td')

			:css('text-align', isnotempty(args'goals1']) and 'right' or nil)

			:wikitext(fmtlist(args'goals1']))	

		row:newline()

		-- report

		row:tag('td')

			:css('text-align', isnotempty(args'report']) and 'center' or nil)

			:wikitext(makelink(args'report' or '', 'Report'))

		row:newline()

		-- goals2

		row:tag('td')

			:wikitext(fmtlist(args'goals2']))

		row:newline()

		-- location, stadium

		row:tag('td')

			:wikitext(table.concat(extra, '<br>'))

	end



	if isnotempty(args'penalties1']) or isnotempty(args'penalties2']) then

		row = rtable:tag('tr')

		row:tag('td'):attr('rowspan', 2)

		row:tag('td'):attr('colspan', 3):css('text-align', 'center'):wikitext(bold(labels'penalties']))

		row:tag('td'):attr('rowspan', 2)

		row = rtable:tag('tr'):css('vertical-align','top'):css('font-size','85%')

		row:newline()

		row:tag('td')

			:css('text-align', isnotempty(args'penalties1']) and 'right' or nil)

			:wikitext(fmtlist(args'penalties1']))

		row:newline()

		row:tag('td')

		row:newline()

		row:tag('td')

			:wikitext(fmtlist(args'penalties2']))

		row:newline()

	elseif isnotempty(args'shootout1']) or isnotempty(args'shootout2']) then

		row = rtable:tag('tr')

		row:tag('td'):attr('rowspan', 2)

		row:tag('td'):attr('colspan', 3):css('text-align', 'center'):wikitext(bold(labels'shootout']))

		row:tag('td'):attr('rowspan', 2)

		row = rtable:tag('tr'):css('vertical-align','top'):css('font-size','85%')

		row:newline()

		row:tag('td')

			:css('text-align', isnotempty(args'shootout1']) and 'right' or nil)

			:wikitext(fmtlist(args'shootout1']))

		row:newline()

		row:tag('td')

		row:newline()

		row:tag('td')

			:wikitext(fmtlist(args'shootout2']))

		row:newline()

	end

	

	if #notes > 0 then

		row = rtable:tag('tr'):css('font-size', '85%')

		row:tag('td')

			:attr('colspan', 5)

			:wikitext(table.concat(notes, '<br>'))

		row:newline()

	end

	

	local trackstr = (#tracking > 0) and table.concat(tracking, '') or ''

	if #preview > 0 then

		trackstr = require('Module:If preview')._warning({

			'Unknown parameters ' .. table.concat(preview, '; ') .. '.'

		}) .. trackstr

	end

	

	return tostring(root) .. trackstr

end



return p