Module:CarpenterList: Difference between revisions
offload much of the search, screen, and format functions to the new ProfessionList module, so they work the same for all table
m (ajust table headings) |
(offload much of the search, screen, and format functions to the new ProfessionList module, so they work the same for all table) |
||
Line 1:
require('strict')
require('Module:Mw.html extension')
local lang = mw.getContentLanguage()
local plist = require('Module:ProfessionList')
local rts = require('Module:RecipeTreeSearch')
local p = {}
Line 10 ⟶ 9:
-- non dynamic module, no inputs
function p.main()
local queryString = '[[Category:Carpenter]] AND [[Category:Pages with recipes]]'
local function screenFunction(item)
local product = (item.output and item.output[1] and item.output[1].name) or ''
return not (item.passive or string.find(product,'Post'))
end
local results = plist.generate_recipe_table(queryString,screenFunction)
results = p.formatResults(results)
Line 32 ⟶ 26:
--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
-- list of all pages to edit, if edit is needed
for _,intermediate in ipairs(item.intermediateMaterials) do
table.insert(item.allPageEdits,intermediate.name)
end
-- poles will show as making 1 and using 0.5 log, which doesnt match the look of planks or staves
-- double them,
if item.
item.
item.
item.
item.profit = item.profit and item.profit * 2
item.xp = item.xp and item.xp * 2
item.duration = item.duration and item.duration * 2
for j,jtem in ipairs(item.materials) do
jtem.quantity = jtem.quantity and jtem.quantity * 2
end
end
-- profitability
item.profitPerXP = item.profit and item.xp and item.profit / item.xp
-- 40 seconds to buy new supplies and travel and deposit and everything, per 12 potions
local batchSize = 12
local downtime = 60
Line 88 ⟶ 70:
-- properties per hour
item.
item.profitPerHour = item.profit and item.productPerHour and math.floor(item.profit * item.productPerHour)
end
Line 97 ⟶ 79:
-- 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')
Line 120 ⟶ 108:
:tag('th')
:attr{ colspan = '10' }
:wikitext('Profit
:done()
:tag('th')
Line 127 ⟶ 115:
:done()
:tag('th')
:wikitext('XP
:done()
:tag('th')
Line 137 ⟶ 125:
: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.
:done()
:ELSE()
:node(plist.unknown_value_edit_cell(item.pageName,1))
:END()
-- recipe
:node(plist.three_column_image_text(item.product,item.output[1].quantity,'File:' .. item.product .. '.png',item.product,item.product))
-- materials
:IF(item.type=='recipe')
:node(plist.one_column_image_text(item.materials))
:node(plist.currency_cell(item.buyPrice))
:node(plist.currency_cell(item.sellPrice))
:ELSE()
:tag('td')
:addClass('table-na')
:css{ ['text-align'] = 'center' }
:attr{ colspan = '21' }
:wikitext('N/A')
:done()
:END()
:node(plist.currency_cell(item.profit))
:node(plist.currency_cell(item.profitPerHour))
:IF(item.xp)
:tag('td')
:wikitext(item.
:done()
:ELSE()
:node(plist.unknown_value_edit_cell(item.allPageEdits,1))
:END()
-- XP per hour
:IF(item.xpPerHour)
:tag('td')
:wikitext(item.
:done()
:ELSE()
:node(plist.unknown_value_cell(1))
:END()
-- XP per hour
:node(plist.currency_cell(item.profitPerXP))
:done()
end
|