Moduł:Partie polityczne
Dokumentacja dla tego modułu może zostać utworzona pod nazwą Moduł:Partie polityczne/opis
local function getPartyParams(country)
mw.logObject(country, "country")
local moduleprefix = "Moduł:Partie polityczne/dane/"
local moduletitle = mw.title.new(country)
if not moduletitle or (moduletitle.namespace ~= 828) then
moduletitle = mw.title.new(moduleprefix..country)
end
if not moduletitle then
mw.log("„"..country.."” nie jest prawidłową nazwą z danymi partii politycznych")
elseif moduletitle.exists then
local status, partiesData = pcall(mw.loadData, moduletitle.fullText)
if status then
return partiesData
end
else
mw.log("Nie mogę znaleźć definicji partii politycznych. Nie istnieje „"..moduleprefix..country.."”.")
end
end
local function selectPartyData(args)
local abbr = args[1]
if not abbr then
return
end
local group = args[2]
mw.logObject({abbr, group}, "abbr, group")
local data = getPartyParams(group or "Polska") or {}
if data[abbr] then
mw.logObject({abbr, group or false, data[abbr]}, "selected key")
return abbr, data[abbr]
end
local result = {}
-- look for name
for k, v in pairs(data) do
local key = type(k) == "string" and k or false
if (abbr == v.opis) or (abbr == v.link) then
table.insert(result, {key, v})
end
end
if #result == 1 then
mw.logObject({abbr, group or false, result[1]}, "selected name")
return result[1][1], result[1][2]
end
mw.logObject({abbr, group or false}, "not selected")
end
local function Name(party)
if not party then
return
end
local desc = party.opis
local link = party.link
mw.logObject({desc, link}, "desc, link")
if link and desc and (link ~= desc) then
mw.logObject("[[w:"..link.."|"..desc.."]]", "return nazwa A")
return "[[w:"..link.."|"..desc.."]]"
elseif link then
mw.logObject("[[w:"..link.."|"..link.."]]", "return nazwa B")
return "[[w:"..link.."|"..link.."]]"
elseif desc then
mw.logObject(desc, "return nazwa C")
return desc
end
end
return {
["skrót"] = function(frame)
local args = require('Module:Arguments').getArgs(frame)
local key, party = selectPartyData(args)
mw.logObject(party, "party")
return key or args[1]
end,
["kolor"] = function(frame)
local args = require('Module:Arguments').getArgs(frame)
local key, party = selectPartyData(args)
mw.logObject(party, "party")
if party and party.kolor then
return party.kolor
end
return args.kolor or "E6E6E6"
end,
["link"] = function(frame)
local args = require('Module:Arguments').getArgs(frame)
local key, party = selectPartyData(args)
mw.logObject(party, "party")
if party then
return party.link
end
end,
["opis"] = function(frame)
local args = require('Module:Arguments').getArgs(frame)
local key, party = selectPartyData(args)
mw.logObject(party, "party")
if party then
return party.opis
end
end,
["nazwa"] = function(frame)
local args = require('Module:Arguments').getArgs(frame)
local key, party = selectPartyData(args)
mw.logObject(party, "party")
return Name(party) or args[1]
end,
["krótko"] = function(frame)
local args = require('Module:Arguments').getArgs(frame)
local abbr, party = selectPartyData(args)
mw.logObject(party, "party")
if party then
local link = party.link
if link and abbr then
return link == abbr and ("[[w:"..link.."|"..link.."]]") or ("[[w:"..link.."|"..abbr.."]]")
elseif abbr then
return abbr
else
return Name(party) or args[1]
end
end
return args[1]
end,
["doc"] = function(frame)
local moduleName = mw.title.getCurrentTitle().fullText
local status, partiesData = pcall(mw.loadData, moduleName)
if not status then
-- logowanie komunikatu błędu może być przydatne
mw.log(partiesData)
return
end
local data = {}
local lang = mw.getContentLanguage()
for k, v in pairs(partiesData) do
table.insert(data, {
_sk = v.kolor and "1" or "0",
_ss = type(k) == "string" and "1" or "0",
_sn = lang:caseFold(v.opis or v.link or (type(k) == "string" and k or "")),
key = type(k) == "string" and k or "''brak''",
color = v.kolor and ("#"..v.kolor) or "none",
kolor = v.kolor or "''brak''",
name = Name(v) or "''brak''"
})
end
table.sort(data, function(a, b) return a._sn < b._sn end)
local builder = mw.html.create()
builder
:wikitext(
'Dane, które są używane przez szablony dotyczące partii politycznych.',
'\n{| class="wikitable collapsible collapsed" width="100%"',
'\n! Struktura rekordu opisującego jedną partię',
'\n|-',
'\n| '
)
:tag("pre"):wikitext(
'["..."] = {\t-- opcjonalny skrót nazwy partii',
'\n\tkolor = "...",\t-- 6 cyfr szesnastkowych kodujących kolor w HTML',
'\n\tlink = "...",\t-- nazwa artykułu opisującego partię',
'\n\topis = "...",\t-- nazwa partii gdy nie ma artykułu lub link zawiera nawias ujednoznaczniający',
'\n}'
):done()
:wikitext(
'\n|}',
'\n{| class="wikitable sortable"',
'\n|+ Lista partii politycznych',
'\n|-',
'\n! class="unsortable ordinal" | lp.',
'\n!Kolor',
'\n!Skrót',
'\n!Nazwa'
)
for i, v in ipairs(data) do
builder
:wikitext(
'\n|-',
'\n| ', i,
'\n| '
)
builder
:tag("span"):css({ display = "none"}):wikitext(v._sk):done()
:tag("span"):css({ border = "none", background = "none", ["text-aling"] = "left", margin = "0px!important"})
:tag("span"):css({border = "solid 1px silver", background = v.color, ["font-size"] = "80%!important", ["vertical-align"] = "middle", })
:wikitext(" ")
:done()
:wikitext(' ', v.kolor)
:done()
:wikitext('\n| '):tag("span"):css({ display = "none"}):wikitext(v._ss):done():wikitext(v.key)
:wikitext('\n| '):tag("span"):css({ display = "none"}):wikitext(#v._sn > 0 and "1" or "0", v._sn):done():wikitext(v.name)
end
builder:wikitext("\n|}")
local result = tostring(builder)
mw.log(result, "result")
return result
end,
}