Модуль:Песочница/Pok
Для документации этого модуля может быть создана страница Модуль:Песочница/Pok/doc
local p = {}
-- Функция для загрузки данных исследований из JSON-файла
local function loadResearchData()
local content = mw.title.new("User:IanComradeBot/Песочница.json"):getContent()
if not content then
return nil
end
return mw.text.jsonDecode(content)
end
-- Функция для поиска исследований по дисциплине
local function findResearchByDiscipline(dataCache, discipline)
local results = {}
for _, research in ipairs(dataCache) do
if research.technology and research.technology.discipline == discipline then
table.insert(results, research.technology)
end
end
return results
end
-- Таблица для перевода названий дисциплин
local disciplineMapping = {
Arsenal = "Арсенал",
Industrial = "Промышленность",
Experimental = "Экспериментальное",
CivilianServices = "Обслуживание персонала"
}
-- Таблица для цветов по уровням
local tierColors = {
[1] = "#54d554",
[2] = "#ed9000",
[3] = "#d72a2a"
}
function p.main(frame)
-- Подключение CSS
local cssLink = frame:extensionTag('templatestyles', '', {
src = 'Шаблон:Research/styles.css'
})
-- Загрузка данных
local dataCache = loadResearchData()
if not dataCache then
return cssLink .. '<div style="color:red;">Ошибка загрузки данных исследований. Проверьте файл JSON.</div>'
end
-- Получение дисциплины
local discipline = frame.args[1] or ""
if discipline == "" then
return cssLink .. '<div style="color:red;">Не указана дисциплина. Доступные дисциплины: '
.. table.concat(vim.tbl_keys(disciplineMapping), ", ") .. '</div>'
end
-- Инициализация строки вывода
local out = cssLink .. '<div class="research-group">'
-- Получаем список исследований по дисциплине
local researches = findResearchByDiscipline(dataCache, discipline)
if not researches or #researches == 0 then
return out .. '<div style="color:red;">Нет исследований для дисциплины "' .. discipline .. '"</div></div>'
end
-- Формирование блоков исследований
for _, tech in ipairs(researches) do
local disciplineName = disciplineMapping[tech.discipline] or "Неизвестная дисциплина"
local tierColor = tierColors[tech.tier] or "#FFFFFF"
local iconPath = tech.icon and tech.icon.sprite or nil
-- Проверка данных
if not tech.id or not tech.name then
return cssLink .. '<div style="color:red;">Ошибка: отсутствует ID или имя технологии.</div>'
end
-- Основной блок исследования
out = out .. '<div class="research" id="' .. tech.id .. '">'
out = out .. frame:preprocess('<div class="research__images">[[Файл:{{#invoke:Entity Sprite|main|path|' .. (iconPath or "default_icon.png") .. '}}]]</div>')
out = out .. frame:preprocess('<div class="research__name">{{#invoke:Ftl|main|translation|' .. tech.name .. '}}[[Файл:' .. tech.discipline .. '.png|16px|link=]]</div>')
out = out .. '<div class="research__type">'
out = out .. '<div>Уровень: <span style="color:' .. tierColor .. ';">' .. (tech.tier or "N/A") .. '</span></div>'
out = out .. '<div class="research__technology">' .. disciplineName .. '</div>'
out = out .. '<div>Стоимость: <span style="color:#DA70D6;">' .. (tech.cost or "N/A") .. '</span></div>'
out = out .. '</div>'
-- Блок необходимых исследований
if tech.recipeUnlocks and #tech.recipeUnlocks > 0 then
out = out .. '<div class="research__technologies-unlocks">Разблокирует:'
out = out .. '<ul>'
for _, recipe in ipairs(tech.recipeUnlocks) do
-- Проверяем, что recipe не пустой и валидный
if recipe and recipe ~= "" then
out = out .. frame:preprocess('<li>{{#invoke:Entity Lookup|createimagetooltip|Файл:'
.. recipe .. '.png|' .. recipe
.. '|Мета=32x32px,link=}} {{#invoke:Entity Lookup|getname|'
.. recipe .. '}}</li>')
else
out = out .. '<li style="color:red;">Ошибка: некорректный рецепт.</li>'
end
end
out = out .. '</ul>'
out = out .. '</div>'
end
out = out .. '</div>'
end
out = out .. '</div>'
return out
end
return p