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

Нет описания правки
Нет описания правки
 
(не показаны 182 промежуточные версии этого же участника)
Строка 1: Строка 1:
-- Загрузка данных
local JsonPaths = require('Module:JsonPaths')
local spriteData = mw.loadData(JsonPaths.get("prototype/sprite.json"))
local p = {}
local p = {}


-- Функция загрузки данных из JSON-страницы
local function normalizeSpritePath(path)
local function loadData(filePath)
if path == nil then
    local page = mw.title.new(filePath)
return nil
    if not page then
end
        return nil
 
    end
path = mw.text.trim(tostring(path))
    local content = page:getContent()
path = path:gsub("^/Textures/?", "")
    if not content then
 
        return nil
return path
    end
    return mw.text.jsonDecode(content)
end
end


-- Функция генерации текста для одного элемента JSON
-- Функция получения таблицы данных
local function generateTemplate(entry)
local function getIdTable()
    if not entry.id or not entry.Sprite or not entry.Sprite.sprite then
if type(spriteData) == "table" and type(spriteData.id) == "table" then
        return nil
return spriteData.id
    end
end
   
return nil
    local template =  
        "== Краткое описание ==\n" ..
        "{{Файл\n" ..
        "|Описание = \n" ..
        "|Id      = %s\n" ..
        "|Сервера  = {{abb|SS14}}\n" ..
        "|Источник = \n" ..
        "|Путь    = Resources/Textures/%s\n" ..
        "|Теги    = \n" ..
        "}}\n\n" ..
        "== Лицензирование ==\n" ..
        "{{CC-BY-SA-3.0}}\n"
   
    return string.format(template, entry.id, entry.Sprite.sprite)
end
end


-- Функция для обёртки текста в HTML с классом
-- Функция для получения таблицы данных
local function wrapInClass(content, className)
function p.getData()
    return string.format('<div class="%s">%s</div>', className, content)
return getIdTable() or {}
end
end


-- Функция для добавления кнопки копирования
-- Функция получения пути спрайта:
local function addCopyIcon(content)
-- 1) сначала entry.sprite
    return content .. '<div class="copy-icon">📋</div>'
-- 2) потом первый layers[*].sprite
local function getSpritePath(entry)
if not entry then
return nil
end
 
if entry.sprite then
return normalizeSpritePath(entry.sprite)
end
 
if type(entry.layers) == "table" then
for _, layer in ipairs(entry.layers) do
if layer and layer.sprite then
return normalizeSpritePath(layer.sprite)
end
end
end
 
return nil
end
end


-- Основная функция модуля
-- Проверка visible
local function isLayerVisible(layer)
if not layer then
return false
end
return layer.visible ~= false
end
 
-- Функция получения списка состояний с учётом переопределяющего sprite в слое
local function getSpriteStates(entry)
local result = {}
local spritePath = getSpritePath(entry)
 
if entry and type(entry.layers) == "table" then
for _, layer in ipairs(entry.layers) do
if isLayerVisible(layer) and layer.state then
table.insert(result, {
state = tostring(layer.state),
sprite = normalizeSpritePath(layer.sprite or spritePath)
})
end
end
elseif entry and entry.state and spritePath then
table.insert(result, {
state = tostring(entry.state),
sprite = spritePath
})
end
 
if #result == 0 and spritePath then
table.insert(result, {
state = "icon",
sprite = spritePath
})
end
 
return (#result > 0) and result or nil
end
 
-- Функция генерации шаблона по записи (mode: image, path, state)
function p.main(frame)
function p.main(frame)
    -- Загрузка данных из указанного JSON-файла
local mode = frame.args[1]
    local data = loadData("User:IanComradeBot/prototypes/entity sprite.json")
local id = frame.args[2]
    if not data or type(data) ~= "table" then
 
        return "Ошибка: Невозможно загрузить данные из JSON."
if not mode or not id then
    end
return "Ошибка: отсутствует режим или ID"
   
end
    -- Создание результата
 
    local result = {}
local data = getIdTable()
    for _, entry in ipairs(data) do
if not data then
        local template = generateTemplate(entry)
return "Ошибка: неверный формат JSON"
        if template then
end
            -- Оборачиваем текст в класс
 
            local wrappedTemplate = wrapInClass(template, "entity-sprite__strings")
if mode == "image" or mode == "state" then
            -- Добавляем кнопку копирования
local entry = data[id]
            local finalTemplate = addCopyIcon(wrappedTemplate)
if not entry then
            table.insert(result, finalTemplate)
return "Ошибка: ID не найден"
        end
end
    end
 
   
if mode == "image" then
    -- Возврат собранного результата
local sprite = getSpritePath(entry)
    return table.concat(result, "\n")
return sprite or "Ошибка: спрайт не найден"
elseif mode == "state" then
local states = getSpriteStates(entry)
if not states then
return ""
end
 
local baseUrl = JsonPaths.git() .. "/Resources/Textures/"
local links = {}
 
for _, item in ipairs(states) do
local spritePath = item.sprite
local stateName = item.state
 
if spritePath then
local url = baseUrl .. normalizeSpritePath(spritePath) .. "/" .. stateName .. ".png"
table.insert(links, "[" .. url .. " " .. stateName .. "]")
else
table.insert(links, stateName .. " Error: sprite not found")
end
end
 
return "(state: " .. table.concat(links, ", ") .. ")"
end
end
 
if mode == "path" then
local targetPath = normalizeSpritePath(id)
 
for entityId, entry in pairs(data) do
if getSpritePath(entry) == targetPath then
return entityId
end
end
 
return "Ошибка: путь не найден"
end
 
return "Ошибка: неизвестный режим"
end
end


return p
return p