Module:Political party

local p = {}

local categories = { party_not_in_list = "", }

local function getFirstLetter(party) index = mw.ustring.sub(party, 1, 1) -- Set index for non-A-Z starts if string.match(index, '%A') then index = '1' end return index end

local function stripToNil(text) -- If text is a string, return its trimmed content, or nil if empty. -- Otherwise return text (which may, for example, be nil). if type(text) == 'string' then text = text:match('(%S.-)%s*$') end return text end

-- Example of having all the data - color and names - in one table. Requires one page to be edited instead of two when adding a new party. function p.fetch(frame) -- Initialise and populate variables local args = frame.args local party = stripToNil(args[1]) or error('parameter 1 should be a party name') local out_type = stripToNil(args[2]) or error('parameter 2 should be the output type') local index = getFirstLetter(party) -- Load data from submodule local data = mw.loadData('Module:Political names/' .. index) local data_all = data.full

local party_alt = data.alternate[party] if party_alt then if data_all[party_alt] then party = data_all[party_alt] else index = getFirstLetter(party_alt) data = mw.loadData('Module:Political names/' .. index) party = data.full[party_alt] end else party = data_all[party] end

if not party then return frame.args[1] .. categories.party_not_in_list end

local return_value = party[out_type] -- If database value doesn't exist, return an error (for colors) or input (for others) if return_value == nil then if out_type == 'color' then return args.error or error('Value not in template. Please request that it be added.') else return party end end

if out_type == 'color' and string.find(return_value, '#') then return_value = string.gsub(return_value, '#', '&#35;') end return return_value end

return p