Editing Module:MinerList
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:Miner]] AND [[Category:Pages with activities]]' |
|||
-- other parameters are determined by subqueries of chained pages |
|||
⚫ | |||
local |
local query = { |
||
'[[Variant of::Mine Cart Work||Iron Ore (skill node)||Cabranese Ore (skill node)||Flantium Ore (skill node)||Adathril Ore (skill node)||Flint (skill node)||Basalt (skill node)||Andesite (skill node)||Granite (skill node)||Deathstone (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', |
|||
'?Activity coins = coins', |
|||
'?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 35: | ||
--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 58: | ||
--catch badly submitted data |
--catch badly submitted data |
||
item.material = item.material or '' |
|||
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 |
|||
⚫ | |||
-- 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 |
|||
⚫ | |||
end |
|||
-- detect mine cart work |
-- detect mine cart work |
||
item. |
item.hasCoins = string.find(item.name,'Mine Cart Work') |
||
if item. |
if item.hasCoins then |
||
item.profit = item.coins and tonumber(item.coins) |
item.profit = item.coins and tonumber(item.coins) |
||
⚫ | |||
⚫ | |||
end |
end |
||
-- profitability |
-- profitability |
||
item.profitPerXP = item.profit and item. |
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 58: | Line 87: | ||
-- 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 67: | Line 96: | ||
-- 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 105: | Line 128: | ||
: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 110: | Line 138: | ||
--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' } |
|||
: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 |
||
:IF(item. |
:IF(item.hasCoins) |
||
:tag('td') |
:tag('td') |
||
:addClass('table-na') |
:addClass('table-na') |
||
Line 130: | Line 166: | ||
:done() |
:done() |
||
:ELSE() |
:ELSE() |
||
: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() |
|||
-- resource/hr |
-- resource/hr |
||
Line 138: | Line 182: | ||
:done() |
:done() |
||
:ELSE() |
:ELSE() |
||
:node( |
:node(unknown_value_cell) |
||
:END() |
:END() |
||
: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() |
||