Editing Module:GathererList
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 lang = mw.getContentLanguage() |
local lang = mw.getContentLanguage() |
||
⚫ | |||
⚫ | |||
local p = {} |
local p = {} |
||
Line 10: | Line 10: | ||
function p.main() |
function p.main() |
||
-- returns only directly needed parameter needed for the row, |
|||
local queryString = '[[Category:Gatherer]] AND [[Category:Pages with activities]]' |
|||
-- other parameters are determined by subqueries of chained pages |
|||
⚫ | |||
local |
local query = { |
||
'[[Variant of::Globeplant (skill node)||Dandelion (skill node)||Goat Horn (skill node)||Apple (skill node)||Leek (skill node)||Haleberries (skill node)||Rams Horn (skill node)||Bitterfruit (skill node)||Chestnut (skill node)||Bone Spike (skill node)||Tangfruit (skill node)||Catkin (skill node)||Femur Shard (skill node)||Clover (skill node)||Snake Scale (skill node)||Orchid (skill node)||Dock Leaf (skill node)||Sage (skill node)||Thistle (skill node)]]', |
|||
return not item.passive |
|||
'?Variant of #- = variant', |
|||
⚫ | |||
'?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() |
|||
⚫ | |||
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 |
|||
⚫ | |||
-- iterate through products |
-- iterate through products |
||
Line 39: | Line 57: | ||
--catch badly submitted data |
--catch badly submitted data |
||
⚫ | |||
item.product = item.product or '' |
item.product = item.product or '' |
||
⚫ | |||
⚫ | |||
-- price of resource |
|||
-- query is: there is a shop object page that has this item AND has buy price cannot be "N/A" |
|||
local query = mw.smw.ask('[[Sold item::' .. item.product .. ']][[Shop sell price::!~N/A]]|?Shop sell price=data|mainlabel=-') |
|||
if type(query)=='table' then |
|||
-- price is returned as a number |
|||
item.profit = tonumber(query[1].data) or 0 |
|||
else |
|||
-- 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 |
|||
item.profit = nil |
|||
end |
|||
-- profitability |
-- profitability |
||
item. |
item.profitPerXP = item.profit and item.XP and item.profit / item.XP |
||
item.profitPerXP = item.profit and item.xp and item.profit / item.xp |
|||
-- DOWNTIME VERY IMPORTANT FOR GATHERING TYPE PROFESSIONS |
-- DOWNTIME VERY IMPORTANT FOR GATHERING TYPE PROFESSIONS |
||
Line 52: | Line 80: | ||
-- properties per hour |
-- properties per hour |
||
item. |
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) |
item.profitPerHour = item.profit and item.productPerHour and math.floor(item.profit * item.productPerHour) |
||
end |
end |
||
Line 61: | 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' |
|||
⚫ | |||
local out = mw.html.create('table') |
local out = mw.html.create('table') |
||
:addClass('wikitable sortable') |
:addClass('wikitable sortable') |
||
Line 99: | Line 121: | ||
: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 104: | 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() |
||
-- gathering node |
-- gathering 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' } |
|||
:addClass('plinkt-link no-border') |
|||
: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 ..']]') |
|||
:done() |
|||
-- resource |
-- resource |
||
:tag('td') |
|||
:node(plist.two_column_image_text(item.product,'File:' .. item.product .. '.png',item.product,item.product)) |
|||
:css{ ['border-right'] = '0', ['text-align'] = 'right', ['max-width'] = '100px' } |
|||
:addClass('plinkt-link no-border') |
|||
:attr{ ['data-sort-value'] = item.product } |
|||
: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 125: | Line 170: | ||
: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') |
:tag('td') |
||
:wikitext(item. |
:wikitext(item.XP and lang:formatNum(tonumber(item.XP))) |
||
:done() |
:done() |
||
:ELSE() |
:ELSE() |
||
:node(unknown_value_cell) |
|||
:node(plist.unknown_value_edit_cell(item.pageName,1)) |
|||
: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() |
||