Модуль:Research: различия между версиями

Материал из Space Station 14 Вики
мНет описания правки
мНет описания правки
Строка 1: Строка 1:
local p = {}
local p = {}
-- Функция для загрузки данных плат из JSON-файла
local function loadBoardData()
return mw.text.jsonDecode(mw.title.new("User:IanComradeBot/entity_prototypes.json"):getContent())
end


-- Функция для загрузки данных исследований из JSON-файла
-- Функция для загрузки данных исследований из JSON-файла
local function loadResearchData()
local function loadResearchData()
return mw.text.jsonDecode(mw.title.new("User:IanComradeBot/research_prototypes.json"):getContent())
    return mw.text.jsonDecode(mw.title.new("User:IanComradeBot/research_prototypes.json"):getContent())
end
end
-- Кэш для ID машин
local machineIDCache = {}


-- Функция для поиска данных по ID
-- Функция для поиска данных по ID
Строка 20: Строка 18:
     return nil
     return nil
end
end
-- Кэш для ID машин
local machineIDCache = {}


-- Функция для перевода ID плат в ID машин
-- Функция для перевода ID плат в ID машин
local function translateBoardIDToMachineID(boardID)
local function translateBoardIDToMachineID(boardID)
if machineIDCache[boardID] then
    if machineIDCache[boardID] then
-- Если ID машины уже есть в кэше, возвращаем его
        return machineIDCache[boardID]
return machineIDCache[boardID]
    end
end


-- Загружаем данные плат
    local data = mw.text.jsonDecode(mw.title.new("User:IanComradeBot/entity_prototypes.json"):getContent())
local data = loadBoardData()
    local board = data[boardID]
    if not board or not board.name then
        return nil
    end


-- Поиск платы по ID
    if not board.name:find("%(машинная плата%)") and not board.name:find("%(консольная плата%)") then
local board = data[boardID]
        return nil
if not board or not board.name then
    end
return nil
end


-- Проверка на машинные или консольные платы
    local machineName = board.name:gsub(" %(машинная плата%)", ""):gsub(" %(консольная плата%)", "")
if not board.name:find("%(машинная плата%)") and not board.name:find("%(консольная плата%)") then
    local excludeWords = {"Unanchored", "Debug", "Admin", "Enabled"}
return nil
end


-- Удаление фраз из имени платы
    for _, entity in pairs(data) do
local machineName = board.name:gsub(" %(машинная плата%)", ""):gsub(" %(консольная плата%)", "")
        if entity.name == machineName then
            local shouldExclude = false
            for _, word in ipairs(excludeWords) do
                if entity.id:find(word) then
                    shouldExclude = true
                    break
                end
            end


-- Исключения
            if not shouldExclude then
local excludeWords = {"Unanchored", "Debug", "Admin", "Enabled"}
                machineIDCache[boardID] = entity.id
                return entity.id
            end
        end
    end


-- Поиск машины по новому имени
    return nil
for _, entity in pairs(data) do
if entity.name == machineName then
local shouldExclude = false
for _, word in ipairs(excludeWords) do
if entity.id:find(word) then
shouldExclude = true
break
end
end
 
if not shouldExclude then
-- Кэширование ID машины
machineIDCache[boardID] = entity.id
return entity.id
end
end
end
 
return nil
end
end


-- Таблица для перевода названий дисциплин
-- Таблица для перевода названий дисциплин
local disciplineMapping = {
local disciplineMapping = {
Arsenal = "Арсенал",
    Arsenal = "Арсенал",
Industrial = "Промышленность",
    Industrial = "Промышленность",
Experimental = "Экспериментальное",
    Experimental = "Экспериментальное",
CivilianServices = "Обслуживание персонала"
    CivilianServices = "Обслуживание персонала"
}
}


-- Таблица для цветов по уровню
-- Таблица для цветов по уровню
local tierColors = {
local tierColors = {
[1] = "#54d554",
    [1] = "#54d554",
[2] = "#ed9000",
    [2] = "#ed9000",
[3] = "#d72a2a"
    [3] = "#d72a2a"
}
}


function p.main(frame)
function p.main(frame)
-- Загрузка данных исследований
    -- Подключение CSS
local dataCache = loadResearchData()
    local cssLink = frame:extensionTag('templatestyles', '', {
        src = 'Шаблон:Research/styles.css'
-- Получаем ID исследования
    })
local id = frame.args.id or ""
local icon = frame.args.icon or ""
local customRecipeUnlocks = frame.args.customRecipeUnlocks or nil
-- Поиск данных исследования по ID
local tech = findResearchById(dataCache, id)
if not tech then
return '<div style="color:red;">Нет доступных исследований.</div>'
end


-- Получение локализованного имени дисциплины
    local dataCache = loadResearchData()
local disciplineName = disciplineMapping[tech.discipline] or "Неизвестная дисциплина"
    local id = frame.args.id or ""
    local icon = frame.args.icon or ""
    local customRecipeUnlocks = frame.args.customRecipeUnlocks or nil


-- Получение цвета для уровня
    local tech = findResearchById(dataCache, id)
local tierColor = tierColors[tech.tier] or "#FFFFFF"
    if not tech then
        return cssLink .. '<div style="color:red;">Нет доступных исследований.</div>'
    end


-- Формирование вывода
    local disciplineName = disciplineMapping[tech.discipline] or "Неизвестная дисциплина"
local out = '<div class="research" id="' .. tech.discipline .. '">'
    local tierColor = tierColors[tech.tier] or "#FFFFFF"
out = out .. '<div class="research__images">[[Файл:' .. icon .. '.png|64x64px|центр|link=]]</div>'
out = out .. '<div class="research__name">' .. tech.name .. '[[Файл:' .. tech.discipline .. '.png|16px|link=]]</div>'
out = out .. '<div class="research__type">'
out = out .. '<div>Уровень: <span style="color:' .. tierColor .. ';">' .. tech.tier .. '</span></div>'
out = out .. '<div class="research__technology">' .. disciplineName .. '</div>'
out = out .. '<div>Стоимость: <span style="color:#DA70D6;">' .. tech.cost .. '</span></div>'
out = out .. '</div>'
out = out .. '<div class="research__unblocks">Разблокирует:'
out = out .. '<ul>'


-- Используем кастомные recipeUnlocks или значения из json
    local out = cssLink .. '<div class="research" id="' .. tech.discipline .. '">'
local recipeUnlocks = customRecipeUnlocks and mw.text.split(customRecipeUnlocks, " ") or tech.recipeUnlocks
    out = out .. '<div class="research__images">[[Файл:' .. icon .. '.png|64x64px|центр|link=]]</div>'
    out = out .. '<div class="research__name">' .. tech.name .. '[[Файл:' .. tech.discipline .. '.png|16px|link=]]</div>'
    out = out .. '<div class="research__type">'
    out = out .. '<div>Уровень: <span style="color:' .. tierColor .. ';">' .. tech.tier .. '</span></div>'
    out = out .. '<div class="research__technology">' .. disciplineName .. '</div>'
    out = out .. '<div>Стоимость: <span style="color:#DA70D6;">' .. tech.cost .. '</span></div>'
    out = out .. '</div>'
    out = out .. '<div class="research__unblocks">Разблокирует:'
    out = out .. '<ul>'


-- Формируем список рецептов
    local recipeUnlocks = customRecipeUnlocks and mw.text.split(customRecipeUnlocks, " ") or tech.recipeUnlocks
for _, recipe in ipairs(recipeUnlocks) do
    for _, recipe in ipairs(recipeUnlocks) do
local machineID = translateBoardIDToMachineID(recipe) or recipe
        local machineID = translateBoardIDToMachineID(recipe) or recipe
out = out .. frame:preprocess('<li>{{#invoke:Entity Lookup|createimagetooltip|Файл:' .. machineID .. '.png|' .. machineID .. '|Мета=32x32px,link=}} {{#invoke:Entity Lookup|getname|' .. machineID .. '}}</li>')
        out = out .. frame:preprocess('<li>{{#invoke:Entity Lookup|createimagetooltip|Файл:' .. machineID .. '.png|' .. machineID .. '|Мета=32x32px,link=}} {{#invoke:Entity Lookup|getname|' .. machineID .. '}}</li>')
end
    end


out = out .. '</ul>'
    out = out .. '</ul>'
out = out .. '</div>'
    out = out .. '</div>'
out = out .. '</div>'
    out = out .. '</div>'


return out
    return out
end
end


return p
return p

Версия от 12:02, 21 ноября 2024

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

local p = {}

-- Функция для загрузки данных исследований из JSON-файла
local function loadResearchData()
    return mw.text.jsonDecode(mw.title.new("User:IanComradeBot/research_prototypes.json"):getContent())
end

-- Кэш для ID машин
local machineIDCache = {}

-- Функция для поиска данных по ID
local function findResearchById(dataCache, id)
    for _, tech in ipairs(dataCache) do
        if tech.id == id then
            return tech
        end
    end
    return nil
end

-- Функция для перевода ID плат в ID машин
local function translateBoardIDToMachineID(boardID)
    if machineIDCache[boardID] then
        return machineIDCache[boardID]
    end

    local data = mw.text.jsonDecode(mw.title.new("User:IanComradeBot/entity_prototypes.json"):getContent())
    local board = data[boardID]
    if not board or not board.name then
        return nil
    end

    if not board.name:find("%(машинная плата%)") and not board.name:find("%(консольная плата%)") then
        return nil
    end

    local machineName = board.name:gsub(" %(машинная плата%)", ""):gsub(" %(консольная плата%)", "")
    local excludeWords = {"Unanchored", "Debug", "Admin", "Enabled"}

    for _, entity in pairs(data) do
        if entity.name == machineName then
            local shouldExclude = false
            for _, word in ipairs(excludeWords) do
                if entity.id:find(word) then
                    shouldExclude = true
                    break
                end
            end

            if not shouldExclude then
                machineIDCache[boardID] = entity.id
                return entity.id
            end
        end
    end

    return nil
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()
    local id = frame.args.id or ""
    local icon = frame.args.icon or ""
    local customRecipeUnlocks = frame.args.customRecipeUnlocks or nil

    local tech = findResearchById(dataCache, id)
    if not tech then
        return cssLink .. '<div style="color:red;">Нет доступных исследований.</div>'
    end

    local disciplineName = disciplineMapping[tech.discipline] or "Неизвестная дисциплина"
    local tierColor = tierColors[tech.tier] or "#FFFFFF"

    local out = cssLink .. '<div class="research" id="' .. tech.discipline .. '">'
    out = out .. '<div class="research__images">[[Файл:' .. icon .. '.png|64x64px|центр|link=]]</div>'
    out = out .. '<div class="research__name">' .. tech.name .. '[[Файл:' .. tech.discipline .. '.png|16px|link=]]</div>'
    out = out .. '<div class="research__type">'
    out = out .. '<div>Уровень: <span style="color:' .. tierColor .. ';">' .. tech.tier .. '</span></div>'
    out = out .. '<div class="research__technology">' .. disciplineName .. '</div>'
    out = out .. '<div>Стоимость: <span style="color:#DA70D6;">' .. tech.cost .. '</span></div>'
    out = out .. '</div>'
    out = out .. '<div class="research__unblocks">Разблокирует:'
    out = out .. '<ul>'

    local recipeUnlocks = customRecipeUnlocks and mw.text.split(customRecipeUnlocks, " ") or tech.recipeUnlocks
    for _, recipe in ipairs(recipeUnlocks) do
        local machineID = translateBoardIDToMachineID(recipe) or recipe
        out = out .. frame:preprocess('<li>{{#invoke:Entity Lookup|createimagetooltip|Файл:' .. machineID .. '.png|' .. machineID .. '|Мета=32x32px,link=}} {{#invoke:Entity Lookup|getname|' .. machineID .. '}}</li>')
    end

    out = out .. '</ul>'
    out = out .. '</div>'
    out = out .. '</div>'

    return out
end

return p