Module:Tooltip

From Discord Dungeons Wiki
Jump to navigation Jump to search

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

local p = {}
 
local yn = require('Module:Yesno')
local hc = require('Module:Paramtest').has_content
 
 
-- module access point for div
p._div = function(args)
	local name = args.name
	if not hc(name) then
		error('Name is required!')
	end
 
	local content = args.content
	local hasarrow = yn(args.arrow or 'yes', true)
	local arrowsize = tonumber(args.arrowsize) or 10
	local limitwidthbool = yn(args.limitwidth or 'yes', true)
	local style = args.style
 
	local div = mw.html.create('div')
 
	local arrow = 'no'
	if hasarrow then
		arrow = 'yes'
	end
 
	local limitwidth = 'no'
	if limitwidthbool then
		limitwidth = 'yes'
	end
 
	local attrs = {
		['data-tooltip-for'] = name,
		['data-tooltip-arrow'] = arrow,
		['data-tooltip-arrow-size'] = arrowsize,
		['data-tooltip-limit-width'] = limitwidth,
	}
 
	if hc(style) then
		attrs['data-tooltip-style'] = style
	end
 
	div	:addClass('hidden js-tooltip-wrapper')
		:css('display', 'none')
		:attr(attrs)
		:tag('div')
			:addClass('js-tooltip-text')
			:wikitext(content)
			:done()
		:done()
 
	return div
end
 
p._span = function(args)
	local name = args.name or args[1] or nil
	if not hc(name) then
		error('Name is required!')
	end
	local alt = args.alt or args[2] or '?'
 
	local span = mw.html.create('span')
 
	span:addClass('hidden js-tooltip-click')
		:css('display', 'none')
		:attr('data-tooltip-name', name)
		:wikitext(alt)
		:done()
 
	return span
end
 
-- template access points
p.div = function(frame)
	return p._div(frame:getParent().args)
end
p.span = function(frame)
	return p._span(frame:getParent().args)
end
 
return p