Jump to content

Module:Demography: Difference between revisions

From Wikipedia, the free encyclopedia
Content deleted Content added
m Protected Module:Demography: High-risk Lua module ([Edit=Allow only autoconfirmed users] (indefinite) [Move=Allow only autoconfirmed users] (indefinite))
Jackmcbarn (talk | contribs)
use mw.html
Line 2: Line 2:


local getArgs = require('Module:Arguments').getArgs
local getArgs = require('Module:Arguments').getArgs
local htmlBuilder = require('Module:HtmlBuilder')
local yesno = require('Module:Yesno')
local yesno = require('Module:Yesno')


Line 46: Line 45:
local years = p.getArgNums(args)
local years = p.getArgNums(args)
local isEmbedded = yesno(args.embed)
local isEmbedded = yesno(args.embed)
local border = not isEmbedded and '1px solid #999'
local border = not isEmbedded and '1px solid #999' or nil
local padding = not isEmbedded and '4px'
local padding = not isEmbedded and '4px' or nil
local dateRows = p.renderDateRows(args, years, border, padding)
local dateRows = p.renderDateRows(args, years, border, padding)
local dateRowLength = #years + 1
local dateRowLength = #years + 1
local root
local root
if isEmbedded then
if isEmbedded then
root = htmlBuilder.create()
root = mw.html.create()
else
else
root = htmlBuilder.create('table')
root = mw.html.create('table')
root
root
.css('margin-left', 'auto')
:css('margin-left', 'auto')
.css('margin-right', 'auto')
:css('margin-right', 'auto')
.css('border', border)
:css('border', border)
.css('border-collapse', 'collapse')
:css('border-collapse', 'collapse')
.css('background-color', '#f3fff3')
:css('background-color', '#f3fff3')
if not args.noheader then
if not args.noheader then
local currentTitle = mw.title.getCurrentTitle()
local currentTitle = mw.title.getCurrentTitle()
local source = args.source
local source = args.source
root.tag('caption')
root:tag('caption')
.css('margin-bottom', '0.5em')
:css('margin-bottom', '0.5em')
.css('font-size', '1.1em')
:css('font-size', '1.1em')
.css('font-weight', 'bold')
:css('font-weight', 'bold')
.wikitext(
:wikitext(
(args.caption or 'Historical population of ' .. currentTitle.prefixedText)
(args.caption or 'Historical population of ' .. currentTitle.prefixedText)
.. (source and ' <br /><small>(Source: ' .. source .. ')</small>' or '')
.. (source and ' <br /><small>(Source: ' .. source .. ')</small>' or '')
Line 74: Line 73:
end
end
end
end
root.wikitext(dateRows)
root:wikitext(dateRows)
local noDoubleYear = args.sansdoublescomptes or args.withoutdoublecount
local noDoubleYear = args.sansdoublescomptes or args.withoutdoublecount
if noDoubleYear then
if noDoubleYear then
local annualSurvey = args['enquêteannuelle'] or args.annualsurvey
local annualSurvey = args['enquêteannuelle'] or args.annualsurvey
root.tag('tr')
root:tag('tr')
.tag('td')
:tag('td')
.attr('colspan', dateRowLength)
:attr('colspan', dateRowLength)
.css('border', border)
:css('border', border)
.css('padding', padding)
:css('padding', padding)
.css('text-align', 'center')
:css('text-align', 'center')
.tag('small')
:tag('small')
.wikitext(
:wikitext(
'From the year ' .. noDoubleYear .. ' on: No double counting&mdash;'
'From the year ' .. noDoubleYear .. ' on: No double counting&mdash;'
.. 'residents of multiple communes (e.g. students and military personnel)'
.. 'residents of multiple communes (e.g. students and military personnel)'
Line 100: Line 99:


function p.renderDateRows(args, years, border, padding)
function p.renderDateRows(args, years, border, padding)
local root = htmlBuilder.create()
local root = mw.html.create()
local hrow = root.tag('tr')
local hrow = root:tag('tr')
hrow
hrow
.css('background', '#ddffdd')
:css('background', '#ddffdd')
.tag('th')
:tag('th')
.attr('scope', 'row')
:attr('scope', 'row')
.css('border', border)
:css('border', border)
.css('padding', padding)
:css('padding', padding)
.wikitext('Year')
:wikitext('Year')
for i, year in ipairs(years) do
for i, year in ipairs(years) do
if year < 0 then
if year < 0 then
Line 115: Line 114:
year = tostring(year)
year = tostring(year)
end
end
hrow.tag('th')
hrow:tag('th')
.css('border', border)
:css('border', border)
.css('padding', padding)
:css('padding', padding)
.wikitext(year)
:wikitext(year)
end
end
local drow = root.tag('tr')
local drow = root:tag('tr')
drow
drow
.tag('th')
:tag('th')
.attr('scope', 'row')
:attr('scope', 'row')
.css('border', border)
:css('border', border)
.css('padding', padding)
:css('padding', padding)
.wikitext('Population')
:wikitext('Population')
for i, year in ipairs(years) do
for i, year in ipairs(years) do
drow.tag('td')
drow:tag('td')
.css('border', border)
:css('border', border)
.css('padding', padding)
:css('padding', padding)
.css('text-align', 'center')
:css('text-align', 'center')
.wikitext(args[year])
:wikitext(args[year])
end
end
return tostring(root)
return tostring(root)

Revision as of 02:14, 5 December 2014

-- This module implements {{demography}}.

local getArgs = require('Module:Arguments').getArgs
local yesno = require('Module:Yesno')

local p = {}

-- Often-used functions.
local floor = math.floor

----------------------------------------------------------------------------
-- Helper functions
----------------------------------------------------------------------------

function p.isInteger(v)
	if type(v) == 'number' and floor(v) == v then
		return true
	else
		return false
	end
end

function p.getArgNums(args)
	local isInteger = p.isInteger
	local nums = {}
	for k, v in pairs(args) do
		if isInteger(k) then
			nums[#nums + 1] = k
		end
	end
	table.sort(nums)
	return nums
end			

----------------------------------------------------------------------------
-- Main functions
----------------------------------------------------------------------------

function p.main(frame)
	local args = getArgs(frame)
	return p._main(args)
end

function p._main(args)
	local years = p.getArgNums(args)
	local isEmbedded = yesno(args.embed)
	local border = not isEmbedded and '1px solid #999' or nil
	local padding = not isEmbedded and '4px' or nil
	local dateRows = p.renderDateRows(args, years, border, padding)
	local dateRowLength = #years + 1
	local root
	if isEmbedded then
		root = mw.html.create()
	else
		root = mw.html.create('table')
		root
			:css('margin-left', 'auto')
			:css('margin-right', 'auto')
			:css('border', border)
			:css('border-collapse', 'collapse')
			:css('background-color', '#f3fff3')
		if not args.noheader then
			local currentTitle = mw.title.getCurrentTitle()
			local source = args.source
			root:tag('caption')
				:css('margin-bottom', '0.5em')
				:css('font-size', '1.1em')
				:css('font-weight', 'bold')
				:wikitext(
					(args.caption or 'Historical population of ' .. currentTitle.prefixedText)
					.. (source and ' <br /><small>(Source: ' .. source .. ')</small>' or '')
				)
		end
	end
	root:wikitext(dateRows)
	local noDoubleYear = args.sansdoublescomptes or args.withoutdoublecount
	if noDoubleYear then
		local annualSurvey = args['enquêteannuelle'] or args.annualsurvey
		root:tag('tr')
			:tag('td')
				:attr('colspan', dateRowLength)
				:css('border', border)
				:css('padding', padding)
				:css('text-align', 'center')
				:tag('small')
					:wikitext(
						'From the year ' .. noDoubleYear .. ' on: No double counting&mdash;'
						.. 'residents of multiple communes (e.g. students and military personnel)'
						.. ' are counted only once.'
						.. (
							annualSurvey
							and ' <br />' .. annualSurvey .. ': Provisional population (annual survey).'
							or ''
						)
					)
	end
	return tostring(root)
end

function p.renderDateRows(args, years, border, padding)
	local root = mw.html.create()
	local hrow = root:tag('tr')
	hrow
		:css('background', '#ddffdd')
		:tag('th')
			:attr('scope', 'row')
			:css('border', border)
			:css('padding', padding)
			:wikitext('Year')
	for i, year in ipairs(years) do
		if year < 0 then
			year = '&minus;' .. tostring(year * -1)
		else
			year = tostring(year)
		end
		hrow:tag('th')
			:css('border', border)
			:css('padding', padding)
			:wikitext(year)
	end
	local drow = root:tag('tr')
	drow
		:tag('th')
			:attr('scope', 'row')
			:css('border', border)
			:css('padding', padding)
			:wikitext('Population')
	for i, year in ipairs(years) do
		drow:tag('td')
			:css('border', border)
			:css('padding', padding)
			:css('text-align', 'center')
			:wikitext(args[year])
	end
	return tostring(root)
end

return p