Module:ResourceLink: Difference between revisions

From Against the Storm Official Wiki
m (forgot a space in the rendered output)
(now with error checking!)
 
(22 intermediate revisions by the same user not shown)
Line 1: Line 1:
-------------------------------------------------------------------------------
--- @module ResourceLink
-- Renders the {{resourceLink}} template
local ResourceLink = {}
--
 
-- Takes an argument, the name of the resource. Optionally, accepts a second
 
-- argument, "med" or "large" to render the icon as larger than the standard
--region Dependencies
-- size of text, {{ImgS}}
 
-------------------------------------------------------------------------------
local GoodsData = require("Module:GoodsData")
 
local VIEW_TEMPLATE = "Resource_link/view"
 
--endregion
 


local ResourceLink = {}


local IconFilenames = require("Module:IconFilenames") -- lookup table for image filenames
--region Private constants
 
local VALID_SIZE = {
["none"] = true,
["small"] = true,
["medium"] = true,
["large"] = true,
["huge"] = true,
}
 
--endregion
 
 
 
--region Private methods
 
---validateResourceName retrieves the icon from the data module.
---
---@param name string the display name of a resource
---@return string the filename of the icon
local function validateResourceName(name)
 
local goodID = GoodsData.getGoodID(name)
local validatedIcon = GoodsData.getIcon(goodID)
 
if not validatedIcon then
error("No resource found with name: " .. name .. ". Please see the template documentation for how to use the parameters")
end
 
return validatedIcon
end
 
--endregion
 
 
 
--region Public methods
 
---main is called from the template to create a link, with an icon, to the page for the specified goods.
---
---@param frame table the Mediawiki template context
---@return string wikimarkup generated by the view template
function ResourceLink.main(frame)
 
local name = frame.args.name
local iconSize = frame.args.size
local display = frame.args.display


function ResourceLink.renderLink(frame)
if not name or name == "" then
local strImageName = frame.args.image
error("You must specify a resource. Please see the template documentation for how to use the parameters")
local strImageSize = frame.args.size
 
local strFilename = IconFilenames.getIconFilename(strImageName)
 
-- if looking up the provided image name returned nil, then render an error
if not strFilename then
return "renderIcon Error: file " .. strImageName .." not found"
end
end


-- render the string to return, starting with the file tag, then the link tag
-- Validate the name.
validatedIcon = validateResourceName(name)
-- use the established templates for image sizes, with the default being
 
-- small, or in-line size.
-- Handle default icon size.
local strFileSize = "{{ImgS}}"
if not iconSize or iconSize == "" or not VALID_SIZE[iconSize] then
if "med" == strImageSize then
iconSize = "small"
strFileSize = "{{ImgM}}"
elseif "large" == strImageSize then
strFileSize = "{{ImgL}}"
elseif "huge" == strImageSize then
strFileSize = "{{ImgH}}"
end
end
local strFilePart = string.format("[[File:%s|%s]]", strFilename, strImageSize)
 
-- The args to pass to the view.
-- build the link based on the name of the resource passed in
viewParameters = {
local strLinkPart = "[[" .. strImageName .. "]]"
["name"] = name,
["iconfilename"] = validatedIcon,
return strFilePart .. " " .. strLinkPart
["iconsize"] = iconSize,
["display"] = display,
}
 
return frame:expandTemplate{
title = VIEW_TEMPLATE,
args = viewParameters,
}
end
end
--endregion


return ResourceLink
return ResourceLink

Latest revision as of 02:44, 19 October 2024

Documentation for this module may be created at Module:ResourceLink/doc

--- @module ResourceLink
local ResourceLink = {}


--region Dependencies

local GoodsData = require("Module:GoodsData")

local VIEW_TEMPLATE = "Resource_link/view"

--endregion



--region Private constants

local VALID_SIZE = {
	["none"] = true,
	["small"] = true,
	["medium"] = true,
	["large"] = true,
	["huge"] = true,
}

--endregion



--region Private methods

---validateResourceName retrieves the icon from the data module.
---
---@param name string the display name of a resource
---@return string the filename of the icon
local function validateResourceName(name)

	local goodID = GoodsData.getGoodID(name)
	local validatedIcon = GoodsData.getIcon(goodID)

	if not validatedIcon then
		error("No resource found with name: " .. name .. ". Please see the template documentation for how to use the parameters")
	end

	return validatedIcon
end

--endregion



--region Public methods

---main is called from the template to create a link, with an icon, to the page for the specified goods.
---
---@param frame table the Mediawiki template context
---@return string wikimarkup generated by the view template
function ResourceLink.main(frame)

	local name = frame.args.name
	local iconSize = frame.args.size
	local display = frame.args.display

	if not name or name == "" then
		error("You must specify a resource. Please see the template documentation for how to use the parameters")
	end

	-- Validate the name.
	validatedIcon = validateResourceName(name)

	-- Handle default icon size.
	if not iconSize or iconSize == "" or not VALID_SIZE[iconSize] then
		iconSize = "small"
	end

	-- The args to pass to the view.
	viewParameters = {
		["name"] = name,
		["iconfilename"] = validatedIcon,
		["iconsize"] = iconSize,
		["display"] = display,
	}

	return frame:expandTemplate{
		title = VIEW_TEMPLATE,
		args = viewParameters,
	}
end

--endregion

return ResourceLink