Editing Module:ForagerList
Jump to navigation
Jump to search
The edit can be undone. Please check the comparison below to verify that this is what you want to do, and then publish the changes below to finish undoing the edit.
Latest revision | Your text | ||
Line 1: | Line 1: | ||
require('strict') |
require('strict') |
||
require('Module:Mw.html extension') |
require('Module:Mw.html extension') |
||
local param = require( 'Module:Paramtest' ) |
|||
local currency = require('Module:Currency') |
|||
local lang = mw.getContentLanguage() |
local lang = mw.getContentLanguage() |
||
local plist = require('Module:ProfessionList') |
|||
local purge = require('Module:Purge')._purge |
|||
local p = {} |
local p = {} |
||
-- non dynamic module, no |
-- non dynamic module, no inputs |
||
function p.main() |
function p.main() |
||
-- returns only directly needed parameter needed for the row, |
|||
local queryString = '[[Category:Forager]] AND [[Category:Pages with activities]]' |
|||
-- other parameters are determined by subqueries of chained pages |
|||
local |
local query = { |
||
'[[Variant of::Kelp (skill node)||Wallplant (skill node)||Periwinkle (skill node)||Shell (skill node)||Potato (skill node)||Pond Weed (skill node)||Bellplant (skill node)||Monument Piece (skill node)||Water Lily (skill node)||Starfish (skill node)||Hogberries (skill node)||Limpet (skill node)||Nettle (skill node)||Wrack (skill node)]]', |
|||
return not item.passive |
|||
'?Variant of #- = variant', |
|||
end |
|||
'?Profession Level A = lvl', |
|||
'? #- = name', |
|||
local results = plist.generate_recipe_table(queryString,screenFunction) |
|||
'?Image #- = Image', |
|||
'?Activity XP = XP', |
|||
'?Activity duration = duration', |
|||
'?Skill node name = product', |
|||
'?Activity input #- = material', |
|||
'sort = Profession Level A', |
|||
'limit = 500' |
|||
} |
|||
local results = mw.smw.ask(query) |
|||
results = p.formatResults(results) |
results = p.formatResults(results) |
||
Line 25: | Line 34: | ||
--return '<pre>'..mw.text.jsonEncode(results, mw.text.JSON_PRETTY)..'</pre>' |
--return '<pre>'..mw.text.jsonEncode(results, mw.text.JSON_PRETTY)..'</pre>' |
||
end |
|||
-- makes the html for the cells containing currency directly |
|||
-- Replaces nil with an "unknown" cell |
|||
local function currency_cell(amount) |
|||
if not amount then |
|||
return mw.html.create('td') |
|||
:addClass('table-bg-gray') |
|||
:css{ ['text-align'] = 'center' } |
|||
:attr{ colspan = '10' } |
|||
:wikitext("''unknown''") |
|||
:done() |
|||
end |
|||
return currency._cell(amount, { html = 'yes' }) |
|||
end |
end |
||
-- do calculations and determine strings to go in cells |
-- do calculations and determine strings to go in cells |
||
function p.formatResults(results) |
function p.formatResults(results) |
||
--simple check for nil results |
|||
if results==nil or results[1]==nil then |
|||
return nil |
|||
end |
|||
-- iterate through products |
-- iterate through products |
||
for _, item in ipairs(results) do |
for _, item in ipairs(results) do |
||
--catch badly submitted data |
|||
-- downtime is very important for gathering-type professions |
|||
item.material = item.material or '' |
|||
-- initial values, it will be obvious if these get used |
|||
item. |
item.product = item.product or '' |
||
item.productPerHourDropping = 1 |
|||
-- price of resource |
|||
-- these numbers are from the strategy guides for each node |
|||
-- query is: there is a shop object page that has this item AND has buy price cannot be "N/A" |
|||
if string.find(item.pageName,'Kelp') then |
|||
local query = mw.smw.ask('[[Sold item::' .. item.product .. ']][[Shop sell price::!~N/A]]|?Shop sell price=data|mainlabel=-') |
|||
item.productPerHour = 313 |
|||
if type(query)=='table' then |
|||
item.productPerHourDropping = 337 |
|||
-- price is returned as a number |
|||
elseif string.find(item.pageName,'Wallplant') then |
|||
item. |
item.profit = tonumber(query[1].data) or 0 |
||
else |
|||
item.productPerHourDropping = 440 |
|||
-- will return nil if the item is not in a shop, or if it is in a shop but can only be sold to the shop |
|||
elseif string.find(item.pageName,'Periwinkle') then |
|||
item. |
item.profit = nil |
||
end |
|||
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 |
-- profitability |
||
item. |
item.profitPerXP = item.profit and item.XP and item.profit / item.XP |
||
-- DOWNTIME VERY IMPORTANT FOR GATHERING TYPE PROFESSIONS |
|||
item.downtime = 60 -- THIS IS AN INITIAL GUESS, DO NOT USE THIS VALUE |
|||
item.batch = 24 |
|||
item.productPerHour = item.duration and 1 / (item.duration + item.downtime / item.batch) * 3600 |
|||
-- properties per hour |
-- properties per hour |
||
item. |
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) |
item.profitPerHour = item.profit and item.productPerHour and math.floor(item.profit * item.productPerHour) |
||
end |
end |
||
Line 102: | Line 89: | ||
-- make the table |
-- make the table |
||
function p.displayTable(results) |
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') |
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') |
||
Line 119: | Line 97: | ||
:tag('th') |
:tag('th') |
||
:attr{ colspan = '2' } |
:attr{ colspan = '2' } |
||
:wikitext(' |
:wikitext('Foraging node') |
||
:done() |
|||
:tag('th') |
|||
:attr{ colspan = '2' } |
|||
:wikitext('Tool') |
|||
:done() |
:done() |
||
:tag('th') |
:tag('th') |
||
Line 145: | Line 119: | ||
:tag('th') |
:tag('th') |
||
:wikitext('XP/hr') |
:wikitext('XP/hr') |
||
:done() |
|||
:tag('th') |
|||
:wikitext('XP/hr<br>(Discarding)') |
|||
:done() |
:done() |
||
:done() |
:done() |
||
local unknown_value_cell = mw.html.create('td') |
|||
:addClass('table-bg-gray') |
|||
:css{ ['text-align'] = 'center' } |
|||
:wikitext("''unknown''") |
|||
for i, item in ipairs(results) do |
for i, item in ipairs(results) do |
||
Line 155: | Line 131: | ||
--level |
--level |
||
:IF(item. |
:IF(item.lvl) |
||
:tag('td') |
:tag('td') |
||
:css{ ['text-align'] = 'center' } |
:css{ ['text-align'] = 'center' } |
||
:wikitext(item. |
:wikitext(item.lvl) |
||
:done() |
:done() |
||
:ELSE() |
:ELSE() |
||
:node(unknown_value_cell) |
|||
:node(plist.unknown_value_edit_cell(item.pageName,1)) |
|||
:END() |
:END() |
||
-- |
-- foraging node |
||
:tag('td') |
|||
:node(plist.two_column_image_text(item.pageName,item.pageImage,item.pageName,item.pageName)) |
|||
:css{ ['border-right'] = '0', ['text-align'] = 'right', ['max-width'] = '100px' } |
|||
: |
:attr{ ['data-sort-value'] = item.name } |
||
: |
:wikitext(' [[' .. item.Image .. '|link=' .. item.name .. '|30x30px]]') |
||
: |
:done() |
||
:tag('td') |
|||
:addClass('plinkt-link no-border') |
|||
:wikitext('[[' .. item.name .. '|' .. item.product ..']]') |
|||
:attr{ colspan = '2' } |
|||
:done() |
|||
:done() |
|||
:END() |
|||
-- resource |
-- resource |
||
: |
:tag('td') |
||
:css{ ['border-right'] = '0', ['text-align'] = 'right', ['max-width'] = '100px' } |
|||
:node(plist.two_column_image_text(item.product,'File:' .. item.product .. '.png',item.product .. ' (co-op)',item.product)) |
|||
:attr{ ['data-sort-value'] = item.product } |
|||
:ELSE() |
|||
: |
:wikitext('[[File:' .. item.product .. '.png|link=' .. item.product .. '|30x30px]]') |
||
: |
:done() |
||
:tag('td') |
|||
:addClass('plinkt-link no-border') |
|||
:wikitext('[[' .. item.product .. ']]') |
|||
:done() |
|||
-- resource/hr |
-- resource/hr |
||
Line 190: | Line 168: | ||
:done() |
:done() |
||
:ELSE() |
:ELSE() |
||
:node(unknown_value_cell) |
|||
:node(plist.unknown_value_edit_cell(item.pageName,1)) |
|||
:END() |
:END() |
||
-- economics |
-- economics |
||
:node( |
:node(currency_cell(item.profit)) |
||
:node( |
:node(currency_cell(item.profitPerHour)) |
||
-- XP |
-- XP |
||
:IF(item. |
: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') |
:tag('td') |
||
:wikitext(item. |
:wikitext(item.XP and lang:formatNum(tonumber(item.XP))) |
||
:done() |
:done() |
||
:ELSE() |
:ELSE() |
||
:node( |
:node(unknown_value_cell) |
||
:END() |
:END() |
||
-- XP per hour |
-- XP per hour |
||
:IF(item. |
:IF(item.XPPerHour) |
||
:tag('td') |
:tag('td') |
||
:wikitext(item. |
:wikitext(item.XPPerHour and lang:formatNum(tonumber(item.XPPerHour))) |
||
:done() |
:done() |
||
:ELSE() |
:ELSE() |
||
:node( |
:node(unknown_value_cell) |
||
:END() |
:END() |
||