Dantes (обсуждение | вклад) Нет описания правки |
Dantes (обсуждение | вклад) Нет описания правки |
||
| Строка 29: | Строка 29: | ||
local html = {} | local html = {} | ||
table.insert(html, '<div style="border: 2px solid ' .. borderColor .. '; padding: 1em; border-radius: 8px; background: ' .. backgroundColor .. '; max-width: 600px;">') | |||
-- Внешний контейнер с классом | |||
table.insert(html, '<div class="alchemy-recipe-card" style="border: 2px solid ' .. borderColor .. '; padding: 1em; border-radius: 8px; background: ' .. backgroundColor .. '; max-width: 600px; margin: 1em auto;">') | |||
table.insert(html, '<h3 style="margin-top:0; text-align:center;">' .. title .. '</h3>') | table.insert(html, '<h3 style="margin-top:0; text-align:center;">' .. title .. '</h3>') | ||
-- | -- Flex контейнер | ||
table.insert(html, '<div style="display: flex; text-align: center; align-items: stretch;">') | table.insert(html, '<div style="display: flex; text-align: center; align-items: stretch;">') | ||
-- Ингредиенты | |||
table.insert(html, '<div style="flex: 1; display: flex; flex-direction: column; justify-content: center; border-right: 1px solid #aaa; padding-right: 0.5em;">') | table.insert(html, '<div style="flex: 1; display: flex; flex-direction: column; justify-content: center; border-right: 1px solid #aaa; padding-right: 0.5em;">') | ||
table.insert(html, listBlock(ingredients)) | table.insert(html, listBlock(ingredients)) | ||
table.insert(html, '</div>') | table.insert(html, '</div>') | ||
-- Смешать | |||
table.insert(html, '<div style="flex: 0 0 100px; display: flex; align-items: center; justify-content: center; font-weight:bold;">СМЕШАТЬ</div>') | table.insert(html, '<div style="flex: 0 0 100px; display: flex; align-items: center; justify-content: center; font-weight:bold;">СМЕШАТЬ</div>') | ||
-- Результат | |||
table.insert(html, '<div style="flex: 1; display: flex; flex-direction: column; justify-content: center; border-left: 1px solid #aaa; padding-left: 0.5em;">') | table.insert(html, '<div style="flex: 1; display: flex; flex-direction: column; justify-content: center; border-left: 1px solid #aaa; padding-left: 0.5em;">') | ||
table.insert(html, listBlock(result)) | table.insert(html, listBlock(result)) | ||
table.insert(html, '</div>') | table.insert(html, '</div>') | ||
table.insert(html, '</div>') | table.insert(html, '</div>') | ||
-- Эффекты | -- Эффекты список | ||
if effects ~= "" then | if effects ~= "" then | ||
table.insert(html, '<hr><b>Эффекты:</b><ul>') | table.insert(html, '<hr><b>Эффекты:</b><ul>') | ||
| Строка 50: | Строка 60: | ||
end | end | ||
-- Описание эффектов ( | -- Описание эффектов (курсивом) | ||
if effectsDesc ~= "" then | if effectsDesc ~= "" then | ||
table.insert(html, '<div style="margin-top: 0.5em; font-style: italic; color: #555;">' .. mw.text.trim(effectsDesc) .. '</div>') | table.insert(html, '<div style="margin-top: 0.5em; font-style: italic; color: #555;">' .. mw.text.trim(effectsDesc) .. '</div>') | ||
| Строка 56: | Строка 66: | ||
table.insert(html, '</div>') | table.insert(html, '</div>') | ||
return table.concat(html, "\n") | return table.concat(html, "\n") | ||
end | end | ||
return p | return p | ||
Версия от 10:55, 16 мая 2025
Для документации этого модуля может быть создана страница Модуль:AlchemyRecipe/doc
local p = {}
function p.card(frame)
local args = frame:getParent().args
local title = args["Название"] or "Без названия"
local ingredients = args["Ингредиенты"] or ""
local result = args["Результат"] or ""
local effects = args["Эффекты"] or ""
local effectsDesc = args["ОписаниеЭффектов"] or ""
local borderColor = args["ЦветРамки"] or "#ccc"
local backgroundColor = args["ЦветФона"] or "#f9f9f9"
local function listBlock(text)
local items = {}
for item in mw.text.gsplit(text, ";") do
table.insert(items, "<div>" .. mw.text.trim(item) .. "</div>")
end
return table.concat(items, "\n")
end
local function listUL(text)
local items = {}
for item in mw.text.gsplit(text, ";") do
table.insert(items, "<li>" .. mw.text.trim(item) .. "</li>")
end
return table.concat(items, "\n")
end
local html = {}
-- Внешний контейнер с классом
table.insert(html, '<div class="alchemy-recipe-card" style="border: 2px solid ' .. borderColor .. '; padding: 1em; border-radius: 8px; background: ' .. backgroundColor .. '; max-width: 600px; margin: 1em auto;">')
table.insert(html, '<h3 style="margin-top:0; text-align:center;">' .. title .. '</h3>')
-- Flex контейнер
table.insert(html, '<div style="display: flex; text-align: center; align-items: stretch;">')
-- Ингредиенты
table.insert(html, '<div style="flex: 1; display: flex; flex-direction: column; justify-content: center; border-right: 1px solid #aaa; padding-right: 0.5em;">')
table.insert(html, listBlock(ingredients))
table.insert(html, '</div>')
-- Смешать
table.insert(html, '<div style="flex: 0 0 100px; display: flex; align-items: center; justify-content: center; font-weight:bold;">СМЕШАТЬ</div>')
-- Результат
table.insert(html, '<div style="flex: 1; display: flex; flex-direction: column; justify-content: center; border-left: 1px solid #aaa; padding-left: 0.5em;">')
table.insert(html, listBlock(result))
table.insert(html, '</div>')
table.insert(html, '</div>')
-- Эффекты список
if effects ~= "" then
table.insert(html, '<hr><b>Эффекты:</b><ul>')
table.insert(html, listUL(effects))
table.insert(html, '</ul>')
end
-- Описание эффектов (курсивом)
if effectsDesc ~= "" then
table.insert(html, '<div style="margin-top: 0.5em; font-style: italic; color: #555;">' .. mw.text.trim(effectsDesc) .. '</div>')
end
table.insert(html, '</div>')
return table.concat(html, "\n")
end
return p