Module:FisherPassiveList: Difference between revisions
Jump to navigation
Jump to search
Content added Content deleted
(offload much of the search, screen, and format functions to the new ProfessionList module, so they work the same for all table.) |
m (cleanup required modules) |
||
Line 3:
local lang = mw.getContentLanguage()
local plist = require('Module:ProfessionList')
local p = {}
|
Revision as of 14:20, 27 December 2024
Module documentation
This documentation is transcluded from Module:FisherPassiveList/doc. [edit] [history] [purge]
This module does not have any documentation. Please consider adding documentation at Module:FisherPassiveList/doc. [edit]
Module:FisherPassiveList's function main is invoked by Template:FisherPassiveList.
Module:FisherPassiveList requires Module:Mw.html extension.
Module:FisherPassiveList requires Module:ProfessionList.
Module:FisherPassiveList requires strict.
require('strict')
require('Module:Mw.html extension')
local lang = mw.getContentLanguage()
local plist = require('Module:ProfessionList')
local p = {}
-- non dynamic module, no inputs
function p.main()
local queryString = '[[Category:Fisher]] AND [[Category:Pages with activities]]'
local function screenFunction(item)
return 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
-- protection against missing parameters
item.product = item.product or ''
item.pageImage = item.pageImage or ''
item.bait = (item.materials and item.materials[1] and item.materials[1].name) or ''
-- profitability
item.profitPerXP = item.profit and item.xp and item.profit / item.xp
-- no downtime for passives
item.productPerHour = item.duration and 1 / item.duration * 3600
-- properties per hour
item.xpPerHour = item.xp and item.productPerHour and math.floor(item.xp * item.productPerHour)
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('tr')
:tag('th')
:wikitext('[[File:Fisher small icon.png|15px]] Level')
:done()
:tag('th')
:attr{ colspan = '2' }
:wikitext('Fishing node')
:done()
:tag('th')
:attr{ colspan = '3' }
:wikitext('Bait')
:done()
:tag('th')
:attr{ colspan = '10' }
:wikitext('Buy<br>Value')
:done()
:tag('th')
:attr{ colspan = '3' }
:wikitext('Fish')
:done()
:tag('th')
:attr{ colspan = '10' }
:wikitext('Sell<br>Value')
: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()
: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()
-- fishing node
:node(plist.two_column_image_text(item.pageName,item.pageImage,item.pageName,item.pageName))
-- bait
:node(plist.three_column_image_text(item.bait,item.materials[1].quantity,'File:' .. item.bait .. '.png',item.bait,item.bait))
-- profit per hour (coins)
:node(plist.currency_cell(item.buyPrice))
-- fish
:node(plist.three_column_image_text(item.product,item.output[1].quantity,'File:' .. item.product .. '.png',item.product,item.product))
-- economics
:node(plist.currency_cell(item.sellPrice))
: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()
:done()
end
return out
end
return p