Модуль:Prototypes/Хранилище/Предмет: различия между версиями
Pok (обсуждение | вклад) мНет описания правки Метка: ручная отмена |
Pok (обсуждение | вклад) Нет описания правки |
||
| Строка 9: | Строка 9: | ||
-- Функция для загрузки данных с кэшированием | -- Функция для загрузки данных с кэшированием | ||
loadData = function(filePath) | loadData = function(filePath) | ||
if dataCache[filePath] then | if not dataCache[filePath] then | ||
local page = mw.title.new(filePath) | |||
local content = page:getContent() | |||
dataCache[filePath] = content and mw.text.jsonDecode(content) or nil | |||
end | end | ||
return dataCache[filePath] | |||
end | end | ||
-- Создание хэш-таблицы для быстрого поиска по ID | -- Создание хэш-таблицы для быстрого поиска по ID | ||
local function buildIndex(data) | local function buildIndex(data) | ||
if not data then return {} end | |||
local index = {} | local index = {} | ||
for _, item in ipairs(data) do | |||
index[item.id] = item | |||
end | end | ||
return index | return index | ||
| Строка 51: | Строка 48: | ||
if content.prob then | if content.prob then | ||
prob = string.format(" <div>%s%%</div>", content.prob * 100 >= 1 and math.floor(content.prob * 100) or content.prob * 100) | |||
prob = string.format(" <div>%s%%</div>", | |||
end | end | ||
| Строка 65: | Строка 61: | ||
local result = {} | local result = {} | ||
for _, content in ipairs(contents) do | for _, content in ipairs(contents) do | ||
result[#result + 1] = formatContent(content) | |||
end | end | ||
return table.concat(result) | return table.concat(result) | ||
| Строка 75: | Строка 71: | ||
for _, child in ipairs(children) do | for _, child in ipairs(children) do | ||
if child.id then | if child.id then | ||
result[#result + 1] = formatContent(child) | |||
elseif child["!type"] == "NestedSelector" and child.tableId then | elseif child["!type"] == "NestedSelector" and child.tableId then | ||
result[#result + 1] = handleNestedSelector(child, true) | |||
elseif child["!type"] == "GroupSelector" then | elseif child["!type"] == "GroupSelector" then | ||
result[#result + 1] = handleGroupSelector(child) | |||
end | end | ||
end | end | ||
| Строка 92: | Строка 88: | ||
if not tableData then return 'Таблица не найдена.' end | if not tableData then return 'Таблица не найдена.' end | ||
if tableData['!type:GroupSelector'] | if tableData['!type:GroupSelector'] then | ||
return handleGroupSelector(tableData['!type:GroupSelector']) | return handleGroupSelector(tableData['!type:GroupSelector']) | ||
elseif tableData['!type:AllSelector'] | elseif tableData['!type:AllSelector'] then | ||
return processNestedSelectors(tableData['!type:AllSelector'].children) | return processNestedSelectors(tableData['!type:AllSelector'].children) | ||
end | end | ||
return 'Таблица не содержит элементов.' | |||
end | end | ||
-- Формирование списка содержащихся предметов или таблиц | -- Формирование списка содержащихся предметов или таблиц | ||
getContainedOutput = function(data, id | getContainedOutput = function(data, id) | ||
local item = findDataById(data, id) | local item = findDataById(data, id) | ||
if not item then return '' end | if not item then return '' end | ||
local result = | local result = {} | ||
-- Обработка StorageFill | -- Обработка StorageFill | ||
if item.StorageFill and item.StorageFill.contents then | if item.StorageFill and item.StorageFill.contents then | ||
result = | result[#result + 1] = getContentsOutput(item.StorageFill.contents) | ||
-- Обработка EntityTableContainerFill | -- Обработка EntityTableContainerFill | ||
elseif item.EntityTableContainerFill and item.EntityTableContainerFill.containers then | elseif item.EntityTableContainerFill and item.EntityTableContainerFill.containers then | ||
local containers = item.EntityTableContainerFill.containers | local containers = item.EntityTableContainerFill.containers | ||
-- Обработка entity_storage | -- Обработка entity_storage | ||
if containers.entity_storage then | if containers.entity_storage then | ||
if containers.entity_storage.children then | |||
result[#result + 1] = processNestedSelectors(containers.entity_storage.children) | |||
end | end | ||
if containers.entity_storage.tableId then | if containers.entity_storage.tableId then | ||
result = | result[#result + 1] = getTableOutput(containers.entity_storage.tableId) | ||
end | end | ||
end | end | ||
-- Обработка storagebase | -- Обработка storagebase | ||
if containers.storagebase and containers.storagebase.tableId then | if containers.storagebase and containers.storagebase.tableId then | ||
result = | result[#result + 1] = getTableOutput(containers.storagebase.tableId) | ||
end | end | ||
end | end | ||
return result | return table.concat(result) | ||
end | end | ||
-- Обработка AllSelector | -- Обработка AllSelector | ||
handleAllSelector = function(allSelector) | handleAllSelector = function(allSelector) | ||
if not allSelector.children then return '' end | |||
if not allSelector.children then return | return processNestedSelectors(allSelector.children) | ||
end | end | ||
-- Обработка GroupSelector | -- Обработка GroupSelector | ||
handleGroupSelector = function(groupSelector) | handleGroupSelector = function(groupSelector) | ||
local result = | if not groupSelector.children then return '' end | ||
local result = {} | |||
local wrapperStart, wrapperEnd = "", "" | |||
if | |||
if groupSelector.weight and groupSelector.weight ~= "default" then | |||
wrapperStart = string.format('<div class="together" id="%s">', groupSelector.weight) | |||
wrapperEnd = "</div>" | |||
end | end | ||
for _, child in ipairs(groupSelector.children) do | |||
if child["!type"] == "GroupSelector" then | |||
result[#result + 1] = handleGroupSelector(child) | |||
elseif child["!type"] == "AllSelector" then | |||
result[#result + 1] = string.format('<div class="AllSelector">%s</div>', handleAllSelector(child)) | |||
elseif child.id then | |||
result[#result + 1] = formatContent(child) | |||
else | |||
result[#result + 1] = "<div>Ошибка: отсутствует id у элемента.</div>" | |||
end | end | ||
end | end | ||
return result | return wrapperStart .. table.concat(result) .. wrapperEnd | ||
end | end | ||
-- Обработка NestedSelector | -- Обработка NestedSelector | ||
handleNestedSelector = function(nestedSelector, wrapped) | handleNestedSelector = function(nestedSelector, wrapped) | ||
if not nestedSelector.tableId then return '' end | |||
local result = {} | |||
if wrapped then | if wrapped then | ||
local classes = {} | local classes = {} | ||
if nestedSelector.rolls and nestedSelector.rolls.range then | if nestedSelector.rolls and nestedSelector.rolls.range then | ||
classes[#classes + 1] = 'rolls-' .. tostring(nestedSelector.rolls.range):gsub(',', '-') | |||
end | end | ||
if nestedSelector.prob then | if nestedSelector.prob then | ||
classes[#classes + 1] = 'prob-' .. tostring(math.floor(nestedSelector.prob * 100)) .. 'p' | |||
end | end | ||
result[#result + 1] = string.format('<div class="%s">', table.concat(classes, ' ')) | |||
result = | |||
end | end | ||
return result | result[#result + 1] = getTableOutput(nestedSelector.tableId) | ||
if wrapped then | |||
result[#result + 1] = "</div>" | |||
end | |||
return table.concat(result) | |||
end | end | ||
-- Формирование списка химии | -- Формирование списка химии | ||
getChemOutput = function(data, id) | getChemOutput = function(data, id) | ||
local item = findDataById(data, id) | local item = findDataById(data, id) | ||
if not item | if not item or not item.SolutionContainerManager or not item.SolutionContainerManager.solutions then return '' end | ||
local result = {} | |||
for _, solution in pairs(item.SolutionContainerManager.solutions) do | |||
local result = | |||
for _, solution in pairs(solutions) do | |||
for _, reagent in ipairs(solution.reagents) do | for _, reagent in ipairs(solution.reagents) do | ||
result = | result[#result + 1] = string.format('<li>[[Химия#chem_%s|%s]] (%d ед.)</li>', reagent.ReagentId, reagent.ReagentId, reagent.Quantity) | ||
end | end | ||
end | end | ||
return result | return string.format('<ul class="1">%s</ul>', table.concat(result)) | ||
end | end | ||
| Строка 308: | Строка 228: | ||
return frame:preprocess('{{СollapsibleMenu|' .. getChemOutput(dataIndex, id) .. '}}') | return frame:preprocess('{{СollapsibleMenu|' .. getChemOutput(dataIndex, id) .. '}}') | ||
elseif subMode == 'contained' then | elseif subMode == 'contained' then | ||
return frame:preprocess('{{СollapsibleMenu|' .. getContainedOutput(dataIndex, id | return frame:preprocess('{{СollapsibleMenu|' .. getContainedOutput(dataIndex, id) .. '}}') | ||
else | else | ||
return 'Неизвестный подрежим для framing: ' .. subMode | return 'Неизвестный подрежим для framing: ' .. subMode | ||
end | end | ||
elseif mode == 'chem' then | |||
return frame:preprocess(getChemOutput(dataIndex, id)) | return frame:preprocess(getChemOutput(dataIndex, id)) | ||
elseif mode == 'contained' then | elseif mode == 'contained' then | ||
return frame:preprocess(getContainedOutput(dataIndex, id | return frame:preprocess(getContainedOutput(dataIndex, id)) | ||
end | |||
return 'Неизвестный режим: ' .. mode | |||
end | end | ||
return p | return p | ||