Module:Tooltip

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