Editing Module:AlchemistPassiveList
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 recipe = require('Module:Infobox Recipe') -- to make use of its extensive material searching function |
|||
local param = require( 'Module:Paramtest' ) |
local param = require( 'Module:Paramtest' ) |
||
local currency = require('Module:Currency') |
local currency = require('Module:Currency') |
||
Line 13: | Line 14: | ||
local query = { |
local query = { |
||
'[[Uses facility::Passive Potion Station]] OR [[Variant of::Ebsworth Work]]', |
'[[Uses facility::Passive Potion Station]] OR [[Variant of::Ebsworth Work]]', |
||
⚫ | |||
'?Profession Level A = lvl', |
'?Profession Level A = lvl', |
||
'? #- = name', |
'? #- = name', |
||
Line 19: | Line 19: | ||
'?Activity XP = XP', |
'?Activity XP = XP', |
||
'?Activity duration = duration', |
'?Activity duration = duration', |
||
⚫ | |||
'?Activity coins = coins', |
'?Activity coins = coins', |
||
⚫ | |||
⚫ | |||
'sort = Profession Level A', |
'sort = Profession Level A', |
||
'limit = 500' |
'limit = 500' |
||
} |
} |
||
local results = mw.smw.ask(query) |
local results = mw.smw.ask(query) |
||
⚫ | |||
-- criterion for if an entry is a recipe, or a passive activity |
|||
for _, item in ipairs(results) do |
|||
item.passiveActivity = item.variant=='Ebsworth Work' |
|||
⚫ | |||
results = p.formatResults(results) |
results = p.formatResults(results) |
||
Line 57: | Line 53: | ||
function p.formatResults(results) |
function p.formatResults(results) |
||
-- iterate through |
-- iterate through potions |
||
for _, item in ipairs(results) do |
for _, item in ipairs(results) do |
||
-- recipe in a workable format |
-- recipe in a workable format |
||
if item. |
if item.variant=='Ebsworth Work' then |
||
-- if it is |
-- if it is ebsworth work, sub in different fields for the buy and sell values |
||
-- some fields are easy to work out |
|||
item.outputQuantity = 1 |
item.outputQuantity = 1 |
||
item. |
item.reagents = {} |
||
item.intermediates = {} |
item.intermediates = {} |
||
item.buy = 0 |
item.buy = 0 |
||
item.sell = item.coins |
|||
else |
else |
||
local unpackJSON = mw.text.jsonDecode(item.recipeJSON) |
local unpackJSON = mw.text.jsonDecode(item.recipeJSON) |
||
item.outputQuantity = unpackJSON.output[1].quantity |
item.outputQuantity = unpackJSON.output[1].quantity |
||
⚫ | |||
-- SECTION REMOVED |
|||
-- do not need to extensively search for subrecipes, as passive recipe |
|||
-- passive recipes only ever have one step |
|||
item.materials = unpackJSON.materials |
|||
-- call the module:infobox recipe to extensively search for |
|||
⚫ | |||
-- all raw materials (to add to prices) |
|||
-- all intermediate materials (for intermediate XP and duration) |
|||
local Materials = recipe._getTrueRawMaterials(unpackJSON.materials) |
|||
if next(Materials) ~= nil then |
|||
item.reagents = Materials.rawMaterials |
|||
item.intermediates = Materials.intermediateMaterials |
|||
⚫ | |||
⚫ | |||
⚫ | |||
item.buy = 0 |
item.buy = 0 |
||
for _, |
for _, reagent in ipairs(item.reagents) do |
||
--shamelessley lifted from Module:Products |
--shamelessley lifted from Module:Products |
||
local shopPriceQuery = '[[:+]][[Sold item::' .. |
local shopPriceQuery = '[[:+]][[Sold item::' .. reagent.name .. ']]|?Shop buy price|mainlabel=' .. reagent.name |
||
local shopPriceResult = mw.smw.ask(shopPriceQuery) or {} |
local shopPriceResult = mw.smw.ask(shopPriceQuery) or {} |
||
local shopPrice = 0 |
local shopPrice = 0 |
||
Line 94: | Line 93: | ||
else |
else |
||
item.buy = nil |
item.buy = nil |
||
end |
|||
⚫ | |||
⚫ | |||
end |
|||
-- iterate through intermediaries to add to XP and duration parameters |
|||
for _, intermediate in ipairs(item.intermediates) do |
|||
-- look up activity XP and add it to running total |
|||
local XPQuery = '[[Recipe output::' .. intermediate.name .. ']]|?Activity XP|mainlabel=' .. intermediate.name |
|||
local XPResult = mw.smw.ask(XPQuery) or {} |
|||
local XPIncrease = 0 |
|||
if XPResult[1] and XPResult[1]["Activity XP"] then |
|||
XPIncrease = tonumber(XPResult[1]["Activity XP"]) or 0 |
|||
else |
|||
XPIncrease = nil |
|||
end |
end |
||
-- need to look up both the amount of the item used in this recipe and created in its own recipe to know how much of this xp to use |
|||
local QTYused = intermediate.quantity |
|||
local QTYQuery = '[[Recipe output::' .. intermediate.name .. ']]|?Recipe JSON|mainlabel=' .. intermediate.name |
|||
⚫ | |||
local QTYResult = mw.smw.ask(QTYQuery) or {} |
|||
local QTYmade = 0 |
|||
if QTYResult[1] and QTYResult[1]["Recipe JSON"] then |
|||
QTYmade = mw.text.jsonDecode(QTYResult[1]["Recipe JSON"]) or {} |
|||
end |
|||
QTYmade = QTYmade.output[1].quantity |
|||
item.XP = item.XP and XPIncrease and item.XP + XPIncrease * QTYused / QTYmade; |
|||
-- look up activity duration and add it to running total |
|||
local durationQuery = '[[Recipe output::' .. intermediate.name .. ']]|?Activity duration|mainlabel=' .. intermediate.name |
|||
local durationResult = mw.smw.ask(durationQuery) or {} |
|||
local durationIncrease = 0 |
|||
if durationResult[1] and durationResult[1]["Activity duration"] then |
|||
durationIncrease = tonumber(durationResult[1]["Activity duration"]) or 0 |
|||
else |
|||
durationIncrease = nil |
|||
end |
|||
item.duration = item.duration and durationIncrease and item.duration + durationIncrease * intermediate.quantity |
|||
end |
end |
||
Line 107: | Line 145: | ||
item.profitPerXP = item.profit and item.XP and math.floor(item.profit / item.XP * 100) / 100 |
item.profitPerXP = item.profit and item.XP and math.floor(item.profit / item.XP * 100) / 100 |
||
-- |
-- potions made in 200 lots of 0.005, no downtime for passive activities |
||
local batchSize = 200 |
local batchSize = 200 |
||
local downtime = 0 |
local downtime = 0 |
||
item.duration = item.duration and item.duration + downtime/batchSize |
item.duration = item.duration and item.duration + downtime/batchSize |
||
item. |
item.potionPerHour = item.duration and 1 / item.duration * 3600 |
||
-- properties per hour |
-- properties per hour |
||
item.XPPerHour = item.XP and item. |
item.XPPerHour = item.XP and item.potionPerHour and math.floor(item.XP * item.potionPerHour) |
||
item.profitPerHour = item.profit and item. |
item.profitPerHour = item.profit and item.potionPerHour and math.floor(item.profit * item.potionPerHour) |
||
end |
end |
||
Line 131: | Line 169: | ||
:tag('th') |
:tag('th') |
||
:attr{ colspan = '3' } |
:attr{ colspan = '3' } |
||
:wikitext(' |
:wikitext('Potion') |
||
:done() |
:done() |
||
:tag('th') |
:tag('th') |
||
:wikitext(' |
:wikitext('Reagents') |
||
:done() |
:done() |
||
:tag('th') |
:tag('th') |
||
Line 195: | Line 233: | ||
:done() |
:done() |
||
:IF(not(item. |
:IF(not(item.variant=='Ebsworth Work')) |
||
local |
local reagentCell = row:tag('td') |
||
for i, _ in ipairs(item. |
for i, _ in ipairs(item.reagents) do |
||
reagentCell:wikitext(item.reagents[i].quantity .. '× [[File:' .. item.reagents[i].name .. '.png|18px|link=' .. item.reagents[i].name .. ']]' .. '[[' .. item.reagents[i].name .. ']]<br>') |
|||
end |
end |
||