Модуль:Песочница/Pok: различия между версиями

мНет описания правки
мНет описания правки
(не показано 407 промежуточных версий этого же участника)
Строка 1: Строка 1:
local p = {}
local p = {}


-- Функция для загрузки данных плат из JSON-файла
local function trim(s)
local function loadData()
    if not s then return s end
return mw.text.jsonDecode(mw.title.new("User:IanComradeBot/armor_prototypes.json"):getContent())
    return (s:gsub('^%s*(.-)%s*$', '%1'))
end
end


-- Функция для поиска данных по ID
local function strip_trailing_digits(s)
local function findDataById(dataCache, id)
    return s:gsub('%d+$', '')
for _, item in ipairs(dataCache) do
if item.id == id then
return item
end
end
return nil
end
end


-- Функция для точного округления до ближайшего целого числа
local function split_first_underscore(k)
local function round(num)
    local a, b = k:match('^([^_]+)_(.+)$')
return math.floor(num + 0.5)
    return a, b
end
end


-- Функция для преобразования значения в проценты
local function collect_labels_from_args(args)
local function formatPercentage(value)
    local meta = {}
return value and round((1 - value) * 100) .. "%" or "-"
    local seen = {}
    for k, v in pairs(args) do
        if type(k) == 'string' and k:find('_', 1, true) then
            local base, rem = split_first_underscore(k)
            if base and rem then
                local label = strip_trailing_digits(rem)
                label = trim(label)
                if label ~= '' then
                    meta[base] = meta[base] or {}
                    if not seen[base] then seen[base] = {} end
                    if not seen[base][label] then
                        table.insert(meta[base], label)
                        seen[base][label] = true
                    end
                end
            end
        end
    end
    return meta
end
end


-- Функция для создания строк для таблицы по типу защиты
local function render_from_args(args)
local function createProtectionRow(class, color, value)
    local field = args[1] or args.field or args["field"]
return '|class="' .. class .. '" style="font-weight:bold;color: ' .. color .. ';"|' .. value .. '\n'
    local label = args[2] or args.label or args["label"]
end
    field = field and trim(field) or ''
    label = label and trim(label) or ''


function p.main(frame)
    -- map base -> label -> value
local dataCache = loadData()
    local map = {}
local id = frame.args.id or "" -- ID предмета
    for k, v in pairs(args) do
local itemData = findDataById(dataCache, id)
        if type(k) == 'string' and k:find('_', 1, true) then
            local base, rem = split_first_underscore(k)
            if base and rem then
                local lab = strip_trailing_digits(rem)
                lab = trim(lab)
                map[base] = map[base] or {}
                local cur = map[base][lab]
                if cur then
                    map[base][lab] = cur .. '\n' .. tostring(v)
                else
                    map[base][lab] = tostring(v)
                end
            end
        end
    end


-- Получаем защитные значения из coefficients, если они присутствуют
    if field ~= '' and label ~= '' then
local coefficients = itemData and itemData.coefficients
        local base = map[field]
local protBlunt = formatPercentage(coefficients and coefficients.Blunt)
        if base then return base[label] or '' end
local protSlash = formatPercentage(coefficients and coefficients.Slash)
        return ''
local protPiercing = formatPercentage(coefficients and coefficients.Piercing)
    end
local protHeat = formatPercentage(coefficients and coefficients.Heat)
local protRadiation = formatPercentage(coefficients and coefficients.Radiation)
local protCaustic = formatPercentage(coefficients and coefficients.Caustic)
local protExplosion = formatPercentage(itemData and itemData.ExplosionResistance and itemData.ExplosionResistance.damageCoefficient)


-- Получаем значения sprintModifier, walkModifier, fireProtection
    if args[1] and args[2] then
local sprintModifier = itemData and itemData.sprintModifier
        local f = trim(args[1]); local l = trim(args[2])
local walkModifier = itemData and itemData.walkModifier
        local base = map[f]
local fireProtection = itemData and itemData.FireProtection and itemData.FireProtection.reduction
        if base then return base[l] or '' end
local speedDescription = ""
    end


-- Формируем сообщение в зависимости от значений sprintModifier и walkModifier
    return ''
if sprintModifier and walkModifier then
end
local sprintPercent = round((1 - sprintModifier) * 100)
local walkPercent = round((1 - walkModifier) * 100)


speedDescription = "* Понижает скорость " .. (sprintModifier == walkModifier and "передвижения" or "бега и ходьбы") ..
function p.main(frame)
  " на <span style=\"color:yellow\">'''" .. sprintPercent .. " %'''</span>\n"
    local args = frame.args or {}
if sprintModifier ~= walkModifier then
    local has_any = false
speedDescription = speedDescription .. "* Понижает скорость ходьбы на <span style=\"color:yellow\">'''" .. walkPercent .. " %'''</span>\n"
    for k, _ in pairs(args) do
end
        has_any = true; break
end
    end
 
    if not has_any then return collect_labels_from_args(args) end
-- Формируем сообщение для огневой защиты, если значение присутствует
local fireProtectionDescription = fireProtection and
"* Имеет огневую защиту в <span style=\"color:OrangeRed\">'''" .. round((1 - fireProtection) * 100) .. " %'''</span>\n" or ""
 
-- Описание и местоположение
local description = (frame.args.description or "") .. '\n' .. speedDescription .. fireProtectionDescription -- Описание
local location = frame.args.location or "" -- Местонахождение
local created = frame.args.created or "" -- Создание
 
local anchorName = frame.args.anchorName or "" -- Название якоря
local backgroundColor = frame.args.backgroundColor or "" -- Цвет фона первой ячейки
local class = frame.args.class or "" -- Класс
 
-- Формирование строк для ячеек таблицы
local out = ''
out = out .. '!class="' .. class .. '" style="background-color: ' .. backgroundColor .. ';"|' .. frame:preprocess('{{Anchor|' .. anchorName .. '}}')
out = out .. frame:preprocess('{{#invoke:Entity Lookup|createimagetooltip|File:' .. id .. '.png|' .. id .. '|Мета=64x64px,link=}}')
out = out .. '<br>' .. frame:preprocess('{{#invoke:Entity Lookup|getname|' .. id .. '}}') .. '\n'
 
-- Используем функцию для формирования строк защиты
out = out .. createProtectionRow(class, "crimson", protBlunt)
out = out .. createProtectionRow(class, "indianred", protSlash)
out = out .. createProtectionRow(class, "darksalmon", protPiercing)
out = out .. createProtectionRow(class, "orange", protHeat)
out = out .. createProtectionRow(class, "plum", protCaustic)
out = out .. createProtectionRow(class, "limegreen", protRadiation)
out = out .. createProtectionRow(class, "tan", protExplosion)
 
out = out .. '|class="' .. class .. '" style=""|\n' .. description .. '\n'
out = out .. '|class="' .. class .. '" style=""|\n'
 
 
-- Проверка класса на "spacesuit-helmet"
if class == "spacesuit-helmet" then
out = out .. frame:preprocess("{{FrameText|color = #bcceff|border-color = #4c4c61|content = Находится в скафандре}}")
-- Местоположение
elseif location ~= "" then
out = out .. frame:preprocess('{{SlideMenu|overlay|color=#e1f6ff|title=Список [[File:Examine.svg.192dpi.png|24x24px]]|content=<p></p>\n' .. location .. '}}\n')
end
 
-- Создаётся
if created ~= "" then
out = out .. frame:preprocess('{{SlideMenu|overlay|color=#e1f6ff|border-color=#4c4c61|title=Создаётся [[File:hammer.svg.192dpi.png|24x24px]]|content=Создаётся в панели строительства<hr>\n' .. created .. '}}\n')
elseif location == "" and class ~= "spacesuit-helmet" then
out = out .. frame:preprocess('{{FrameText|color=#82d1c4|content=Нет гарантированных мест спавна}}\n')
end
 
out = out .. '|-\n'


return out
    return render_from_args(args)
end
end


return p
return p