Модуль:Prototypes/Хранилище/Предмет: различия между версиями
Pok (обсуждение | вклад) Отмена правки 64370, сделанной Pok (обсуждение) Метка: отмена |
Pok (обсуждение | вклад) мНет описания правки |
||
| Строка 7: | Строка 7: | ||
-- Функция processRolls для преобразования диапазона | -- Функция processRolls для преобразования диапазона | ||
local processRolls = function(rolls) | local processRolls = function(rolls) | ||
if not rolls then return 'Не указан параметр rolls.' end | |||
if | if rolls.range then | ||
local min, max = rolls.range:match("(%d+),%s*(%d+)") | local min, max = rolls.range:match("(%d+),%s*(%d+)") | ||
if min and max then | if min and max then | ||
return string.format('от %d до %d.', min + 1, max + 1) | |||
end | end | ||
elseif | return 'Некорректный формат для range.' | ||
elseif rolls.value then | |||
return string.format('Будет сгенерировано %d предметов.', rolls.value) | |||
end | end | ||
return | return 'Не указан параметр rolls.' | ||
end | end | ||
| Строка 34: | Строка 28: | ||
local page = mw.title.new(filePath) | local page = mw.title.new(filePath) | ||
local content = page:getContent() | local content = page:getContent() | ||
dataCache[filePath] = content and mw.text.jsonDecode(content) or | dataCache[filePath] = content and mw.text.jsonDecode(content) or {} | ||
indexCache[filePath] = {} | |||
for _, item in ipairs(dataCache[filePath]) do | |||
indexCache[filePath][item.id] = item | |||
end | |||
end | end | ||
indexCache[ | return dataCache[filePath], indexCache[filePath] | ||
end | end | ||
-- Поиск данных по ID через | -- Поиск данных по ID через кэшированный индекс | ||
findDataById = function(dataIndex, id) | findDataById = function(dataIndex, id) | ||
return | return dataIndex[id] | ||
end | end | ||
-- Форматирование содержимого | -- Форматирование содержимого | ||
formatContent = function(content) | formatContent = function(content) | ||
if not content.id then | if not content.id then return "Ошибка: отсутствует id у элемента." end | ||
local name = string.format('{{#invoke:Entity Lookup|getname|%s}}', content.id) | local name = string.format('{{#invoke:Entity Lookup|getname|%s}}', content.id) | ||
local image = | local image = content.id .. ".png" | ||
local amount = content.amount and string.format(" [%d]", content.amount) or "" | local amount = content.amount and string.format(" [%d]", content.amount) or "" | ||
local prob = | local prob = content.weight and string.format(" <div>%.0f%%</div>", (content.weight / 100) * 100) or "" | ||
return string.format( | return string.format( | ||
'{{LinkСard|SideStyle=1|background-color=#cbcbff0b|image=%s|name=%s%s%s {{#invoke:Prototypes/Хранилище/Предмет|main|framing|contained|%s}} }}', | '{{LinkСard|SideStyle=1|background-color=#cbcbff0b|image=%s|name=%s%s%s {{#invoke:Prototypes/Хранилище/Предмет|main|framing|contained|%s}} }}', | ||
| Строка 93: | Строка 69: | ||
processNestedSelectors = function(children) | processNestedSelectors = function(children) | ||
if not children or #children == 0 then return "" end | if not children or #children == 0 then return "" end | ||
local results = {} | local results = {} | ||
for _, child in ipairs(children) do | for _, child in ipairs(children) do | ||
results[#results + 1] = child.id and formatContent(child) or "" | |||
end | end | ||
return table.concat(results) | return table.concat(results) | ||
end | end | ||
| Строка 116: | Строка 78: | ||
-- Обработка таблиц | -- Обработка таблиц | ||
getTableOutput = function(tableId) | getTableOutput = function(tableId) | ||
local allSelectors = loadData('User:IanComradeBot/prototypes/AllSelector.json') | local allSelectors, allSelectorsIndex = loadData('User:IanComradeBot/prototypes/AllSelector.json') | ||
local tableData = findDataById( | local tableData = findDataById(allSelectorsIndex, tableId) | ||
return tableData and processNestedSelectors(tableData.children or {}) or 'Таблица не найдена.' | |||
end | end | ||
-- Формирование списка содержащихся предметов | -- Формирование списка содержащихся предметов | ||
getContainedOutput = function( | getContainedOutput = function(dataIndex, id) | ||
local item = findDataById( | local item = findDataById(dataIndex, id) | ||
if not item then return '' end | if not item then return '' end | ||
return item.StorageFill and getContentsOutput(item.StorageFill.contents) or '' | |||
end | end | ||
-- Обработка AllSelector | -- Обработка AllSelector | ||
handleAllSelector = function(allSelector) | handleAllSelector = function(allSelector) | ||
return allSelector.children and processNestedSelectors(allSelector.children) or '' | |||
end | end | ||
| Строка 175: | Строка 99: | ||
if not groupSelector.children then return '' end | if not groupSelector.children then return '' end | ||
local result = {} | local result = {} | ||
for _, child in ipairs(groupSelector.children) do | for _, child in ipairs(groupSelector.children) do | ||
result[#result + 1] = child.id and formatContent(child) or "" | |||
end | end | ||
return table.concat(result) | |||
return | |||
end | end | ||
-- Обработка NestedSelector | -- Обработка NestedSelector | ||
handleNestedSelector = function(nestedSelector, wrapped) | handleNestedSelector = function(nestedSelector, wrapped) | ||
return nestedSelector.tableId and getTableOutput(nestedSelector.tableId) or '' | |||
end | end | ||
-- Формирование списка химии | -- Формирование списка химии | ||
getChemOutput = function( | getChemOutput = function(dataIndex, id) | ||
local item = findDataById( | local item = findDataById(dataIndex, id) | ||
if not item or not item.SolutionContainerManager or not item.SolutionContainerManager.solutions then return '' end | if not item or not item.SolutionContainerManager or not item.SolutionContainerManager.solutions then return '' end | ||
local result = {} | local result = {} | ||
for _, solution in pairs(item.SolutionContainerManager.solutions) do | for _, solution in pairs(item.SolutionContainerManager.solutions) do | ||
| Строка 246: | Строка 125: | ||
-- Основная функция модуля | -- Основная функция модуля | ||
function p.main(frame) | function p.main(frame) | ||
local mode = frame.args[1] | local mode, id = frame.args[1], frame.args[2] | ||
if not id then return 'Не указан ID.' end | if not id then return 'Не указан ID.' end | ||
local data = loadData('User:IanComradeBot/prototypes/fills/Item.json') | local data, dataIndex = loadData('User:IanComradeBot/prototypes/fills/Item.json') | ||
if not data then return 'Не удалось загрузить данные.' end | if not data then return 'Не удалось загрузить данные.' end | ||
if mode == 'framing' then | if mode == 'framing' then | ||
local subMode = frame.args[2] | local subMode, subId = frame.args[2], frame.args[3] | ||
if not subId then return 'Не указан ID для режима framing.' end | |||
return frame:preprocess(subMode == 'chem' and ('{{СollapsibleMenu|' .. getChemOutput(dataIndex, subId) .. '}}') | |||
if not | or subMode == 'contained' and ('{{СollapsibleMenu|' .. getContainedOutput(dataIndex, subId) .. '}}') | ||
or 'Неизвестный подрежим для framing: ' .. subMode) | |||
elseif mode == 'chem' then | elseif mode == 'chem' then | ||
return frame:preprocess(getChemOutput(dataIndex, id)) | return frame:preprocess(getChemOutput(dataIndex, id)) | ||
| Строка 277: | Строка 143: | ||
elseif mode == 'rolls' then | elseif mode == 'rolls' then | ||
local entity = findDataById(dataIndex, id) | local entity = findDataById(dataIndex, id) | ||
return entity and entity.EntityTableContainerFill and entity.EntityTableContainerFill.containers | |||
and entity.EntityTableContainerFill.containers.entity_storage and entity.EntityTableContainerFill.containers.entity_storage.rolls | |||
and processRolls(entity.EntityTableContainerFill.containers.entity_storage.rolls) or 'Режим rolls не найден для этого ID.' | |||
end | end | ||
return 'Неизвестный режим: ' .. mode | |||
end | end | ||
return p | return p | ||