Модуль:Предмет

Материал из Space Station 14 Вики

Для документации этого модуля может быть создана страница Модуль:Предмет/doc

local p = {}
local getArgs = require('Module:Arguments').getArgs

--------------------------------------------------------------------------------
-- Вспомогательные функции
--------------------------------------------------------------------------------

-- Формирует строку ссылки на изображение
local function formatImage(file, size)
	return string.format("[[Файл:%s|%s]]", file, size)
end

-- Возвращает значение аргумента: если nil, то значение по умолчанию; если пустая строка, то пустую строку; иначе само значение
local function resolveArg(input, defaultValue)
	if input == nil then
		return defaultValue
	elseif input == "" then
		return ""
	else
		return input
	end
end

-- Обёртка для вызова другого модуля через #invoke
local function invoke(frame, module, method, subMethod, extra, id)
	local invocation = string.format("{{#invoke:%s|%s|%s|%s|%s}}", module, method, subMethod, extra, id)
	return frame:preprocess(invocation)
end

-- Оборачивает текст в вики-ссылку, если цель задана
local function wrapLink(text, target)
	if text == "" then
		return ""
	else
		return string.format("[[%s|%s]]", target, text)
	end
end

--------------------------------------------------------------------------------
-- Основная функция модуля
--------------------------------------------------------------------------------

function p.main(frame)
	-- Получаем аргументы шаблона
	local args = getArgs(frame)
	local argsRaw = getArgs(frame, { trim = false, removeBlanks = false })

	-- Основные параметры
	local id       = args[1] or ""
	local size     = args["size"] or "32px"
	local prefix   = args[2] or ""
	local vertical = argsRaw.vertical

	-- Получаем данные о предмете через вызовы других модулей
	local itemStack     = invoke(frame, "Prototypes/Хранилище/Предмет", "main", "framing", "stack", id)
	local itemContained = invoke(frame, "Prototypes/Хранилище/Предмет", "main", "framing", "contained", id)
	local itemSlot      = invoke(frame, "Prototypes/Хранилище/Предмет", "main", "framing", "slot", id)
	-- Для химии оборачиваем в CollapsibleMenu (из-за ошибки в модуле)
	local itemChem = frame:preprocess(string.format("{{СollapsibleMenu|color=#3e7c82|{{#invoke:Prototypes/Хранилище/Предмет|main|chem|%s}}}}", id))
	local itemName = frame:preprocess(string.format("{{#invoke:Entity Lookup|getname|%s}}", id))

	-- Обработка ярлыка
	local rawLabel = argsRaw.label or argsRaw.l
	local label = rawLabel == nil and itemName or resolveArg(rawLabel, itemName)

	-- Обработка изображения
	local rawImage = argsRaw.image or argsRaw.img
	local image
	if rawImage == nil then
		image = formatImage(id .. ".png", size)
	else
		image = (rawImage ~= "") and formatImage(rawImage, size) or ""
	end

	-- Если указан imageTooltip, переопределяем изображение
	if argsRaw.imageTooltip ~= nil then
		image = frame:preprocess(string.format(
			"{{#invoke:Entity Lookup|createimagetooltip|Файл:%s.png|%s|Мета=%s}}",
			id, id, size
		))
	end

	-- Обработка ссылки
	local rawLink = argsRaw.link
	local labelOutput = (rawLink ~= nil) and wrapLink(label, (rawLink == "" and itemName or rawLink)) or label

	-- Формирование описания репозитория
	local repository = (argsRaw.repository == nil) and prefix or table.concat({ itemContained, itemSlot, itemChem }, " ")

	-- Формирование итогового блока с изображением и описанием
	local imagerepository, result
	if vertical ~= nil then
		imagerepository = string.format(
			"<span style='display:inline-flex;flex-direction:column;align-items:center;'>%s<b>%s</b></span>",
			image, labelOutput
		)
		result = table.concat({ imagerepository, itemStack, prefix }, " ")
	else
		imagerepository = string.format("<span>%s%s</span>", image, repository)
		result = table.concat({ imagerepository, labelOutput, itemStack, prefix }, " ")
	end

	-- Если задан параметр wrapper, формируем LinkCard
	if argsRaw.wrapper ~= nil then
		local pixel = string.match(size, "(%d+)")
		local linkParam = (rawLink ~= nil) and ((rawLink == "" and itemName) or rawLink) or ""
		-- Если vertical не задан, добавляем SideStyle=1
		local sideStyle = (vertical ~= nil) and "" or "|SideStyle=1"

		return frame:preprocess(string.format(
			"{{LinkCard|name=%s %s %s|pin=%s|image-full=%s|pixel=%s|link=%s%s}}",
			labelOutput, itemStack, prefix, repository, image, pixel, linkParam, sideStyle
		))
	end

	return frame:preprocess(string.format("<span>%s</span>", result))
end

return p