Module:Products: Difference between revisions
Jump to navigation
Jump to search
Content added Content deleted
(x -> × simplify single value / table of values implementation; allow quantity to have a decimal point (like when it's "0.05")) |
m (Spaces to tabs) |
||
Line 1: | Line 1: | ||
⚫ | |||
local p = {} |
local p = {} |
||
Line 7: | Line 9: | ||
function p._main(args) |
function p._main(args) |
||
args = args or {} |
args = args or {} |
||
args.item = args.item or mw.title.getCurrentTitle().text |
|||
local showPrices = args.showPrices or false |
|||
local showValues = args.showValues or false |
|||
local products = p.getProducts(args) |
|||
if products ~= 0 then |
|||
local recipeNames = p.extractRecipeNames(products) |
|||
local prodprices = p.getShopBuyPrices(products) |
|||
-- Generate and return a table containing the product information |
|||
local output = p.displayProductTable(prodprices, showPrices, showValues) |
|||
return output |
|||
else |
|||
return "There are no known products for item '''args.item'''" |
|||
end |
|||
end |
end |
||
function p.extractRecipeNames(products) |
function p.extractRecipeNames(products) |
||
local recipeNames = {} |
|||
for _, recipeInfo in ipairs(products) do |
|||
local recipeLink = recipeInfo["Recipe"] |
|||
if recipeLink then |
|||
local displayName = recipeLink:match("%[%[.-|(.+)%]%]") |
|||
if displayName then |
|||
table.insert(recipeNames, displayName) |
|||
⚫ | |||
end |
|||
end |
|||
end |
|||
return recipeNames |
|||
end |
end |
||
function p.getProducts(args) |
function p.getProducts(args) |
||
local item = mw.smw.ask('[[:+]][[Uses item::' .. args.item .. ']]|?Uses item |?Uses item and quantity |?Profession A |?Profession Level A|?Value |mainlabel=Recipe') or 0 |
|||
return item |
|||
end |
end |
||
function p.getShopBuyPrices(products) |
function p.getShopBuyPrices(products) |
||
⚫ | |||
local mw = require('mw') |
|||
⚫ | |||
⚫ | |||
⚫ | |||
⚫ | |||
⚫ | |||
⚫ | |||
⚫ | |||
⚫ | |||
⚫ | |||
⚫ | |||
⚫ | |||
⚫ | |||
⚫ | |||
⚫ | |||
⚫ | |||
⚫ | |||
⚫ | |||
⚫ | |||
⚫ | |||
end |
|||
⚫ | |||
⚫ | |||
⚫ | |||
⚫ | |||
⚫ | |||
⚫ | |||
⚫ | |||
⚫ | |||
end |
|||
⚫ | |||
⚫ | |||
⚫ | |||
⚫ | |||
⚫ | |||
⚫ | |||
⚫ | |||
end |
|||
⚫ | |||
⚫ | |||
⚫ | |||
⚫ | |||
⚫ | |||
end |
|||
⚫ | |||
end |
|||
⚫ | |||
end |
|||
⚫ | |||
⚫ | |||
end |
|||
end |
|||
⚫ | |||
⚫ | |||
end |
end |
||
function p.displayProductTable(products, showPrices, showValues) |
function p.displayProductTable(products, showPrices, showValues) |
||
⚫ | |||
⚫ | |||
⚫ | |||
⚫ | |||
⚫ | |||
local headerRow = {} |
|||
table.insert(headerRow, '!colspan="2" | Recipe') |
|||
table.insert(headerRow, '!! Level') |
|||
⚫ | |||
if showValues then |
if showValues then |
||
table.insert(headerRow, '!! Value') |
|||
end |
end |
||
Line 93: | Line 92: | ||
if showPrices then |
if showPrices then |
||
table.insert(headerRow, '!! Price') |
|||
end |
end |
||
table.insert(out, table.concat(headerRow, ' ')) |
table.insert(out, table.concat(headerRow, ' ')) |
||
for _, product in ipairs(products) do |
|||
local recipeRawText = product["Recipe"]:match("%[%[.-|(.+)%]%]") |
|||
local recipeImage = "[[File:" .. recipeRawText .. ".png|30px]]" |
|||
local recipe = product["Recipe"] or "Unknown" |
|||
local professionName = product["Profession A"]:match("%[%[.-|(.+)%]%]") or product["Profession A"]:match("%[%[(.-)%]%]") or product["Profession A"] or "Unknown" |
|||
local professionLevel = "[[File:" .. professionName .. " small icon.png|15px]] " .. (product["Profession Level A"] or "Unknown") |
|||
local usesItems = product["Uses item"] or {} |
|||
local value = currency(product["Value"]) or "Unknown" |
|||
-- Concatenate uses items and their shop buy prices in unordered lists |
|||
local usesItemStr = "<ul style='list-style:none; margin:0; padding-left:0;'>" |
|||
local shopBuyPriceStr = "<ul style='list-style:none; margin:0; padding-left:0; text-align:right;'>" |
|||
if type(usesItems) == "table" then |
|||
for _, item in ipairs(usesItems) do |
|||
local itemName = item:match("%[%[.-|(.+)%]%]") or item:match("%[%[(.-)%]%]") or item |
|||
usesItemStr = usesItemStr .. "<li>" .. product[itemName .. "_Formatted"] .. "</li>" |
|||
local shopBuyPrice = product[itemName .. "_Shop_buy_price"] or 0 |
|||
if shopBuyPrice == "N/A" then shopBuyPrice = 0 end |
|||
shopBuyPriceStr = shopBuyPriceStr .. "<li>" .. currency(shopBuyPrice) .. "</li>" |
|||
end |
|||
end |
|||
elseif type(usesItems) == "string" then |
|||
local itemName = usesItems:match("%[%[.-|(.+)%]%]") or usesItems:match("%[%[(.-)%]%]") or usesItems |
|||
usesItemStr = usesItemStr .. "<li>" .. product[itemName .. "_Formatted"] .. "</li>" |
|||
local shopBuyPrice = product[itemName .. "_Shop_buy_price"] or 0 |
|||
if shopBuyPrice == "N/A" then shopBuyPrice = 0 end |
|||
shopBuyPriceStr = shopBuyPriceStr .. "<li>" .. currency(shopBuyPrice) .. "</li>" |
|||
end |
|||
usesItemStr = usesItemStr .. "</ul>" |
|||
shopBuyPriceStr = shopBuyPriceStr .. "</ul>" |
|||
table.insert(out, '|-') |
|||
local valuesRow = {} |
|||
table.insert(valuesRow, '| ' .. recipeImage) |
|||
table.insert(valuesRow, '|| ' .. recipe) |
|||
table.insert(valuesRow, '|| ' .. professionLevel) |
table.insert(valuesRow, '|| ' .. professionLevel) |
||
if showValues then |
if showValues then |
||
table.insert(valuesRow, '|| ' .. value) |
|||
end |
end |
||
Line 145: | Line 144: | ||
if showPrices then |
if showPrices then |
||
table.insert(valuesRow, '|| ' .. shopBuyPriceStr) |
|||
end |
end |
||
table.insert(out, table.concat(valuesRow, ' ')) |
table.insert(out, table.concat(valuesRow, ' ')) |
||
⚫ | |||
⚫ | |||
⚫ | |||
⚫ | |||
return table.concat(out, '\n') |
|||
end |
|||
⚫ | |||
⚫ | |||
end |
end |
||