Modul:Ext scan link
Utilizează Lua: |
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