-- Модуль для кузнечного стола
local p = {}
-- Сам стол.
function p.smithing(f)
-- Сбор аргументов
local args = f
if f == mw.getCurrentFrame() then
args = require("Модуль:ProcessArgs").merge()
end
-- Аргументы
local input1 = args["Вход1"] or args[1] or "" -- улучшаемый предмет
local input2 = args["Вход2"] or args[2] or "Незеритовый слиток" -- незеритовый слиток
local Output = args["Выход"] or args[3] or ""
-- Модуль Cg
local cg = require("Модуль:Cg")
-- Сборка интерфейса
local ui = {
-- Размеры
cg.begin{282, 140},
-- Фон
cg.backgroundImage{"Элементы интерфейса кузнечного стола.png"},
-- Слоты входа
cg.slot{input1, 18, 76, class2="invslot-plain"},
cg.slot{input2, 116, 76, class2="invslot-plain"},
-- Слот выхода
cg.slot{Output, 232, 76, class2="invslot-plain"},
-- Конец
cg.footer()
}
return table.concat(ui)
end
-- Таблица
function p.table(f)
-- Сбор аргументов
local args = f
if f == mw.getCurrentFrame() then
args = require("Модуль:ProcessArgs").merge()
else
f = mw.getCurrentFrame()
end
local getParts = require('Модуль:Инвентарный слот').getParts
-- Контролирует границы таблицы
local multirow = f:callParserFunction( '#dplvar', 'multirow' )
if multirow ~= '1' then
multirow = nil
end
-- Начало
local head = args["глава"] or ''
if multirow then
head = ''
elseif head ~= '' then
multirow = 1
f:callParserFunction( '#dplvar:set', 'multirow', '1' )
else
head = 1
end
-- Конец
local foot = args["подвал"] or ''
if multirow then
if foot ~= '' then
multirow = nil
f:callParserFunction( '#dplvar:set', 'multirow', '0' )
end
else
foot = 1
end
-- Заголовок
local header = ''
if head ~= '' then
local name = ''
local description = ''
if args["показатьимя"] == '1' or multirow and args["показатьимя"] ~= '0' then
name = '!! Результат'
f:callParserFunction( '#dplvar:set', 'resultname', '1' )
end
if args["показатьописание"] == '1' then
description = ' !! class="unsortable" | Описание'
f:callParserFunction( '#dplvar:set', 'smithingdescription', '1' )
end
local class = args["класс"] or ''
if multirow then
class = 'sortable collapsible ' .. class
recipeClass = 'class="unsortable" |'
else
recipeClass = ''
end
header = table.concat( {
' {| style="text-align:center" class="wikitable ' .. class .. '" data-description="Рецепты для кузнечного стола"',
'! ' .. 'Ингредиенты !! ' .. recipeClass .. ' Рецепты для [[Кузнечный стол|кузнечного стола]]' .. name .. description,
'|-'}, '\n' )
end
-- Аргументы
args["Вход1"] = args["Вход1"] or args[1] or "" -- улучшаемый предмет
args["Вход2"] = args["Вход2"] or args[2] or "Незеритовый слиток" -- незеритовый слиток
args["Выход"] = args["Выход"] or args[3] or ""
local inputs = {mw.text.trim(args["Вход1"]),
mw.text.trim(args["Вход2"])}
-- Перечислить все ингредиенты
local ingredientsCell
if args["ингредиенты"] or '' ~= '' then
ingredientsCell = args["ингредиенты"]
else
ingredientsCell = {}
local ingredients = {}
local separator = ''
for k, v in ipairs(inputs) do
if k > 1 and next(ingredients) then
separator = ' +<br>\n'
end
for item in mw.text.gsplit( v, '%s*;%s*' ) do
local parts = getParts( item, mod )
if parts.name ~= '' and not ingredients[parts.name] then
local link = ''
if separator == '' and next( ingredients ) then
separator = ' или<br>\n'
end
if parts.mod then
link = parts.mod .. '/' .. parts.name .. '|'
end
if parts.name:find( '^Люб' ) then
if parts.mod then
link = parts.mod .. '/' .. mw.ustring.gsub( mw.ustring.sub( parts.name, 7 ), "^%l", mw.ustring.upper ) .. '|'
end
table.insert( ingredientsCell, separator .. mw.ustring.sub( parts.name, 0, 6 ) .. '[[' .. link .. mw.ustring.sub( parts.name, 7 ) .. ']]' )
else
table.insert( ingredientsCell, separator .. '[[' .. link .. parts.name .. ']]' )
end
separator = ''
ingredients[parts.name] = 1
end
end
end
ingredientsCell = table.concat( ingredientsCell )
end
-- В ячейке для процесса будет собственно интерфейс стола
local recipeCell = p.smithing(args)
-- Что будет на выходе
local nameCell
if args["название"] or '' ~= '' then
nameCell = args["название"]
elseif multirow or f:callParserFunction( '#dplvar', 'resultname' ) == '1' then
local names = {}
local links = {}
for v in mw.text.gsplit(args["Выход"], '%s*;%s*' ) do
parts = getParts( v )
if not names[( parts.mod or '' ) .. parts.name] then
local link = ''
if parts.mod then
link = parts.mod .. '/' .. parts.name .. '|'
end
if parts.name:find( '^Люб' ) then
if parts.mod then
link = parts.mod .. '/' .. mw.ustring.gsub( mw.ustring.sub( parts.name, 7 ), "^%l", mw.ustring.upper ) .. '|'
end
table.insert( ingredientsCell, separator .. mw.ustring.sub( parts.name, 0, 6 ) .. '[[' .. link .. mw.ustring.sub( parts.name, 7 ) .. ']]' )
else
table.insert( ingredientsCell, separator .. '[[' .. link .. parts.name .. ']]' )
end
separator = ''
ingredients[parts.name] = 1
end
end
nameCell = table.concat( links, ' или<br>\n' )
end
if nameCell and args["запланированное"] then
nameCell = nameCell .. '<br>([[' .. args["запланированное"] .. ']])'
end
-- Сборка строки таблицы с интерфейсом
local row = {
'\n|' .. ingredientsCell,
recipeCell
}
if nameCell then
table.insert( row, nameCell )
end
if f:callParserFunction( '#dplvar', 'smithingdescription' ) == '1' then
table.insert( row, args["описание"] or '' )
end
row = table.concat( row, '\n|' ) .. '\n|-'
-- Закрытие таблицы
local footer = ''
if foot ~= '' then
footer = '\n|}'
f:callParserFunction( '#dplvar:set', 'resultname', '0', 'smithingdescription', '0' )
end
local title = mw.title.getCurrentTitle()
local category = ''
if args["запланированное"] and args["некат"] ~= '1' and title.namespace == 0 and not title.isSubpage then
category = '[[Категория:Запланированные материалы]]'
end
return header .. row .. footer .. category
end
return p
Advertisement
Модуль:Кузнечный стол
Advertisement