Ugrás a tartalomhoz

Modul:Versenyszám navoszlop

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

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

Ezt a modult használja a {{Versenyszám navoszlop}}(?). A leírását lásd a sablonnál.

--
-- Ezzel a modullal működik a {{Versenyszám navoszlop}} sablon.
-- A [[Modul:Navoszlop]]ot használja.
-- stílusok: Modul:Versenyszám navoszlop/styles.css
require('strict')

local p = {}

local getArgs = require('Modul:Arguments').getArgs

local tracking, preview = {}, {}

local function checkargs(args)
    for k, v in pairs(args) do
    	if v ~= '' then
			if k and type(k) == 'string' then
				if k == 'event' or k == 'games' or k == 'name' or k == 'image' or
					k == 'imageright' or k =='caption' or k =='above' or
					k == 'title' or k == 'title-b' or k == 'alignresults' or k == 'alignevents' or
					k == 'width' or k == 'maxwidth' or k == 'float' or
					k == 'below' or k == 'prev' or k == 'next' or
					k == 'versenyszám' or k == 'esemény' or k == 'név' or k == 'kép' or
					k == 'képjobbra' or k =='képaláírás' or k =='felül' or
					k == 'cím' or k == 'cím-b' or k == 'eredménystílus' or k == 'versenyszámstílus' or
					k == 'szélesség' or k == 'maxszélesség' or k == 'igazítás' or
					k == 'alul' or k == 'előző' or k == 'következő' then
					-- valid
				elseif k:match('^title%d+$') or k:match('^title-b') or k:match('^event%d+$') or
					k:match('^image%d+$') or k:match('^type%d+[a-e]$') or
					k:match('^event%d+%.%d+$') or 
					k:match('^results%d+%.%d+[a-e]?$') or
					k:match('^border%d+%.%d+$') or
					k:match('^cím%d+$') or k:match('^cím-b') or k:match('^versenyszám%d+$') or
					k:match('^kép%d+$') or k:match('^típus%d+[a-e]$') or
					k:match('^versenyszám%d+%.%d+$') or 
					k:match('^eredmény%d+%.%d+[a-e]?$') or
					k:match('^szegély%d+%.%d+$') then
					-- valid
				elseif k == 'categories' or k == 'nocat' or k == 'demo' then
					-- valid for doc page
				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, '[[Kategória:Hibásan használt versenyszám navoszlop sablont tartalmazó lapok|' .. k .. ']]')
					table.insert(preview, '"' .. k .. '"')
				end
			end
		end
	end
end

function p.sidebar(frame, args)

	if not args then
		args = getArgs(frame)
	end
		
	local root = mw.html.create()

	root = root
		:tag('table')
		:addClass('sidebar-games-events')
		:addClass((args.float == 'left' or args['igazítás'] == 'balra') and 'sidebar-games-events-left' or nil)
		:addClass((args.float == 'none' or args['igazítás'] == 'nincs') and 'sidebar-games-events-none' or nil)
		:addClass('sidebar')
		:addClass('nomobile')
		:css('width', args.width or args['szélesség'] or nil)
		:css('max-width', args.maxwidth or args['maxszélesség'] or nil)

	-- enumerate the rows and count the columns
	local cols = 1
	local colindex = {a = '2', b = '3', c = '4', d = '5', e = '6'}
	local lets = {'a', 'b', 'c', 'd', 'e'}
	local rowNums = {}
	local subevents = 0
	local hasevents = false

	for k, v in pairs(args) do
		k = '' .. k
		
		-- find rows
		local num = k:match('^event(%d+)$') 
			or k:match('^image(%d+)$')
			or k:match('^title(%d+)$')
			or k:match('^type(%d+)[a-e]$')
			or k:match('^event(%d+)%.%d+$')
			or k:match('^results(%d+)%.%d+[a-e]?$')
			or k:match('^versenyszám(%d+)$')
			or k:match('^kép(%d+)$')
			or k:match('^cím(%d+)$')
			or k:match('^típus(%d+)[a-e]$')
			or k:match('^versenyszám(%d+)%.%d+$')
			or k:match('^eredmény(%d+)%.%d+[a-e]?$')
		if num then table.insert(rowNums, tonumber(num)) end
		
		-- find number of columns
		if k:match('^results%d+%.(%d+)$') or k:match('^eredmény%d+%.(%d+)$')  then
			cols = (2 > cols) and 2 or cols
		end
		
		-- find number of columns based on let(s)
		local let = k:match('^results%d+%.%d+([a-e])$') or k:match('^eredmény%d+%.%d+([a-e])$')
			or k:match('^type%d+([a-e])$') or k:match('^típus%d+([a-e])$')
		if let and colindex[let] then
			local n = tonumber(colindex[let])
			cols = (n > cols) and n or cols
		end
		
		-- find subevents
		local subnum = k:match('^results%d+%.(%d+)[a-e]?$') or k:match('^eredmény%d+%.(%d+)[a-e]?$')
			or k:match('^event%d+%.(%d+)$') or k:match('^versenyszám%d+%.(%d+)$')
		if subnum then
			subnum = tonumber(subnum)
			subevents = (subnum > subevents) and subnum or subevents
		end
		
		-- identify events (that match looks awfully similar to subevents)
		if k:match('^(event%d+%.%d+)$') or k:match('^(versenyszám%d+%.%d+)$') then
			hasevents = true
		end
	end
	-- remove duplicates from the list (e.g. 3 will be duplicated if both event3 and image3 are specified)
	table.sort(rowNums)
	for i = #rowNums, 1, -1 do
		if rowNums[i] == rowNums[i - 1] then
			table.remove(rowNums, i)
		end
	end
	
	-- alignment
	local alignevents = nil
	if (args.alignevents or args['versenyszámstílus']) and (args.alignevents == 'right' or args['versenyszámstílus'] == 'jobbra') then
		alignevents = 'event-r'
	end
	local alignresults = nil
	if (args.alignresults or args['eredménystílus']) and (args.alignresults == 'right' or args['eredménystílus'] == 'jobbra') then
		alignresults = 'result-r'
	elseif (args.alignresults or args['eredménystílus']) and (args.alignresults == 'left' or args['eredménystílus'] == 'balra') then
		alignresults = 'result-l'
	end

	-- add the top level header
	if args.title or args['cím'] then
		local t = args.title or args['cím']
		local tb = args['title-b'] or args['cím-b']
		if args.title or args['cím'] then
			if args['title-b'] or args['cím-b'] then
			t = t .. '<br>' .. tb
			else
			t = t
			end
		end
		local cell = root:tag('tr'):tag('th')
		cell
			:addClass('sidebar-games-events-title')
			:attr('colspan', cols)
		if args.imageright or args['képjobbra'] then
			local d = cell:tag('div')
				:addClass('sidebar-games-events-ir-cont')
			d:tag('div')
				:addClass('sidebar-games-events-ir-title')
				:wikitext(t)
			d:tag('div')
				:addClass('sidebar-games-events-ir')
				:wikitext(args.imageright or args['képjobbra'])
		else
			cell:wikitext(t)
		end
	end

	if args.image or args['kép'] then
		local imageCell = root:tag('tr'):tag('td')

		imageCell
			:addClass('sidebar-games-events-image')
			:attr('colspan', cols)
			:wikitext(args.image or args['kép'])
		if args.caption or args['képaláírás'] then
			imageCell
				:tag('div')
					:addClass('sidebar-games-events-caption')
					:wikitext(args.caption or args['képaláírás'])
		end
	end

	if args.above or args['felül'] then
		local cell = root:tag('tr'):tag('td')
		cell:attr('colspan', cols)
			:wikitext(args.above or args['felül'])
	end
	
	-- start adding rows
	for i, num in ipairs(rowNums) do
		local heading = nil
		local event = args['event' .. num] or args['versenyszám' .. num]
		local image = args['image' .. num] or args['kép' .. num]
		local title = args['title' .. num] or args['cím' .. num]
		if title then
			root:tag('tr')
					:tag('th')
						:addClass('event-title')
						:attr('colspan', cols)
						:wikitext(title)
		end
		
		if event and image then
			heading = event .. '<br>' .. image
		elseif event then
			heading = event
		elseif image then
			heading = image
		end
		
		if heading then
			root
				:tag('tr')
					:tag('th')
						:addClass('sidebar-games-events-heading')
						:attr('colspan', cols)
						:wikitext(heading)
		end

		local showtypes = false
		for j, let in ipairs(lets) do
			if j < cols then
				if args['type' .. num .. let] or args['típus' .. num .. let] then
					showtypes = true
				end
			end
		end
		if showtypes == true then
			local row = root:tag('tr')
			row:tag('th'):addClass((hasevents == false) and 'no-event' or nil)
			for j, let in ipairs(lets) do
				if j < cols then
					local t = args['type' .. num .. let] or args['típus' .. num .. let]
					local cell = row:tag('th')
					if t then
						cell
							:addClass('type-let')
							:css('width', (cols > 2) and tostring(math.floor(100/(cols-1))) .. '%' or nil)
							:wikitext(t)
					end
				end
			end
		end

		for k=1,subevents do
			local hasresults = false
			if args['results' .. num .. '.' .. k] or args['eredmény' .. num .. '.' .. k] then
				hasresults = true
			else
				for j, let in ipairs(lets) do
					if j < cols then
						if args['results' .. num .. '.' .. k .. let] or args['eredmény' .. num .. '.' .. k .. let]  then
							hasresults = true
						end
					end
				end
			end
	
			if hasresults then
				local row = root:tag('tr')
				local cell = row:tag('th'):addClass((hasevents == false) and 'no-event' or nil)
				local t = args['event' .. num .. '.' .. k] or args['versenyszám' .. num .. '.' .. k]
				local border = (args['border' .. num .. '.' .. k] or args['szegély' .. num .. '.' .. k]) and 'erl-border' or nil
				if t then
					cell
						:addClass('event')
						:addClass(alignevents)
						:addClass(border)
						:wikitext(t)
				end
				if args['results' .. num .. '.' .. k] or args['eredmény' .. num .. '.' .. k] then
					row:tag('td')
							:addClass(border)
							:addClass(alignresults)
							:attr('colspan', cols - 1)
							:wikitext(args['results' .. num .. '.' .. k] or args['eredmény' .. num .. '.' .. k])
				else
					for j, let in ipairs(lets) do
						if j < cols then
							t = args['results' .. num .. '.' .. k .. let] or args['eredmény' .. num .. '.' .. k .. let]
							row:tag('td')
								:addClass(border)
								:addClass(alignresults)
								:wikitext(t)
						end
					end
				end
			end
		end
	end
		
	if args.below or args["alul"] then
		root
			:tag('tr')
				:tag('td')
					:addClass(args.belowclass)
					:attr('colspan', cols)
					:cssText(args.belowstyle)
					:wikitext(args.below or args["alul"])
	end

	if args.prev or args["előző"] or args.next or args["következő"] then
		local row = root:tag('tr'):tag('td')
			:addClass('sidebar-games-events-prevnext')
			:attr('colspan', cols)
				:tag('div')
		row:tag('div')
			:addClass('sidebar-games-events-prev')
			:wikitext(args.prev or args["előző"])
		row:tag('div')
			:addClass('sidebar-games-events-next')
			:wikitext(args.next or args["következő"])
	end

	if args.navbar ~= 'none' and args.navbar ~= 'off' and
		(args.name or args["név"] or frame:getParent():getTitle():gsub('/sandbox$', '') ~= 'Sablon:Versenyszám navoszlop') then
		root
			:tag('tr')
				:tag('td')
					:addClass('sidebar-games-events-navbar')
					:attr('colspan', cols)
					:wikitext(require('Modul:Navbar')._navbar{
						args.name or args["név"],
						mini = 1,
						fontstyle = args.navbarfontstyle
					})
	end
	
	if mw.title.getCurrentTitle().namespace == 10 and (args.name or args['név'] ~= mw.title.getCurrentTitle().text) and not (mw.title.getCurrentTitle().text:match('Versenyszám navoszlop')) then
    	root:wikitext("[[Kategória:Hibásan használt versenyszám navoszlop sablont tartalmazó lapok]]")
	end
	
	checkargs(args)

	local trackstr = (#tracking > 0) and table.concat(tracking, '') or ''
	if #preview > 0 then
		trackstr = require('Modul:If preview')._warning({
			'Unknown parameters ' .. table.concat(preview, '; ') .. '.'
		}) .. trackstr
	end

	return mw.getCurrentFrame():extensionTag{
		name = 'templatestyles', args = { src = 'Modul:Versenyszám navoszlop/styles.css' }
	} .. tostring(root) .. trackstr
end
return p