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

Материал из Space Station 14 Вики
мНет описания правки
мНет описания правки
Метка: ручная отмена
Строка 1: Строка 1:
local p = {}
local p = {}
-- Глобальная переменная для данных
local data
-- Хранилище для кэша перевода
local boardToMachineCache = {}


-- Функция для перевода ID плат в ID машин
-- Функция для перевода ID плат в ID машин
local function translateBoardIDToMachineID(boardID)
local function translateBoardIDToMachineID(boardID)
-- Проверяем кэш
-- Загрузка данных из JSON
if boardToMachineCache[boardID] ~= nil then
local data = mw.text.jsonDecode(mw.title.new("Участник:IanComradeBot/entity_prototypes.json"):getContent())
return boardToMachineCache[boardID]
end
 
-- Если данные еще не загружены, загружаем их
if not data then
data = mw.text.jsonDecode(mw.title.new("Участник:IanComradeBot/entity_prototypes.json"):getContent())
end


-- Поиск платы по ID и извлечение её названия
-- Поиск платы по ID и извлечение её названия
Строка 26: Строка 13:


-- Проверка наличия "(машинная плата)" или "(консольная плата)" в имени
-- Проверка наличия "(машинная плата)" или "(консольная плата)" в имени
if not (board.name:find("%(машинная плата%)") or board.name:find("%(консольная плата%)")) then
if not board.name:find("%(машинная плата%)") and not board.name:find("%(консольная плата%)") then
return nil -- Если в имени нет одной из фраз, возвращаем nil
return nil -- Если в имени нет одной из фраз, возвращаем nil
end
end


-- Удаление "(машинная плата)" и "(консольная плата)" из имени платы
-- Удаление "(машинная плата)" и "(консольная плата)" из имени платы
local machineName = board.name:gsub(" %(машинная плата%)", ""):gsub(" %(консольная плата%)", ""):trim()
local machineName = board.name:gsub(" %(машинная плата%)", ""):gsub(" %(консольная плата%)", "")


-- Список исключений
-- Список исключений
local excludeWords = {"Unanchored", "Debug", "Admin"}
local excludeWords = {"Unanchored", "Debug", "Admin", "Enabled"}


-- Оптимизация: создаем таблицу для быстрого поиска по имени
-- Поиск машины по новому названию
local machineID = nil
for _, entity in pairs(data) do
for _, entity in pairs(data) do
if entity.name == machineName then
if entity.name == machineName then
Строка 50: Строка 36:
if not shouldExclude then
if not shouldExclude then
machineID = entity.id -- Сохраняем ID машины
return entity.id -- Возвращаем ID машины
break
end
end
end
end
end
end


-- Кэшируем результат (nil, если не найдено)
return nil -- Если машина не найдена, возвращаем nil
boardToMachineCache[boardID] = machineID
return machineID -- Возвращаем ID машины или nil
end
end


Строка 71: Строка 54:
local customRecipeUnlocks = frame.args.customRecipeUnlocks or nil -- Ручной ввод в список разблокируемых технологий
local customRecipeUnlocks = frame.args.customRecipeUnlocks or nil -- Ручной ввод в список разблокируемых технологий


-- Загрузка данных из JSON один раз
-- Загрузка данных из JSON
if not data then
local data = mw.text.jsonDecode(mw.title.new("User:IanComradeBot/research_prototypes.json"):getContent())
data = mw.text.jsonDecode(mw.title.new("User:IanComradeBot/research_prototypes.json"):getContent())
end


local out = cssLink
local out = cssLink

Версия от 10:39, 9 октября 2024

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

local p = {}

-- Функция для перевода ID плат в ID машин
local function translateBoardIDToMachineID(boardID)
	-- Загрузка данных из JSON
	local data = mw.text.jsonDecode(mw.title.new("Участник:IanComradeBot/entity_prototypes.json"):getContent())

	-- Поиск платы по ID и извлечение её названия
	local board = data[boardID]
	if not board or not board.name then
		return nil -- Если платы нет в данных, возвращаем nil
	end

	-- Проверка наличия "(машинная плата)" или "(консольная плата)" в имени
	if not board.name:find("%(машинная плата%)") and not board.name:find("%(консольная плата%)") then
		return nil -- Если в имени нет одной из фраз, возвращаем 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
			-- Проверка на наличие исключений в ID
			local shouldExclude = false
			for _, word in ipairs(excludeWords) do
				if entity.id:find(word) then
					shouldExclude = true
					break
				end
			end
			
			if not shouldExclude then
				return entity.id -- Возвращаем ID машины
			end
		end
	end

	return nil -- Если машина не найдена, возвращаем nil
end

function p.main(frame)
	-- Подключение CSS файла
	local cssLink = frame:extensionTag('templatestyles', '', {
		src = 'Шаблон:Research/styles.css'
	})

	local id = frame.args.id or "" -- ID исследования
	local icon = frame.args.icon or "" -- Изобрадения исследования
	local customRecipeUnlocks = frame.args.customRecipeUnlocks or nil -- Ручной ввод в список разблокируемых технологий

	-- Загрузка данных из JSON
	local data = mw.text.jsonDecode(mw.title.new("User:IanComradeBot/research_prototypes.json"):getContent())

	local out = cssLink
	local found = false  -- Флаг для отслеживания наличия элементов
	local disciplineName = "" 

	-- Определяем дисциплину на основе переданного id
	for discipline, technologies in pairs(data) do
		for _, tech in ipairs(technologies) do
			if tech.id == id then
				found = true
				disciplineName = ({
					Arsenal = "Арсенал",
					Industrial = "Промышленность",
					Experimental = "Экспериментальное",
					CivilianServices = "Обслуживание персонала"
				})[discipline]

				-- Цвета для номеров уровней
				local tierColor = ({
					[1] = "#54d554",  -- зеленый
					[2] = "#ed9000",  -- оранжевый
					[3] = "#d72a2a"   -- красный
				})[tech.tier]

				-- Формирование HTML
				out = out .. '<div class="research" id="' .. discipline .. '">'
				out = out .. '<div class="research__images">[[Файл:' .. icon .. '.png|64x64px|центр|link=]]</div>' -- Используем переданный icon
				out = out .. '<div class="research__name">' .. tech.name .. '[[Файл:' .. 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 recipeUnlocks
				if customRecipeUnlocks then
					recipeUnlocks = mw.text.split(customRecipeUnlocks, " ") -- Разбиваем по пробелам
				else
					recipeUnlocks = tech.recipeUnlocks
				end

				-- Проверка каждого ID в 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>'
			end
		end
	end

	if not found then
		out = out .. '<div style="color:red;">Нет доступных исследований.</div>'
	end

	return out
end

return p