Jump to content

Module:Vgrtbl

From Wikipedia, the free encyclopedia
This is an old revision of this page, as edited by Jackmcbarn (talk | contribs) at 22:01, 21 March 2014 (forgot a tag). The present address (URL) is a permanent link to this revision, which may differ significantly from the current revision.

local p = {}

local lang = mw.language.getContentLanguage()

local function looksLikeYear(str)
	local success, result = pcall(lang.formatDate, lang, 'Y', '1-1-' .. str)
	return success and tonumber(result) == tonumber(str)
end

function p._text(dateText, name, v, s)
	local retval = '<span style="white-space:normal;"><span style="white-space:normal;">'
	local success, result = pcall(lang.formatDate, lang, 'c', dateText)
	if looksLikeYear(dateText) or not success then
		retval = retval .. dateText
	else
		if s then
			retval = retval .. '<span style="display:none">{{#time:Ym|{{{1}}}}}</span>'
		end
		local success2, result2 = pcall(lang.formatDate, lang, 'c', '1 ' .. dateText)
		if success2 and result == result2 then
			retval = retval .. lang:formatDate(v == '0' and 'Y-m' or 'F Y', dateText)
		else
			if s then
				retval = retval .. '<span style="display:none">' .. lang:formatDate('Ymd', dateText) .. '</span>'
			end
			local formatString
			if v == '0' then
				formatString = 'Y-m-d'
			elseif v == '2' then
				formatString = 'j F Y'
			else
				formatString = 'F j, Y'
			end
			retval = retval .. lang:formatDate(formatString, dateText)
		end
	end
	return retval .. '<small>&nbsp;(' .. name .. ')</small></span>'
end

function p.text(frame)
	local args = frame:getParent().args
	return p._text(args[1], args[2], args.v, args.s)
end

local function tryDate(str)
	local success, result = pcall(lang.formatDate, lang, 'c', str)
	if success then
		return result
	else
		return str
	end
end

function p.main(frame)
	local args = frame:getParent().args
	local v = args.v or 1
	if args.c == '0' then
		-- If collapse mode is off
		local retval = frame:expandTemplate{title = 'vgrtbl/text', args = { s = 1, v = v, args[2], args[1] }}
		local i = 3
		while args[i] and mw.text.trim(args[i]) ~= '' do
			retval = retval .. '<br />' .. frame:expandTemplate{title = 'vgrtbl/text', args = { v = v, args[i + 1], args[i] }}
			i = i + 2
		end
		return retval
	else
		-- If collapse mode is on
		local dates = {}
		local dateOrder = {}
		local i = 1
		while args[i] and mw.text.trim(args[i]) ~= '' do
			local d = tryDate(args[i + 1])
			if dates[d] then
				table.insert(dates[d], args[i])
			else
				table.insert(dateOrder, d)
				dates[d] = { display = args[i + 1], args[i] }
			end
			i = i + 2
		end
		local retval = ''
		for key, val in ipairs(dateOrder) do
			if key == 1 then
				retval = frame:expandTemplate{title = 'vgrtbl/text', args = { s = 1, v = v, dates[val].display, table.concat(dates[val], '/') }}
			else
				retval = retval .. '<br />' .. frame:expandTemplate{title = 'vgrtbl/text', args = { v = v, dates[val].display, table.concat(dates[val], '/') }}
			end
		end
		return retval
	end
end

return p