Editing Module:FisherList
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:Fisher]] AND [[Category:Pages with activities]]' |
|||
-- other parameters are determined by subqueries of chained pages |
|||
⚫ | |||
local |
local query = { |
||
'[[Variant of::Flounder (skill node)||Eel (skill node)||Pufferfish (skill node)||Gurnard (skill node)||Bass (skill node)||Ray (skill node)||Cod (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 |
||
Line 30: | Line 53: | ||
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 |
||
for _, item in ipairs(results) do |
for _, item in ipairs(results) do |
||
--catch badly submitted data |
|||
item.material = item.material or '' |
|||
item.product = item.product or '' |
|||
⚫ | |||
-- price of fish |
|||
-- 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 48: | 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 57: | 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 95: | 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 100: | 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() |
||
-- fishing node |
-- fishing 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 ..']]') |
|||
:done() |
|||
-- fish |
-- fish |
||
: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' } |
|||
: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() |
|||
-- fish/hr |
-- fish/hr |
||
Line 121: | 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') |
: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() |
||