Module:GetRecipes: Difference between revisions
From Eco - English Wiki
[unchecked revision] | [unchecked revision] |
No edit summary |
No edit summary |
||
Line 56: | Line 56: | ||
--TEST CODE to access nested variants | --TEST CODE to access nested variants | ||
for k, v in pairs(recipes[1].variants) do --AS IT IS A FOR LOOP, WILL ALWAYS SET FINAL VALUE WHICH IS ALSO DEFAULT VARIANT | --for k, v in pairs(recipes[1].variants) do --AS IT IS A FOR LOOP, WILL ALWAYS SET FINAL VALUE WHICH IS ALSO DEFAULT VARIANT | ||
s = v.ingredients[1][2] | --s = v.ingredients[1][2] | ||
local ingredients = v.ingredients | --local ingredients = v.ingredients | ||
local products = v.products --THIS MAY PRODUCE ODD RESULTS, NEED TO CHECK | --local products = v.products --THIS MAY PRODUCE ODD RESULTS, NEED TO CHECK | ||
end | --end | ||
return "=== CODE WORKS === " .. s | --return "=== CODE WORKS === " .. s | ||
--return parser.formattedItem( recipes, item ) | --return parser.formattedItem( recipes, item ) | ||
Revision as of 13:01, 19 August 2020
Documentation
This module is called by Template:GetRecipes, and is the entry point for modules in the system that displays crafting recipes. It takes the item passed to the template, and uses Module:RecipeData to get every recipe related to the item. The resulting list of recipes is then passed to Module:CraftingParser, and the results from CraftingParser are returned to the template.
If the template is passed, this module creates a table using details from the following Modules:
local p = {}
-- Grabs args from the parent frame
-- Trims and parses the args into a table, then returns the table
function norm()
local origArgs = mw.getCurrentFrame():getParent().args
local args = {}
for k, v in pairs( origArgs ) do
v = mw.text.trim( tostring( v ) )
if v ~= '' then
args[k] = v
end
end
return args
end
-- Main entry point for the Module
function p.main()
-- get args from the Template
local args = norm()
-- assign variables for item, table, and group
local item = args.item
local table = args.table
local group = args.group
-- load list of recipes
local completeList = require( "Module:TestCraftingRecipes" )
local recipeList = completeList.recipes
local itemList = completeList.items
local tableList = completeList.tables
-- groups no longer exists. Need to check all dependencies on this throughout other modules. Expecting implication to be removal of 'used in' table in the wiki.
--local groupList = completeList.groups
-- initialize a table to store recipes
local recipes = {}
-- load CraftingParser
local parser = require( "Module:TestCraftingParser" )
-- priority: item > table > group
if item ~= nil then
if itemList[item] == nil then
return '===Crafting Recipes===\n\'\'None\'\'\n===Used in Recipes (potentially deprecated due to removal of groups - clean this up)===\n\'\'None\'\'\n'
end
for num = 1, #itemList[item] do
recipes[num] = recipeList[itemList[item][num]]
end
--TEST CODE to access nested variants
--for k, v in pairs(recipes[1].variants) do --AS IT IS A FOR LOOP, WILL ALWAYS SET FINAL VALUE WHICH IS ALSO DEFAULT VARIANT
--s = v.ingredients[1][2]
--local ingredients = v.ingredients
--local products = v.products --THIS MAY PRODUCE ODD RESULTS, NEED TO CHECK
--end
--return "=== CODE WORKS === " .. s
--return parser.formattedItem( recipes, item )
elseif table ~= nil then
--GROUP deprecated
--if group ~= nil then
--local count = 1
--for num = 1, #tableList[table] do
--for gnum = 1, #groupList[group] do
--if tableList[table][num] == groupList[group][gnum] then
--recipes[count] = recipeList[tableList[table][num]]
--count = count + 1
--end
--end
--end
--else
for num = 1, #tableList[table] do
recipes[num] = recipeList[tableList[table][num]]
end
--end
return parser.formattedTable( recipes, table )
--GROUP deprecated
--elseif group ~= nil then
--for num = 1, #groupList[group] do
--recipes[num] = recipeList[groupList[group][num]]
--end
--return parser.formattedGroup( recipes, group )
else
return 'Invalid use of parameters, please see [[Template:TestGetRecipes]].'
end
end
return p