Module:ForagerList: Difference between revisions

m (miscalculating fish per hour from duration and respawn)
(move from calculating actions per hour to specifying actions per hour, so people can import values from strategy guides)
 
(3 intermediate revisions by 2 users not shown)
Line 3: Line 3:
local lang = mw.getContentLanguage()
local lang = mw.getContentLanguage()
local plist = require('Module:ProfessionList')
local plist = require('Module:ProfessionList')
local rts = require('Module:RecipeTreeSearch')
local purge = require('Module:Purge')._purge


local p = {}
local p = {}


-- non dynamic module, no inputs
-- non dynamic module, no inputscleanup required modules
function p.main()
function p.main()
Line 40: Line 40:
-- downtime is very important for gathering-type professions
-- downtime is very important for gathering-type professions
-- initial values, it will be obvious if these get used
-- initial values, it will be obvious if these get used
item.downtime = 10000
item.productPerHour = 1
item.nodes = 1
item.productPerHourDropping = 1
-- these numbers are based roughly on how far the nodes are from a storage rift or shop or bank
-- these numbers are from the strategy guides for each node
-- 20s per room to traverse
-- duration and relocation times arent used for fisher, only respawn time and number of nodes
if string.find(item.pageName,'Kelp') then
if string.find(item.pageName,'Kelp') then
item.downtime = 20
item.productPerHour = 313
item.nodes = 6
item.productPerHourDropping = 337
elseif string.find(item.pageName,'Wallplant') then
elseif string.find(item.pageName,'Wallplant') then
item.downtime = 40
item.productPerHour = 366
item.nodes = 6
item.productPerHourDropping = 440
elseif string.find(item.pageName,'Periwinkle') then
elseif string.find(item.pageName,'Periwinkle') then
item.downtime = 40
item.productPerHour = 366
item.nodes = 6
item.productPerHourDropping = 440
elseif string.find(item.pageName,'Shell') then
elseif string.find(item.pageName,'Shell') then
item.downtime = 20
item.productPerHour = 313
item.nodes = 6
item.productPerHourDropping = 337
elseif string.find(item.pageName,'Potato') then
elseif string.find(item.pageName,'Potato') then
item.downtime = 80
item.productPerHour = 273
item.nodes = 6
item.productPerHourDropping = 337
elseif string.find(item.pageName,'Pond Weed') then
elseif string.find(item.pageName,'Pond Weed') then
item.downtime = 40
item.productPerHour = 366
item.nodes = 6
item.productPerHourDropping = 440
elseif string.find(item.pageName,'Bellplant') then
elseif string.find(item.pageName,'Bellplant') then
item.downtime = 40
item.productPerHour = 291
item.nodes = 6
item.productPerHourDropping = 337
elseif string.find(item.pageName,'Monument Piece') then
elseif string.find(item.pageName,'Monument Piece') then
item.downtime = 20
item.productPerHour = 407
item.nodes = 8
item.productPerHourDropping = 450
elseif string.find(item.pageName,'Water Lily') then
elseif string.find(item.pageName,'Water Lily') then
item.downtime = 40
item.productPerHour = 288
item.nodes = 6
item.productPerHourDropping = 337
elseif string.find(item.pageName,'Starfish') then
elseif string.find(item.pageName,'Starfish') then
item.downtime = 60
item.productPerHour = 273
item.nodes = 6
item.productPerHourDropping = 337
elseif string.find(item.pageName,'Hogberries') then
elseif string.find(item.pageName,'Hogberries') then
item.downtime = 80
item.productPerHour = 257
item.nodes = 6
item.productPerHourDropping = 337
elseif string.find(item.pageName,'Limpet') then
elseif string.find(item.pageName,'Limpet') then
item.downtime = 100
item.productPerHour = 242
item.nodes = 6
item.productPerHourDropping = 337
elseif string.find(item.pageName,'Nettle') then
elseif string.find(item.pageName,'Nettle') then
item.downtime = 20
item.productPerHour = 313
item.nodes = 6
item.productPerHourDropping = 337
elseif string.find(item.pageName,'Wrack') then
elseif string.find(item.pageName,'Wrack') then
item.downtime = 80
item.productPerHour = 257
item.nodes = 6
item.productPerHourDropping = 337
end
end


-- profitability
-- profitability
item.profit = item.sellPrice
item.profit = item.sellPrice
-- products per hour
item.batch = 24
item.durationEffective = item.duration and item.respawn and (item.duration + item.respawn) / item.nodes
item.productPerHour = item.durationEffective and math.floor(1 / (item.durationEffective + item.downtime / item.batch) * 3600)
item.productPerHourDropping = item.durationEffective and 1 / (item.durationEffective) * 3600


-- properties per hour
-- properties per hour
Line 118: Line 110:
local out = mw.html.create('table')
local out = mw.html.create('table')
:addClass('wikitable sortable')
:addClass('wikitable sortable')
:tag('caption')
:wikitext('This list is updated dynamically. '..purge())
:done()
:tag('tr')
:tag('tr')
:tag('th')
:tag('th')

Latest revision as of 19:31, 7 January 2025

Module documentation
This documentation is transcluded from Module:ForagerList/doc. [edit] [history] [purge]
This module does not have any documentation. Please consider adding documentation at Module:ForagerList/doc. [edit]
Module:ForagerList's function main is invoked by Template:ForagerList.
Module:ForagerList requires Module:Mw.html extension.
Module:ForagerList requires Module:ProfessionList.
Module:ForagerList requires Module:Purge.
Module:ForagerList requires strict.

require('strict')
require('Module:Mw.html extension')
local lang = mw.getContentLanguage()
local plist = require('Module:ProfessionList')
local purge = require('Module:Purge')._purge

local p = {}

-- non dynamic module, no inputscleanup required modules
function p.main()
	
	local queryString = '[[Category:Forager]] AND [[Category:Pages with activities]]'
	
	local function screenFunction(item)
		return not item.passive
	end
	
	local results = plist.generate_recipe_table(queryString,screenFunction)
	
	results = p.formatResults(results)

	return p.displayTable(results)
	
	--for debugging
	--return '<pre>'..mw.text.jsonEncode(results, mw.text.JSON_PRETTY)..'</pre>'

end

-- do calculations and determine strings to go in cells
function p.formatResults(results)
	
	--simple check for nil results
	if results==nil or results[1]==nil then
		return nil
	end
	
	-- iterate through products
	for _, item in ipairs(results) do

		-- downtime is very important for gathering-type professions
		-- initial values, it will be obvious if these get used
		item.productPerHour = 1 
		item.productPerHourDropping = 1
		-- these numbers are from the strategy guides for each node
		if string.find(item.pageName,'Kelp') then
			item.productPerHour = 313
			item.productPerHourDropping = 337
		elseif string.find(item.pageName,'Wallplant') then
			item.productPerHour = 366
			item.productPerHourDropping = 440
		elseif string.find(item.pageName,'Periwinkle') then
			item.productPerHour = 366
			item.productPerHourDropping = 440
		elseif string.find(item.pageName,'Shell') then
			item.productPerHour = 313
			item.productPerHourDropping = 337
		elseif string.find(item.pageName,'Potato') then
			item.productPerHour = 273
			item.productPerHourDropping = 337
		elseif string.find(item.pageName,'Pond Weed') then
			item.productPerHour = 366
			item.productPerHourDropping = 440
		elseif string.find(item.pageName,'Bellplant') then
			item.productPerHour = 291
			item.productPerHourDropping = 337
		elseif string.find(item.pageName,'Monument Piece') then
			item.productPerHour = 407
			item.productPerHourDropping = 450
		elseif string.find(item.pageName,'Water Lily') then
			item.productPerHour = 288
			item.productPerHourDropping = 337
		elseif string.find(item.pageName,'Starfish') then
			item.productPerHour = 273
			item.productPerHourDropping = 337
		elseif string.find(item.pageName,'Hogberries') then
			item.productPerHour = 257
			item.productPerHourDropping = 337
		elseif string.find(item.pageName,'Limpet') then
			item.productPerHour = 242
			item.productPerHourDropping = 337
		elseif string.find(item.pageName,'Nettle') then
			item.productPerHour = 313
			item.productPerHourDropping = 337
		elseif string.find(item.pageName,'Wrack') then
			item.productPerHour = 257
			item.productPerHourDropping = 337
		end 

		-- profitability
		item.profit = item.sellPrice

		-- properties per hour
		item.xpPerHour = item.xp and item.productPerHour and math.floor(item.xp * item.productPerHour)
		item.xpPerHourDropping = item.xp and item.productPerHourDropping and math.floor(item.xp * item.productPerHourDropping)
		item.profitPerHour = item.profit and item.productPerHour and math.floor(item.profit * item.productPerHour)
			
	end

	return results
end

-- make the table
function p.displayTable(results)
	
	--simple check for nil results
	if results ==nil or results[1] == nil then
		return 'No data found for table'
	end
	
	local out = mw.html.create('table')
		:addClass('wikitable sortable')
		:tag('caption')
			:wikitext('This list is updated dynamically. '..purge())
		:done()
		:tag('tr')
			:tag('th')
				:wikitext('[[File:Forager small icon.png|15px]]  Level')
			:done()
			:tag('th')
				:attr{ colspan = '2' }
				:wikitext('Node')
			:done()
			:tag('th')
				:attr{ colspan = '2' }
				:wikitext('Tool')
			:done()
			:tag('th')
				:attr{ colspan = '2' }
				:wikitext('Resource')
			:done()
			:tag('th')
				:wikitext('Resource/hr')
			:done()
			:tag('th')
				:attr{ colspan = '10' }
				:wikitext('Profit')
			:done()
			:tag('th')
				:attr{ colspan = '10' }
				:wikitext('Profit/hr')
			:done()
			:tag('th')
				:wikitext('XP')
			:done()
			:tag('th')
				:wikitext('XP/hr')
			:done()
			:tag('th')
				:wikitext('XP/hr<br>(Discarding)')
			:done()
		:done()

	for i, item in ipairs(results) do
		local row = out:tag('tr')
		
			--level
			:IF(item.level)
				:tag('td')
					:css{ ['text-align'] = 'center' }
					:wikitext(item.level)
				:done()
			:ELSE()
				:node(plist.unknown_value_edit_cell(item.pageName,1))
			:END()
			
			-- gathering node
			:node(plist.two_column_image_text(item.pageName,item.pageImage,item.pageName,item.pageName))
			
			:IF(item.tool)
				:node(plist.two_column_image_text(item.tool,'File:'..(item.tool or '')..' (grade 1).png',(item.tool or ''),(item.tool or '')))
			:ELSE()
				:tag('td')
					:addClass('table-na')
					:attr{ colspan = '2' }
					:wikitext('N/A')
				:done()
			:END()
			
			-- resource
			:IF(item.coop)
				:node(plist.two_column_image_text(item.product,'File:' .. item.product .. '.png',item.product .. ' (co-op)',item.product))
			:ELSE()
				:node(plist.two_column_image_text(item.product,'File:' .. item.product .. '.png',item.product,item.product))
			:END()
			
			-- resource/hr
			:IF(item.productPerHour)
				:tag('td')
					:wikitext(item.productPerHour and math.floor(tonumber(item.productPerHour)*10)/10)
				:done()
			:ELSE()
				:node(plist.unknown_value_edit_cell(item.pageName,1))
			:END()
		
			-- economics
			:node(plist.currency_cell(item.profit))
			:node(plist.currency_cell(item.profitPerHour))

			-- XP
			:IF(item.xp)
				:tag('td')
					:wikitext(item.xp and lang:formatNum(tonumber(item.xp)))
				:done()
			:ELSE()
				:node(plist.unknown_value_edit_cell(item.pageName,1))
			:END()
			
			-- XP per hour
			:IF(item.xpPerHour)
				:tag('td')
					:wikitext(item.xpPerHour and lang:formatNum(tonumber(item.xpPerHour)))
				:done()
			:ELSE()
				:node(plist.unknown_value_cell(1))
			:END()
			
			-- XP per hour
			:IF(item.xpPerHourDropping)
				:tag('td')
					:wikitext(item.xpPerHourDropping and lang:formatNum(tonumber(item.xpPerHourDropping)))
				:done()
			:ELSE()
				:node(plist.unknown_value_cell(1))
			:END()

		:done()
	end

	return out
end

return p