Module:Political party: Difference between revisions
Jump to navigation
Jump to search
Content added Content deleted
(scrap the two-subpages nonsense, given that with abbrev there will be three sets otherwise) |
(added support for # sign for colors) |
||
Line 22: | Line 22: | ||
local return_value = data_all[party][out_type] or data_all[data_alt[party]] |
local return_value = data_all[party][out_type] or data_all[data_alt[party]] |
||
mw.log(return_value) |
|||
-- If database value doesn't exist, return input |
-- If database value doesn't exist, return input |
||
if return_value == nil and frame.args[1] ~= nil then |
if return_value == nil and frame.args[1] ~= nil then |
||
Line 28: | Line 28: | ||
end |
end |
||
if out_type == "color" then |
|||
return_value = "#" .. return_value |
|||
end |
|||
return return_value |
return return_value |
||
end |
end |
Revision as of 03:59, 7 September 2021
Documentation for this module may be created at Module:Political party/doc
local p = {}
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)
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 = mw.ustring.sub(party, 1, 1)
local data = mw.loadData('Module:Political names/' .. index)
local data_all = data.full
local data_alt = data.alternate
local return_value = data_all[party][out_type] or data_all[data_alt[party]]
-- If database value doesn't exist, return input
if return_value == nil and frame.args[1] ~= nil then
return_value = error('value not in template. Please request that it be added')
end
if out_type == "color" then
return_value = "#" .. return_value
end
return return_value
end
return p