Sari la conținut

Modul:Ext scan link

Logică pentru {{digitizare externă}}


--[=[
Logică pentru [[Format:Digitizare externă]]
]=]

local p = {} --p stands for package
local getArgs = require('Modul:Arguments').getArgs


function generate_links_from_args(args)
	local links = {}
	
	local i = 1
	while args[i] ~= nil do
		
		local link = {
			href = args[i],
			filename = args['filename' .. i],
			display = args['display' .. i]
		}
		
		table.insert(links, link)
		i = i + 1
	end
	return links
end

function format_links(links, single_link_text, multi_link_prefix, sep)
	local out = mw.html.create('span')
		:addClass('wst-ext-scan-links')
		:wikitext('(')
	
	if #links > 1 then
		out:wikitext(multi_link_prefix)
	end

	for k, link in pairs(links) do
		
		if k > 1 then
			out:wikitext(sep)
		end
		
		local display = link.display
		if display == nil then
			if #links == 1 then
				display = single_link_text
			else
				display = tostring(k)
			end
		end

		local span = out:tag('span')
			:addClass('wst-ext-scan-link')
			:wikitext('[' .. link.href .. ' ' .. display .. ']')
			
		if link.filename then
			span:attr('data-upload-filename', link.filename)	
		end
	end
	
	out:wikitext(')')
	return out
end

--[=[
Main entry point
]=]
function p.ext_scan_link(frame)
	local args = getArgs(frame)

	for k, v in pairs(args) do
		if string.match(k, "^https?://") ~= nil then
			local err = ""
			err = err .. "<strong class='error'>"
			err = err .. "Lipsește semnul = înaintea parametrului: '" .. k .. "'='" .. v .. "'"
			err = err .. "</strong>"
			err = err .. "[[Categorie:" .. "Pagini care folosesc digitizare externă cu semne egal cu probleme" .. "]]"
			return err
		end
	end

	
	local links = generate_links_from_args(args)
	local out = format_links(links,
		'digitizare externă',
		'digitizare externă (în mai multe părți): ',
		', ')
	return out
end

return p