Модуль:Палітычная партыя
Модуль залежыць ад наступных іншых модуляў: |
Ужыванне
{{#invoke:{{BASEPAGENAME}}|fetch|<party>|<value>}}
Абнаўленне модуля
Палітычныя партыі, якія змяшчае модуль, падзелены на алфавітныя спісы ў залежнасці ад першай літары назвы (напрыклад, "Сацыял-дэмакратычная партыя Фінляндыі" будзе на падстаронцы /С).
Кожны падмодуль мае дзве групы: local alternate
і local full
.
Альтэрнатыўныя назвы партый
Група alternate ўжываецца для альтэрнатыўнах назваў партый. Ніжэй прыклад альтэрнатыўных назваў для Лейбарысцкая партыя (Вялікабрытанія):
local alternate = {
....
["Лейбарысцкая і кааператыўная"] = "Лейбарысцкая партыя (Вялікабрытанія)",
["Лейбарысцкая кааператыўная"] = "Лейбарысцкая партыя (Вялікабрытанія)",
...
}
Першае значэнне ў квадратных дужках — альтэрнатыўная назва, другое значэнне толькі ў двукоссях — назва, якая змяшчаецца ў групе full
ніжэй. Альтэрнатыўная назва партыі мусіць змяшчацца на адпаведнай падстаронцы ў залежнасці ад першай літары; "Алабамская дэмакратычная партыя" будзе змяшчацца на старонцы /А), хоць гэта альтэрнатыўная назва для "Дэмакратычная партыя ЗША" (якая змяшчаецца ў /Д).
Таблічныя значэнні
local full = {
....
["Лейбарысцкая партыя (Вялікабрытанія)"] = {abbrev = "Лейб", color = "#E4003B", shortname = "Лейбарысты",},
...
}
Для кожнай партыі захоўваюцца тры значэнні:
- Абрэвіятура (
abbrev
). - Колер партыі (
color
), які можа быць шаснаццатковым трыплетам або базавай назвай колера. - Кароткая назва партыі (
shortname
).
Значэнні гэтых параметраў не абавязаны быць унікальнымі, якрамя асноўнай назвы партыі.
Старонкі даных
- Палітычная партыя/А
- Палітычная партыя/Б
- Палітычная партыя/В
- Палітычная партыя/Г
- Палітычная партыя/Д
- Палітычная партыя/Е
- Палітычная партыя/Ё
- Палітычная партыя/Ж
- Палітычная партыя/З
- Палітычная партыя/І
- Палітычная партыя/К
- Палітычная партыя/Л
- Палітычная партыя/М
- Палітычная партыя/Н
- Палітычная партыя/О
- Палітычная партыя/П
- Палітычная партыя/Р
- Палітычная партыя/С
- Палітычная партыя/Т
- Палітычная партыя/У
- Палітычная партыя/Ф
- Палітычная партыя/Х
- Палітычная партыя/Ц
- Палітычная партыя/Ч
- Палітычная партыя/Ш
- Палітычная партыя/Ы
- Палітычная партыя/Э
- Палітычная партыя/Ю
- Палітычная партыя/Я
Каб пазбегнуць паломак старонак, дзе ўжыты гэты модуль, пажадана эксперыментаваць у пясочніцы для модуляў.
local p = {}
local default_color = '#F8F9FA'
local categories = {
party_not_in_list = '[[Category:Pages using Political party with unknown party]]',
shortname_not_in_list = '[[Category:Pages using Political party with missing shortname]]',
color_not_in_list = '[[Category:Pages using Political party with missing color]]',
}
local function create_error(error_message)
return string.format('<strong class="error">%s</strong>', error_message)
end
local function getFirstLetter(party)
local index = mw.ustring.sub(party, 1, 1)
return string.upper(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*$')
local delink = require('Module:Delink')._delink
text = delink({text, wikilinks = "target"})
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(args)
if not args[1] then
return create_error("parameter 1 should be a party name.")
end
if not args[2] then
return create_error("parameter 2 should be the output type.")
end
local party = stripToNil(args[1])
local out_type = stripToNil(args[2])
if out_type == 'colour' then
out_type = 'color'
end
local index = getFirstLetter(party)
-- Load data from submodule
local data = mw.loadData('Модуль:Палітычная партыя/' .. index)
local data_all = data.full
local party_alt = data.alternate[party]
local party_info
if party_alt then
if data_all[party_alt] then
party_info = data_all[party_alt]
else
index = getFirstLetter(party_alt)
data = mw.loadData('Модуль:Палітычная партыя/' .. index)
party_info = data.full[party_alt]
end
else
party_info = data_all[party]
end
-- Check if database value exists
-- * Not even in database - return given error or input
-- * No color - return error
-- * No shortname/abbrev - return first non-blank of abbrev->shortname->input
if not party_info then
if out_type == 'color' then
return args.error or default_color
else
return args.error or party
end
end
local return_value = party_info[out_type]
if return_value == "" then
if out_type == 'color' then
return args.error or create_error("Value not in template. Please request that it be added.")
elseif out_type == 'abbrev' then
if party_info.shortname ~= "" then
return party_info.shortname
else
return party
end
elseif out_type == 'shortname' then
if party_info.abbrev ~= "" then
return party_info.abbrev
else
return party
end
else
return party
end
end
if out_type == 'color' and string.find(return_value, '#') then
return_value = string.gsub(return_value, '#', '#')
end
return return_value
end
function p.fetch(frame)
-- Initialise and populate variables
local getArgs = require("Module:Arguments").getArgs
local args = getArgs(frame)
return p._fetch(args)
end
return p