Дополнительные действия
DarkMuse (обсуждение | вклад) Нет описания правки |
DarkMuse (обсуждение | вклад) Нет описания правки |
||
| Строка 2: | Строка 2: | ||
function p.renderNotes(frame) | function p.renderNotes(frame) | ||
local parent = frame:getParent() -- Получаем все параметры родительского шаблона | |||
local notes = {} | local notes = {} | ||
-- Проходим по всем | -- Проходим по всем параметрам родительского шаблона | ||
for key, value in pairs( | for key, value in pairs(parent.args) do | ||
if key:match("^note_") and value ~= "" then | |||
if | -- Проверяем, является ли ключ параметром note_ | ||
table.insert(notes, value) | table.insert(notes, {key = key, value = value}) | ||
end | end | ||
end | end | ||
-- Сортируем параметры по ключу для корректного отображения | |||
table.sort(notes, function(a, b) return a.key < b.key end) | |||
-- Если нет примечаний, выводим сообщение | -- Если нет примечаний, выводим сообщение | ||
| Строка 20: | Строка 24: | ||
local result = '<ul>' | local result = '<ul>' | ||
for _, note in ipairs(notes) do | for _, note in ipairs(notes) do | ||
result = result .. '<li>' .. note .. '</li>' | result = result .. '<li>' .. note.value .. '</li>' | ||
end | end | ||
result = result .. '</ul>' | result = result .. '</ul>' | ||
Версия от 13:33, 28 сентября 2024
Описание
Модуль 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.renderNotes(frame)
local parent = frame:getParent() -- Получаем все параметры родительского шаблона
local notes = {}
-- Проходим по всем параметрам родительского шаблона
for key, value in pairs(parent.args) do
if key:match("^note_") and value ~= "" then
-- Проверяем, является ли ключ параметром note_
table.insert(notes, {key = key, value = value})
end
end
-- Сортируем параметры по ключу для корректного отображения
table.sort(notes, function(a, b) return a.key < b.key end)
-- Если нет примечаний, выводим сообщение
if #notes == 0 then
return "Примечаний нет."
end
-- Формируем список примечаний
local result = '<ul>'
for _, note in ipairs(notes) do
result = result .. '<li>' .. note.value .. '</li>'
end
result = result .. '</ul>'
return result
end
return p