Open main menu

Module:Authority control

Revision as of 11:15, 6 April 2013 by en>Tpt

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

function getCatForId( id )
    local title = mw.title.getCurrentTitle()
    local namespace = title.namespace
    if namespace == 0 then
        return '[[Category:Wikipedia articles with ' .. id .. ' identifiers]]'
    elseif namespace == 2 and not title.isSubpage then
        return '[[Category:User pages with ' .. id .. ' identifiers]]'
    else
        return '[[Category:Miscellaneous pages with ' .. id .. ' identifiers]]'
    end
end

function viafLink( id )
    if not string.match( id, '^%d+$' ) then
        return false
    end
    return '[http://viaf.org/viaf/' .. id .. ' ' .. id .. ']'
end

function lccnLink( id )
    local parts = splitLccn( id )
    if not parts then
        return false
    end
    id = table.concat( parts )
    return '[http://id.loc.gov/authorities/names/' .. id .. ' ' .. id .. ']'
end

function splitLccn( id )
    if string.match( id, '^%l%l?%l?%d%d%d%d%d%d%d%d%d?%d?$' ) then
        id = string.gsub( id, '^(%l+)(%d+)(%d%d%d%d%d%d)$', '%1/%2/%3' )
    end
    if string.match( id, '^%l%l?%l?/%d%d%d?%d?/%d+$' ) then
        local parts = split( id, '/' )
        parts[3] = append( parts[3], '0', 6 )
        return parts
    end
    return false
end

--Do split before deployment of mw.text.split
function split( str, c )
    local parts = {}
    local current = ''
    local length = string.len( str )
    for i = 1,length do
        local ch = string.char( string.byte( str, i ) )
        if ch == c then
            table.insert( parts, current )
            current = ''
        else
            current = current .. ch
        end
    end
    table.insert( parts, current )
    return parts
end

function append(str, c, length)
    while string.len( str ) < length do
        str = c .. str
    end
    return str
end

function orcidLink( id )
    return '[http://orcid.org/' .. id .. ' ' .. id .. ']'
end

function gndLink( id )
    if not string.match( id, '^%d+$' ) then
        return false
    end
    return '[http://d-nb.info/gnd/' .. id .. ' ' .. id .. ']'
end

--In this order: name of the parameter, label, propertyId in Wikidata, formatting function
local conf = {
    { 'VIAF', '[[Virtual International Authority File|VIAF]]', 0, viafLink },
    { 'LCCN', '[[Library of Congress Control Number|LCCN]]', 0, lccnLink },
    { 'ORCID', '[[ORCID]]', 0, orcidLink },
    { 'GND', '[[Universal Authority File|GND]]', 0, gndLink }
}
    
local p = {}

function p.authorityControl( frame )
    local parentArgs = frame:getParent().args
    --Create rows
    local elements = {}
    for k, params in pairs( conf ) do
        local val = parentArgs[params[1]]
        if val and val ~= '' then
            local link = params[4]( val )
            if link then
                table.insert( elements, '* ' .. params[2] .. ': <span class="uid">' .. link .. '</span>' .. getCatForId( params[1] ) .. '\n' )
            else
                table.insert( elements, '* <span class="error">The ' .. params[1] .. ' id ' .. val .. ' is not valid.</span>[[Category:Wikipedia articles with faulty authority control identifiers (' .. params[1] .. ')]]\n' )
            end
            
        end
    end
    local Navbox = require('Module:Navbox')
    return Navbox._navbox( {
        name  = 'Authority control',
        bodyclass = 'hlist',
        group1 = '[[Authority control]]',
        list1 = table.concat( elements )
    } )
end

return p