Дополнительные действия
Описание
Модуль RenderSubnotes используется для рендеринга примечаний и действий с изображениями в карточках героев или других информационных блоках. Этот модуль предоставляет две основные функции: renderNotes для отображения примечаний и renderItemsAction для рендеринга действий с изображениями.
Использование
Функция renderNotes
Функция renderNotes используется для отображения примечаний, где примечания могут быть как основными, так и вложенными. Основные примечания задаются параметрами вида note_1, note_2 и так далее. Вложенные примечания задаются параметрами вида note_1_1, note_1_2 и так далее.
Пример использования:
{{#invoke:RenderSubnotes|renderNotes
| note_1 = Примечание 1
| note_1_1 = Подпримечание 1.1
| note_1_2 = Подпримечание 1.2
| note_2 = Примечание 2
}}
Функция renderItemsAction
Функция renderItemsAction используется для отображения действий с изображениями. Описание действия задается параметром вида itemsActionDescr_1, а изображение – параметром itemsActionImage_1_1, где числа после символа подчеркивания должны совпадать для правильной привязки изображения к действию.
Пример использования:
{{#invoke:RenderSubnotes|renderItemsAction
| itemsActionDescr_1 = Описание действия 1
| itemsActionImage_1_1 = action_image_1.png
| itemsActionImage_1_2 = action_image_2.png
| itemsActionDescr_2 = Описание действия 2
| itemsActionImage_2_1 = action_image_3.png
}}
Параметры
Параметры для renderNotes
note_X– основное примечание, гдеX– порядковый номер.note_X_Y– вложенное примечание, гдеX– номер основного примечания, аY– номер вложенного примечания.
Параметры для renderItemsAction
itemsActionDescr_X– описание действия, гдеX– порядковый номер.itemsActionImage_X_Y– изображение для действия, гдеX– номер действия, аY– номер изображения для данного действия.
Примечания
- Основные примечания могут иметь несколько уровней вложенности.
- Изображения для действий должны быть привязаны к правильным действиям с помощью одинаковых порядковых номеров в параметрах.
local p = {}
function p.renderSubnotes(frame, prefix, index)
local result = {}
local i = 1
while true do
local subnote = frame.args[prefix .. "_" .. index .. "_" .. i]
if not subnote then break end
table.insert(result, string.format("<li>%s</li>", subnote))
i = i + 1
end
if #result > 0 then
return string.format("<ul>%s</ul>", table.concat(result, "\n"))
end
return nil
end
function p.renderNotes(frame)
local result = {}
local i = 1
while true do
local note = frame.args["note_" .. i]
if not note then break end
-- Render the main note
local noteItem = string.format("<li>%s", note)
-- Render subnotes if they exist
local subnotes = p.renderSubnotes(frame, "note", i)
if subnotes then
noteItem = noteItem .. subnotes
end
noteItem = noteItem .. "</li>"
table.insert(result, noteItem)
i = i + 1
end
return table.concat(result, "\n")
end
return p