Editing Module:Sandbox/User:Alsang
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('Module:Mw.html extension') |
|||
local param = require( 'Module:Paramtest' ) |
|||
local currency = require('Module:Currency') |
|||
local lang = mw.getContentLanguage() |
|||
local xpdata = mw.loadData('Module:Experience/data') |
|||
local p = {} |
local p = {} |
||
-- non dynamic module, no inputs |
|||
function p.minerPages() |
|||
function p.main() |
|||
-- returns only directly needed parameter needed for the row, |
|||
local queryString = '[[Variant of::Flint||Andesite||Granite||Basalt||Deathstone||Iron Ore||Cabranese Ore||Adathril Ore||Flantium Ore||Mine Cart Work]]' |
|||
-- other parameters are determined by subqueries of chained pages |
|||
local query = { |
|||
return p.main(queryString) |
|||
'[[Activity JSON::~*]]', |
|||
'? = name', |
|||
end |
|||
'?Activity JSON = activityJSON', |
|||
'limit = 1500' |
|||
function p.foragerPages() |
|||
} |
|||
local results = mw.smw.ask(query) |
|||
results = p.screenResults(results) |
|||
local queryString = '[[Variant of::Kelp||Wallplant||Periwinkle||Shell||Potato||Pond Weed||Bellplant||Monument Piece||Water Lily||Starfish||Hogberries||Limpet||Nettle||Wrack]]' |
|||
return p. |
return p.displayTable(results) |
||
--for debugging |
|||
--return '<pre>'..mw.text.jsonEncode(results, mw.text.JSON_PRETTY)..'</pre>' |
|||
end |
end |
||
-- goes through a list of results and culls the ones which are not needed for this table |
|||
function p.gathererPages1() |
|||
function p.screenResults(results) |
|||
local resultsScreened = {} |
|||
-- iterate through products |
|||
local queryString = '[[Variant of::Globeplant||Dandelion||Goat Horn||Apple||Leek||Haleberries||Rams Horn||Bitterfruit||Chestnut||Bone Spike]]' |
|||
for _, item in ipairs(results) do |
|||
-- if theres only one activity, wrap in table |
|||
if type(item.activityJSON)=='string' then |
|||
item.activityJSON = { item.activityJSON } |
|||
end |
|||
for j,json in ipairs(item.activityJSON) do |
|||
local activityJSON = mw.text.jsonDecode(json) |
|||
if activityJSON.duration and tonumber(activityJSON.duration)==20 then |
|||
local itemNew = {} |
|||
itemNew.name = item.name |
|||
itemNew.XP = activityJSON.xp |
|||
itemNew.lvl = activityJSON.level |
|||
itemNew.profession = activityJSON.profession |
|||
itemNew.duration = activityJSON.duration |
|||
itemNew.product = activityJSON.output[1].name |
|||
itemNew.XPperHour = itemNew.XP and tonumber(itemNew.XP) and itemNew.duration and tonumber(itemNew.duration) and tonumber(itemNew.XP) * 3600 / tonumber(itemNew.duration) |
|||
itemNew.fitXP = xpdata.knowledge[itemNew.lvl]*4*0.0005 |
|||
if itemNew.lvl>=200 then |
|||
itemNew.fitXP = itemNew.fitXP * 4 |
|||
end |
|||
itemNew.fitXP = math.floor(itemNew.fitXP * 100 ) / 100 |
|||
local query = mw.smw.ask('[[Sold item::' .. itemNew.product .. ']][[Shop sell price::!~N/A]]|?Shop sell price=data|mainlabel=-') |
|||
if type(query)=='table' then |
|||
-- price is returned as a number |
|||
itemNew.productSellPrice = tonumber(query[1].data)*0.005 |
|||
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 |
|||
itemNew.productSellPrice = nil |
|||
end |
|||
table.insert(resultsScreened,itemNew) |
|||
end |
|||
end |
|||
end |
|||
-- sort the results by recipe level |
|||
table.sort(resultsScreened, function(item1, item2) |
|||
local lvl1 = item1.lvl |
|||
local lvl2 = item2.lvl |
|||
if (lvl1 == nil) ~= (lvl2 == nil) then --one of two are empty |
|||
return lvl2 == nil -- true if lvl2 is nil but not lvl1, false if lvl1 is nil but not lvl2 |
|||
end |
|||
if lvl1 == nil then |
|||
return false -- Both empty, equivalent |
|||
end |
|||
return lvl1 < lvl2 -- normal comparison |
|||
end) |
|||
return |
return resultsScreened |
||
end |
end |
||
-- make the table |
|||
function p.gathererPages2() |
|||
function p.displayTable(results) |
|||
local out = mw.html.create('table') |
|||
local queryString = '[[Variant of::Tangfruit||Catkin||Femur Shard||Clover||Snake Scale||Orchid||Dock Leaf||Sage||Thistle]]' |
|||
:addClass('wikitable sortable') |
|||
:tag('tr') |
|||
:tag('th') |
|||
:wikitext('Page') |
|||
:done() |
|||
:tag('th') |
|||
:wikitext('Product') |
|||
:done() |
|||
:tag('th') |
|||
:wikitext('Profession') |
|||
:done() |
|||
:tag('th') |
|||
:wikitext('Level') |
|||
:done() |
|||
:tag('th') |
|||
:wikitext('XP') |
|||
:done() |
|||
:tag('th') |
|||
:wikitext('0.0005 of levelup XP') |
|||
:done() |
|||
:tag('th') |
|||
:wikitext('sell price<br>per action') |
|||
:done() |
|||
:tag('th') |
|||
:wikitext('Duration') |
|||
:done() |
|||
:tag('th') |
|||
:wikitext('XP/hr') |
|||
:done() |
|||
:done() |
|||
for i, item in ipairs(results) do |
|||
return p.main(queryString) |
|||
local row = out:tag('tr') |
|||
--level |
|||
:tag('td') |
|||
:wikitext(item.name) |
|||
:done() |
|||
:tag('td') |
|||
:wikitext('[[' .. item.product .. ']]') |
|||
:done() |
|||
:tag('td') |
|||
:wikitext('[[' .. item.profession .. ']]') |
|||
:done() |
|||
:tag('td') |
|||
:wikitext(item.lvl) |
|||
:done() |
|||
:tag('td') |
|||
:wikitext(item.XP) |
|||
:done() |
|||
:tag('td') |
|||
:wikitext(item.fitXP) |
|||
:done() |
|||
:tag('td') |
|||
:wikitext(item.productSellPrice) |
|||
:done() |
|||
:tag('td') |
|||
:wikitext(item.duration) |
|||
:done() |
|||
:tag('td') |
|||
:wikitext(item.XPperHour) |
|||
:done() |
|||
:done() |
|||
end |
|||
return out |
|||
end |
end |
||
function p. |
function p.fisherPages() |
||
local query = { |
local query = { |
||
'[[Variant of::Flounder||Eel||Pufferfish||Gurnard||Bass||Ray||Cod]]', |
|||
queryString, |
|||
'? #- = name', |
'? #- = name', |
||
'?Profession Level A = level', |
'?Profession Level A = level', |
||
'?Variant of |
'?Variant of = variant', |
||
'sort = Variant of,Profession Level A', |
'sort = Variant of,Profession Level A', |
||
'limit = 500' |
'limit = 500' |
||
Line 47: | Line 179: | ||
for _,page in ipairs(results) do |
for _,page in ipairs(results) do |
||
local result = mw.smw.ask('[['..page.name..' (skill node)]]|?Activity JSON = data') |
|||
if string.find(page.name,'Mine') then |
|||
page.JSON = (result and result[1] and result[1].data) or '' |
|||
page.node = page.name |
|||
page.nodevar = page.variant |
|||
else |
|||
page.node = page.name .. ' (skill node)' |
|||
page.nodevar = page.variant .. ' (skill node)' |
|||
end |
|||
local result = mw.smw.ask('[['..page.node..']]|?Activity JSON = data') |
|||
page.JSON = (result and result[1] and result[1].data) or '' |
|||
if type(page.JSON)=='table' then |
|||
page.JSON = table.concat(page.JSON,'<br>') |
|||
end |
|||
end |
end |
||
Line 66: | Line 188: | ||
:tag('th') |
:tag('th') |
||
:wikitext('Variant') |
:wikitext('Variant') |
||
:done() |
|||
:tag('th') |
|||
:wikitext('Node Variant') |
|||
:done() |
:done() |
||
:tag('th') |
:tag('th') |
||
Line 89: | Line 208: | ||
--level |
--level |
||
:tag('td') |
:tag('td') |
||
:wikitext( |
:wikitext(item.variant) |
||
:done() |
|||
:tag('td') |
|||
:wikitext('[['..item.nodevar..']]') |
|||
:done() |
:done() |
||
:tag('td') |
:tag('td') |
||
Line 101: | Line 217: | ||
:done() |
:done() |
||
:tag('td') |
:tag('td') |
||
:wikitext('[['..item. |
:wikitext('[['..item.name..' (skill node)]]') |
||
:done() |
:done() |
||
:tag('td') |
:tag('td') |