「モジュール:Authority control」の版間の差分

提供:脳科学辞典
ナビゲーションに移動 検索に移動
(1版 をインポートしました)
bsd>MSGJ
(some simplification and other tweaks)
1行目: 1行目:
--[[ 
require('strict')
  __  __          _      _          _        _  _                _ _                          _            _
local p = {}
|  \/  | ___  __| |_  _| | ___ _  / \  _  _| |_| |__  ___  _ __(_) |_ _  _    ___ ___  _ __ | |_ _ __ ___ | |
local frame = mw.getCurrentFrame()
| |\/| |/ _ \ / _` | | | | |/ _ (_) / _ \| | | | __| '_ \ / _ \| '__| | __| | | |  / __/ _ \| '_ \| __| '__/ _ \| |
local config_file = frame.args.config and frame.args.config~='' and ('/' .. frame.args.config) or ''
| |  | | (_) | (_| | |_| | |  __/_ / ___ \ |_| | |_| | | | (_) | |  | | |_| |_| | | (_| (_) | | | | |_| | | (_) | |
local config = mw.loadData('Module:Authority control/config' .. config_file)
|_|  |_|\___/ \__,_|\__,_|_|\___(_)_/  \_\__,_|\__|_| |_|\___/|_|  |_|\__|\__, |  \___\___/|_| |_|\__|_|  \___/|_|
local title = mw.title.getCurrentTitle()
                                                                            |___/                                   
local namespace = title.namespace
This module is intended to be the engine behind "Template:Authority control".
local testcases = title.subpageText == config.i18n.testcases


Please do not modify this code without applying the changes first at "Module:Authority control/sandbox" and testing
local wikilink = function(target, label)
at "Module:Authority control/testcases".
return label and '[[' .. target .. '|' .. label .. ']]' or '[[' .. target .. ']]'
end


Authors and maintainers:
local needsAttention = function(sortkey)
* User:Jarekt - original version
return wikilink(config.i18n.category .. ':' .. config.i18n.attentioncat, sortkey .. title.text)
end


]]
local addCat = function(cat, sortkey)
 
if cat and cat~='' and (namespace==0 or namespace==14 or testcases) then
-- ==================================================
local redlinkcat = ''
-- === Internal functions ===========================
if testcases==false then
-- ==================================================
local success, exists = pcall(function() return mw.title.new(cat, 14).exists end)
 
if success and not exists then
local function getSitelink(item, lang)
redlinkcat = needsAttention('N')
local langList = mw.language.getFallbacksFor(lang)
end
table.insert(langList, 1, lang)
for _, language in ipairs(langList) do
local sitelink = mw.wikibase.sitelink( item, language .. 'wiki' )
if sitelink then
return 'w:'.. language ..':'.. sitelink
end
end
return wikilink(config.i18n.category..':'..cat, sortkey and sortkey..title.text) .. redlinkcat
else
return ''
end
end
return nil
end
end


local function getIdentifierNameLink( lang, item1, item2, label )
local tooltip = function(text, label)
-- Identifier names, like VIAF, LCCN, ISNI, need to be linked to the articles about them if possible
if label and label~='' then
-- Alternativly they can be linked to the articles for institutions that issue them
return frame:expandTemplate{
local id_name_URL = nil
title = 'Tooltip',
-- 1) try wikipedia sitelink for the identifier in users language and in English
args = {text, label}
if item1 and item1 ~='' then
}
id_name_URL = getSitelink(item1, lang)
else
end
return text
-- 2) try wikipedia sitelink for the issuedBy property in users language and in English
if id_name_URL==nil and item2 and item2 ~='' then -- if no link than
id_name_URL = getSitelink(item2, lang)
end
-- 3) if still no links than link to wikidata
if id_name_URL then
return string.format("[[%s|%s]]", id_name_URL, label) -- link to wikipedia
else  
return string.format("[[d:%s|%s]]", item1, label) -- link to wikidata
end
end
end
end


-- ==================================================
local _makelink = function(id, val, additional, qid) --validate values and create a link
-- Create link to a single identifier
local link = mw.html.create('span'):addClass('uid')
-- INPUTS:
if not additional and id.prefix then --show prefix on primary value
--  * val - value of the identifier
link:wikitext(id.prefix .. ': ')
--  * URL_format - string used to create URL
--  * params - additional parameters related to this type of identifiers. Single item from "conf"
--  * color - color of the link
local function getIdentifierValLink(val, URL_format, params, color)
if not val or val=='' then
return ''
end
end
-- check if identifier is in the right format
local valid_value = false
local mismatchStr = ''
if id.customlink then -- use function to validate and generate link
local val_ = val:gsub( ' ', '' ) -- remove spaces
local newlink = require(config.auxiliary)[id.customlink](val.id, additional)
if (params.regexp and not val:match( params.regexp )) then
if newlink then
mismatchStr  = string.format("<span style=\"color:red\">[does not match %s pattern]</span>", params.regexp)
link:wikitext(newlink)
elseif (params.verify) then -- check if special "Verify" function is present
valid_value = true
mismatchStr = params.verify(val_) -- add error message if any
end
end
else
-- identifier_value_URL
if id.pattern then -- check pattern to determine validity
local val_URL = URL_format:gsub('$1', val_)-- URL part of the link for the identifier value
valid_value = string.match(val.id, '^' .. id.pattern .. '$')
if color~="blue" then
elseif id.patterns then -- check multiple patterns to determine validity
val = string.format('<span style=\"color:%s\">%s</span>', color, val)
for _, pattern in ipairs(id.patterns) do
end
valid_value = val.id:match('^' .. pattern .. '$')
return string.format("<span class=\"plainlinks\">[%s %s]</span>%s", val_URL, val, mismatchStr) -- link to the identifier's external website
if valid_value then break end
end  
end
 
elseif id.valid then -- use function to determine validity
-- ==================================================
valid_value = require(config.auxiliary)[id.valid](val.id)
-- Convert between 2 formats of LCCN: "n/79/63767" -> "n79063767"
else -- no validation possible
-- "n/79/63767" format was used as input by {{Authority Control}} templates
valid_value = val.id
-- "n79063767" format is used by wikidata
end
local function fixLCCN(id)
if valid_value then
  if id then
local label = id.label
local a, b, c = string.match(id, "([%a%d]*)/([%a%d]*)/([%a%d]*)")
if not label or additional then
if c then
label = tostring(additional)
local pad = 6 - string.len(c)
end
if pad > 0 then
local newlink
c = string.rep("0", pad)..c
if id.link then
valid_value = valid_value:gsub('%%', '%%%%')
newlink = '[' .. mw.ustring.gsub(id.link, '%$1', valid_value) .. ' ' .. label .. ']'
else
newlink = valid_value
end
end
id = a..b..c
link:wikitext(tooltip(newlink, val.name))
end
end
end
end
return id
if valid_value then
end -- fixLCCN
local cat = id.category and string.format(config.i18n.cat, id.category)
 
link:wikitext(addCat(cat))
-- ==================================================
-- Verify last "check" digit is correct. ISNI and several other
-- identifiers use last digit as a verification digit
local function verifyLastDigit( id )
    local total = 0
    for i = 1, #id-1 do
        local digit = id:byte( i ) - 48 --Get integer value
        total = (total + digit) * 2
    end
    --local remainder = total % 11
    local lastDigit = tostring((12 - total % 11) % 11)
    if lastDigit == '10' then
        lastDigit = "X"
    end
    if (lastDigit == string.sub( id, -1)) then
return ''
else
else
return "<span style=\"color:red\">[last digit should be " .. lastDigit .. "]</span>"
local wdlink = qid and wikilink(':wikidata:' .. qid .. '#P' .. id.property) or ''
local name = mw.wikibase.getLabel('P' .. id.property) or ''
local tooltip = string.format(
config.i18n.idnotvalid,
name,
val.id
)
local cat = id.category and string.format(
config.i18n.cat,
config.i18n.faulty .. ' ' .. id.category
)
link:wikitext(wikilink('File:' .. config.i18n.warningicon .. '|20px|frameless|link=' .. wdlink, tooltip .. '.'))
:wikitext(addCat(cat))
:wikitext(addCat(config.i18n.allfaultycat, name))
end
end
return link
end
end


-- ==================================================
local _makelinks = function(id, qid)
-- === Settings =====================================
--[[==================================]]
-- ==================================================
--[[           Make links            ]]
-- In order to add a new identifier associated with Wikidata property do the following
--[[==================================]]
-- 1) go to [[Template:Authority control/IdentifierList]] and verify that the property number is on the list, if not than edit the page to add it
local getquals = function(statement, qualid)
-- 2) copy code generated at [[Template:Authority control/IdentifierList]] to protected [[Module:Authority control/conf]]
if statement.qualifiers and statement.qualifiers['P'..qualid] then
-- 3) add the property to the "conf" list below
return mw.wikibase.renderSnak(statement.qualifiers['P'..qualid][1])
 
-- load 'Module:Authority control/conf' which holds hardwired data derived from Wikidata's properties of
-- properties
local properties = require('Module:Authority control/conf')
 
--conf  holds list of identifiers to be displayed
local conf = {
    -- people
{label='VIAF'        , property='P214' , lang=''  , regexp='^%d+$' },
{label='ISNI'        , property='P213' , lang=''  , regexp='^%d%d%d%d %d%d%d%d %d%d%d%d %d%d%d[%dX]$', verify=verifyLastDigit },
{label='ORCID'      , property='P496' , lang=''  , regexp='^0000%-000[1-3]%-%d%d%d%d%-%d%d%d[%dX]$' },
{label='ULAN'        , property='P245' , lang=''  , regexp='^500%d%d%d%d%d%d$' }, -- 'Union List of Artist Names' by Getty Research Institute
{label='ResearcherID', property='P1053', lang=''  , regexp='^[A-Z]%-%d%d%d%d%-[12][90]%d%d$' },
{label='LCCN'        , property='P244' , lang='en', regexp='^[ns][broshj]?%d%d%d%d%d%d%d%d%d?%d?$' }, -- Library of Congress Authorities
{label='GND'        , property='P227' , lang='de', regexp='^[%dX%-]+$'},
{label='SELIBR'      , property='P906' , lang='se', regexp='^%d+$' }, -- National Library of Sweden
{label='SUDOC'      , property='P269' , lang='fr', regexp='^%d%d%d%d%d%d%d%d[%dxX]$' },   
{label='BNF'        , property='P268' , lang='fr', regexp='^%d+%w?$' }, -- Bibliothèque nationale de France
{label='BPN'        , property='P651' , lang='nl', regexp='^%d%d%d%d%d%d%d%d$' }, -- Biografisch Portaal number
{label='NAID'        , property='P1225', lang='en', regexp='^%d+$' }, -- NARA ID (redirect for US National Archives Identifier (P1225))
{label='Museofile'  , property='P539' , lang='fr', regexp='^M%d%d%d%d%-?%d?%d?$' }, --Ministry of Culture (France)
{label='NDL'        , property='P349' , lang='ja', regexp='^0?%d%d%d%d%d%d%d%d$' }, -- National Diet Library (of Japan)
{label='NLA'        , property='P409' , lang='en', regexp='^[1-9]%d*$' }, -- National Library of Australia
{label='BIBSYS'      , property='P1015', lang='no', regexp='^%d+$' }, -- Norwegian information system BIBSYS
{label='HDS'        , property='P902' , lang='de', regexp='^[1-9]%d%d?%d?%d?%d?$' },  -- Historical Dictionary of Switzerland
{label='MusicBrainz' , property='P434' , lang='en', regexp='^[-%x]+$' },
{label='MGP'        , property='P549' , lang='en', regexp='^%d%d?%d?%d?%d?%d?$' },  -- Mathematics Genealogy Project
{label='NCL'        , property='P1048', lang='zh', regexp='^%d+$' },  --National Central Library (Taiwan)
{label='NKC'        , property='P691' , lang='cs', regexp='^%l%l%l?%l?%d%d%d?%d?%d?%d?%d?%d?%d?%d?%d?%d?%d?%d?$' },  --National Library of the Czech Republic
{label='Léonore'    , property='P640' , lang='fr', regexp='^[LHC%/%d]+$' },  
{label='SBN'        , property='P396' , lang='it'},  -- Istituto Centrale per il Catalogo Unico /  National Library Service (SBN) of Italy
{label='RSL'        , property='P947' , lang='ru', regexp='^%d%d%d%d%d%d%d%d%d$' },  --Russian State Library
{label='Botanist'    , property='P428' , lang='en' },
{label='US Congress' , property='P1157', lang='en', regexp='^%u00[01]%d%d%d' },
{label='BNE'        , property='P950' , lang='es', regexp='' }, --Biblioteca Nacional de España
{label='CALIS'      , property='P270' , lang='zh'}, --China Academic Library and Information
{label='CiNii'      , property='P271' , lang='jp', regexp='^DA%d%d%d%d%d%d%d[%dX]$' },
{label='TLS'        , property='P1362', lang='de', regexp='' }, -- Theaterlexikon der Schweiz
{label='SIKART'      , property='P781' , lang='de', regexp='^%d%d%d%d%d%d%d%d?%d?%d?$' }, -- Swiss
{label='NLP'        , property='P1695', lang='pl', regexp='' }, -- National Library of Poland
{label='WGA'        , property='P1882', lang='en', regexp='' }, -- Web Gallery of Art
{label='KulturNav'  , property='P1248', lang='no', regexp='' },
{label='RKD'        , property='P650' , lang='nl', regexp='^[1-9]%d%d?%d?%d?%d?$' }, --Netherlands Institute for Art History#Online artist pages
{label='autores.uy'  , property='P2558', lang='es', regexp='^[1-9]%d?%d?%d?%d?$' },  --autores.uy
{label='NLI'        , property='P949' , lang='he', regexp='^%d%d%d%d%d%d%d%d%d$' },  --National Library of Israel ID
 
{label='FIDE'        , property='P1440', lang='en', regexp='' }, -- FIDE database for chess players
{label='Chess Games' , property='P1665', lang='en', regexp='' }, -- Chess Games
 
{label='ISSN'        , property='P236',  lang='', regexp='' }, -- P1629: International Standard Serial Number
{label='OSM'        , property='P402',  lang='', regexp='' },  -- P1629: OpenStreetMap
{label='Joconde'    , property='P347',  lang='fr', regexp='' }, -- Joconde ID
{label='Rijksmonument',property='P359',  lang='nl', regexp='' }, -- Rijksmonument ID
{label='IMO'        , property='P458',  lang='', regexp='' }, --IMO ship number
{label='BNCF'        , property='P508',  lang='it', regexp='' }, -- BNCF Thesaurus ID
{label='MMSI'        , property='P587',  lang='', regexp='' }, -- P1629: Maritime Mobile Service Identity
{label='Open Library', property='P648',  lang='', regexp='' }, -- P1629: Open Library
{label='NRHP'        , property='P649',  lang='en', regexp='' }, -- NRHP reference number
{label='DBNL'        , property='P723',  lang='', regexp='' }, -- DBNL author ID
{label='Europeana'  , property='P727',  lang='', regexp='' }, -- Europeana ID
{label='UNESCO'      , property='P757',  lang='', regexp='' }, -- World Heritage Site ID
{label='BIC'        , property='P808',  lang='', regexp='' }, -- Bien de Interés Cultural (BIC) code
{label='LIR'        , property='P886',  lang='', regexp='' }, -- LIR
{label='BNR'        , property='P1003', lang='ro', regexp='' }, -- NLR (Romania) ID
{label='Koninklijke' , property='P1006', lang='nl', regexp='' }, -- National Thesaurus for Author Names ID
{label='Atlas'      , property='P1212', lang='', regexp='' }, -- Atlas ID
{label='Historic England', property='P1216', lang='en', regexp='' }, -- National Heritage List for England number
 
{label='Oxford Dict.', property='P1415', lang='en', regexp='' }, -- Oxford Dictionary of National Biography ID
{label='kulturnoe-nasledie', property='P1483', lang='ru', regexp='' },  -- kulturnoe-nasledie.ru ID
{label='Catalunya'  , property='P1600', lang='ca', regexp='' }, -- Inventari del Patrimoni Arquitectònic de Catalunya code
{label='COAM'        , property='P2917', lang='es', regexp='' }, -- COAM structure ID
{label='SIMBAD'      , property='P3083', lang='fr', regexp='' }, -- SIMBAD ID
{label='JCyL'        , property='P3177', lang='es', regexp='' }, -- Patrimonio Web JCyL ID
{label='Zaragoza'    , property='P3178', lang='es', regexp='' },  -- Zaragoza monument ID
{label='BDI'        , property='P3318', lang='es', regexp='' }, -- Patrimonio Inmueble de Andalucía ID
{label='SIPCA'      , property='P3580', lang='es', regexp='' }, -- SIPCA code
{label='DOCOMOMO'    , property='P3758', lang='', regexp='' }, -- DOCOMOMO Ibérico ID
{label='Czech Monument', property='P4075', lang='cz', regexp='' }, -- Czech Monument Catalogue Number
{label='MEG'        , property='P4157', lang='ch', regexp='' }, -- P1629: Musée d'ethnographie de Genève
{label='Enciclopédia Itaú Cultural' , property='P4399', lang='pt_br', regexp='' }, -- Enciclopédia Itaú Cultural ID
{label='Monumentos de São Paulo'    , property='P4360', lang='pt_br', regexp='' }, -- Monumentos de São Paulo ID
{label='Infopatrimônio'            , property='P4372', lang='pt_br', regexp='' }, -- Infopatrimônio ID
{label="Musée d'Orsay"              , property='P4659', lang='fr'  , regexp='' }, -- Musée d'Orsay artwork ID
{label='MuBE'                      , property='P4721', lang='pt_br', regexp='' }, -- MuBE Virtual ID
{label='Hispania Nostra'            , property='P4868', lang='es'  , regexp='' }, -- Hispania Nostra Red List ID
{label='NLK'            , property='P5034', lang='ko'  , regexp='' }, -- National Library of Korea ID
}
 
-- ==================================================
-- === External functions ===========================
-- ==================================================
local p = {}
 
function p.getAuthorityControlTag( lang )
-- get a localized interwiki link to article "Authority Control"
local field_name = "[[w:en:Help:Authority control|Authority control]]" -- hardwire the default
if lang~='en' then
local Wikidata = require("Module:Wikidata label")    -- used for creation of name based on wikidata
field_name = Wikidata._getLabel("Q36524", lang, "wikipedia")
end
end
return field_name
end
end
 
local ids = {}
-- ==================================================
if qid then
function p._authorityControl(entity, args, lang, length)
for _, statement in ipairs(mw.wikibase.getBestStatements(qid, 'P'..id.property)) do
-- INPUTS:
if statement.mainsnak.datavalue then
--  * entity - wikidata entity if already created or nil. If provided than you should still provide args.Wikidata
local val = statement.mainsnak.datavalue.value
--  * args  - structure with identifier fields: args.VIAF, args.LCCN, args.Wikidata, etc.
if val then
--  * lang  - language code
local namedas = getquals(statement, 1810) or getquals(statement, 742) or ''
--  * length - maximum length of the identifier array, or number of identifiers to display
table.insert(ids, {id=val, name=namedas})
-- OUTPUTS:
end end end end
--  * results - wikicode string equivalent to {{Authority control|...|bare=1 }} call
local links
--  * cats    - wikicode with maintenance categories
if ids[1] then
 
links = mw.html.create('li'):node(_makelink(id, ids[1], false, qid))
  -- count custom parameters (not pulled from Wikidata)
if ids[2] then
local nCustomParam = 0
local sublinks = mw.html.create('ul')
for _,params in ipairs( conf ) do
for n = 2, #ids do
if (args[params.label]~=nil) then
sublinks:tag('li'):node(_makelink(id, ids[n], n, qid)):done()
nCustomParam = nCustomParam + 1
end
end
links:node(sublinks)
end
end
end
-- Get entity - record of wikidata related to a single item
return links
local q = args.wikidata
end
if not entity and q then
 
entity = mw.wikibase.getEntity(q)
p.authorityControl = function(frame)
--[[==================================]]
--[[              Main              ]]
--[[==================================]]
local resolveQID = function(qid)
if qid then
qid = 'Q' .. mw.ustring.gsub(qid, '^[Qq]', '')
if mw.wikibase.isValidEntityId(qid) and mw.wikibase.entityExists(qid) then
local sitelink = mw.wikibase.getSitelink(qid)
if sitelink then
return mw.wikibase.getEntityIdForTitle(sitelink) or mw.wikibase.getEntity(qid).id
end
return mw.wikibase.getEntity(qid).id
end end end
local conf = config.config
local parentArgs = frame:getParent().args
local auxCats = ''
local rct = false -- boolean to track if there are any links to be returned
local qid, topic
if namespace==0 then
qid = mw.wikibase.getEntityIdForCurrentPage()
end
if qid then -- article is connected to a Wikidata item
if parentArgs.qid and resolveQID(parentArgs.qid)~=qid then -- non-matching qid parameter
auxCats = auxCats .. needsAttention('D')
end
end
else -- page is not connected to any Wikidata item
-- Check if this is category item
qid = resolveQID(parentArgs.qid) -- check qid parameter if no wikidata item is connected
local cats = '' -- categories (mismatching and missing)
if qid then -- qid parameter is valid, set topic to display
if entity and entity.claims and entity.claims.P31 then  
topic = mw.wikibase.getLabel(qid)
for _, statement in pairs( entity.claims.P31) do
if topic then
if (statement.mainsnak.snaktype == "value") and (statement.mainsnak.datavalue.value.id == 'Q4167836') then -- P31 == Wikimedia category
if mw.ustring.lower(title.subpageText)==mw.ustring.lower(topic) then -- suppress topic display if subpagename equals topic up to case change
cats = '[[Category:Wrong Wikidata ID in authority control data: category item]]'
topic = nil
end
end
if (statement.mainsnak.snaktype == "value") and (statement.mainsnak.datavalue.value.id == 'Q4167410') then -- P31 == Wikimedia disambiguation page
if topic and mw.wikibase.getSitelink(qid) then -- make wikilink to article
cats = '[[Category:Wrong Wikidata ID in authority control data: disambiguation item]]'
topic = wikilink(mw.wikibase.getSitelink(qid), topic)
end
end
else
auxCats = auxCats .. needsAttention('L')
end
end
elseif parentArgs.qid and parentArgs.qid~='' then -- invalid qid has been supplied, add to tracking cat
auxCats = auxCats .. needsAttention('Q')
end
end
 
end
--compare provided arguments with Wikidata identifiers
local qids = {} -- setup any additional QIDs
local data = {} -- structure similar to "args" but filled with wikidata data
if parentArgs.additional=='auto' and qid then  -- check P527 for parts to add additional qids
for _,params in ipairs( conf ) do
local checkparts = function(property)
local label = string.lower(params.label)
local parts = mw.wikibase.getBestStatements(qid, property)
data[label] = nil
if parts then
if entity and entity.claims and params.property and entity.claims[params.property] then -- if we have wikidata item and item has the property
for _, part in ipairs(parts) do
-- capture all Wikidata values for the identifier
if part.mainsnak.datavalue and part.mainsnak.datavalue.value.id then
--for _, statement in pairs( entity.claims[params.property]) do
local resolvedqid = resolveQID(part.mainsnak.datavalue.value.id)
for _, statement in pairs( entity:getBestStatements( params.property )) do
if resolvedqid then
if (statement.mainsnak.snaktype == "value") then -- or if statement.mainsnak.datavalue then  
table.insert(qids,resolvedqid)
local v = statement.mainsnak.datavalue.value
end end end end end
if data[label]==nil then
for _, part in ipairs(config.auto_additional) do
data[label] = v         -- save the first value
checkparts('P' .. part)
end
end
if args[label] == v then -- match between template and wikidata identifiers
elseif parentArgs.additional and parentArgs.additional~='' then
data[label] = ''       -- ignore identifier from wikidata
for _, v in ipairs(mw.text.split(parentArgs.additional, '%s*,%s*')) do
break 
v = resolveQID(v)
end
if v then
end
if v==qid then -- duplicate of qid parameter
auxCats = auxCats .. needsAttention('R')
end
end
table.insert(qids, v)
else -- invalid QID specified
auxCats = auxCats .. needsAttention('A')
end
end
end
end
end
local numsections, sections = 0, {}
for _, _ in ipairs(config.sections) do -- count number of regular sections
numsections = numsections + 1
end
for _ = 1, #qids+numsections do
table.insert(sections, {})
end


--Create string with all the identifiers listed
-- check which identifiers to show/suppress in template
local results1 = {} -- high priority list
local show, show_all_unsuppressed = {}, true
local results2 = {} -- low  priority list
local stripP = function(pid) --strip P from property number
properties.P214.item = 'Q54919';  -- hardwire link to VIAF
if pid:match('^[Pp]%d+$') then
local today = '+' .. os.date('!%F') .. 'T00:00:00Z/11'
pid = mw.ustring.gsub(pid, '[Pp]', '')
local TransStr = 'https://tools.wmflabs.org/quickstatements/index_old.html#v1=%s|%s|%%22%s%%22|S143|Q565|S813|'.. today -- QuickStatementts URL
TransStr = '<span class=\"plainlinks\" title=\"Click (+) to copy to wikidata\">['.. TransStr .. ' (+)]</span>'
for _,params in ipairs( conf ) do
local label = string.lower(params.label)
local val1 = args[label] -- identifier value provided to the template
local val2 = data[label] -- identifier value pulled from wikidata
if val1 or val2 then
local P = properties[params.property] -- properties of wikidata identifier propertyc
-- name_link - link for the identifier name
local name_link = getIdentifierNameLink( lang, P.item, P.issuedBy, params.label )
-- val_link - identifier value or values
local transfer = ''
local val3 = string.gsub(val1 or '', ' ', '' ) -- remove spaces
local val_link
if not val1 then
val_link = getIdentifierValLink(val2, P.URL_format, params, 'blue') -- wikidata only no local identifier
elseif val2=='' then
val_link = getIdentifierValLink(val1, P.URL_format, params, 'magenta') -- match was found
elseif val2 then
val_link = getIdentifierValLink(val1, P.URL_format, params, 'darkgreen') .. "/"..getIdentifierValLink(val2, P.URL_format, params, 'blue')
cats  = string.format("%s[[Category:Pages using authority control with identifiers mismatching Wikidata]]\n", cats)
transfer  = string.format(TransStr, q, params.property, val3)
elseif not val2 and entity then
val_link = getIdentifierValLink(val1, P.URL_format, params, 'darkgreen')
cats  = string.format("%s[[Category:Pages using authority control with identifiers missing from Wikidata]]\n", cats)
transfer  = string.format(TransStr, q, params.property, val3)
else
val_link = getIdentifierValLink(val1, P.URL_format, params, 'blue') -- local identifier and no wikidata q-code
end
 
-- combine them all
local lineStr = string.format("\n*%s:&thinsp;<span class=\"uid\">%s</span>%s", name_link, val_link, transfer)
if (params.lang==lang) or (params.lang=='') then
table.insert(results1, lineStr) -- add to high priority list
else
table.insert(results2, lineStr) -- add to low priority list
end
end
end -- for all sources
-- merge high and low priority lists, trim them if needed and convert to string
--table.insert(results1, "\n*End list 1") -- for debuging
--table.insert(results2, "\n*End list 2")
for _,v in pairs(results2) do table.insert(results1, v) end
local results = table.concat(results1, "", 1, math.min(#results1, length or #results1))
-- Add Link to wikidata
if q then
results = string.format("\n*[[File:Wikidata-logo.svg|20px|wikidata:%s|link=wikidata:%s]]: [[d:%s|%s]]%s",q,q,q,q,results)
end
end
if pid:match('^%d+$') then
-- Add link to Worldcat
return tonumber(pid)
if (args.worldcatid==nil and (args.lccn or data.lccn)) then
args.worldcatid = 'lccn-' .. (args.lccn or data.lccn)
end
end
if args.worldcatid  then
end
results = string.format("%s\n*<span class=\"uid\">[//www.worldcat.org/identities/%s WorldCat]</span>", results, args.worldcatid)
local addshowlist = function(list)
end
if list and list~='' then
for _, v in ipairs(mw.text.split(string.lower(list), '%s*,%s*')) do
-- Add maintenance categories
local vprop = stripP(v)
if q == nil then
if vprop then -- e.g. show=P214 to show one particular property
cats = string.format("%s[[Category:Pages using authority control without Wikidata link]]\n", cats)
show[vprop] = true
end
else -- e.g. show=arts to use whitelist
if nCustomParam>0 then
if config.whitelists[v] then
if cats=='' and entity ~= nil then
for _, w in ipairs(config.whitelists[v].properties) do
cats = string.format("%s[[Category:Pages using authority control with all identifiers matching Wikidata]]\n", cats)
show[w] = true
end
end end end end
if string.find(results, "<span style=\"color:red\">") then
show_all_unsuppressed = false
cats = string.format("%s[[Category:Pages using authority control with badly formated identifier]]\n", cats)
end end
addshowlist(frame.args.show) -- check show parameter on wrapper template
addshowlist(parentArgs.show) -- check show parameter on article
addshowlist(parentArgs.country) -- check country parameter on article
if parentArgs.suppress then
local suppresslist = mw.text.split(parentArgs.suppress, '%s*,%s*') -- split parameter by comma
for _, v in ipairs(suppresslist) do
v = stripP(v)
if v then
show[v] = false
auxCats = auxCats .. wikilink(config.i18n.category .. ':' .. config.i18n.suppressedcat)
else
auxCats = auxCats .. needsAttention('P')
end
end
end
end
end


-- return results
local makeSections = function(qid, addit)
if results~='' then -- if there are any results than wrap them in <div> tag
for _, id in ipairs(conf) do
results  = string.format('<div class="hlist">%s\n</div>', results)
if id.suppressedbyproperty then
for _, property in ipairs(id.suppressedbyproperty) do
if show[property]=='used' then -- property is in use
show[id.property] = false -- suppressed by another property
end end end
if show[id.property]==nil then
show[id.property] = show_all_unsuppressed
end
if show[id.property] then
local links = _makelinks(id, qid)
if links then
table.insert(
sections[addit or id.section],
links
)
show[id.property] = 'used'
rct = true
end end end end
local pencil = function(qid)
if qid then
return require('Module:EditAtWikidata')._showMessage{
pid = 'identifiers',
qid = qid
}
else
return ''
end
end
return results, cats
end
makeSections(qid, false)
for c = 1, #qids do
makeSections(qids[c], numsections+c)
end
end


--================================================
--configure Navbox
function p.authorityControl(frame)
local outString = ''
-- prepare arguments
if rct then -- there is at least one link to display
local args = {}
local Navbox = require('Module:Navbox')
for name, value in pairs( frame.args ) do  
local sect, lastsect = 0, 0
if value ~= '' then -- nuke empty strings
local navboxArgs = {
args[string.lower(name)] = value -- make it case independent
name  = 'Authority control',
navboxclass = 'authority-control',
bodyclass = 'hlist',
state = parentArgs.state or config.i18n.autocollapse,
navbar = 'off'
}
for c = 1, numsections+#qids do
if #sections[c]>0 then -- section is non-empty
sect = sect + 1
lastsect = c
local sectname
if c<=numsections then -- regular section
sectname = config.sections[c].name
else -- section from additional qid
local qid = qids[c-numsections]
local label, sitelink = mw.wikibase.getLabel(qid), mw.wikibase.getSitelink(qid)
if label then
if sitelink then
local target = mw.title.new(sitelink)
if target==title or (target.isRedirect and target.redirectTarget==title) then -- do not link
sectname = label
else -- make wikilink to article
sectname = wikilink(sitelink, label)
end
else
sectname = label
end
else
auxCats = auxCats .. needsAttention('L')
sectname = qid
end
sectname = sectname .. pencil(qid)
end
navboxArgs['group' .. c] = sectname
local list = mw.html.create('ul')
for _, link in ipairs(sections[c]) do
list:node(link)
end
navboxArgs['list' .. c] = tostring(list)
end
end
end
end
for name, value in pairs( frame:getParent().args ) do
if topic then -- display in expanded form with topic
if value ~= '' then -- nuke empty strings
navboxArgs.title = config.i18n.aclink .. ' &ndash; ' .. topic .. pencil(qid)
args[string.lower(name)] = value
elseif sect==1 then -- special display when only one section
if lastsect<=numsections then
if config.sections[lastsect].hidelabelwhenalone then -- no special label when only general or other IDs are present
navboxArgs['group' .. lastsect] = config.i18n.aclink .. pencil(qid)
else -- other regular section
navboxArgs['group' .. lastsect] = config.i18n.aclink .. ': ' .. navboxArgs['group' .. lastsect] .. pencil(qid)
end
else -- section from additional qid
navboxArgs['group' .. lastsect] = config.i18n.aclink .. ': ' .. navboxArgs['group' .. lastsect]
end
end
else -- add title to navbox
navboxArgs.title = config.i18n.aclink .. pencil(qid)
end
end
if not (args.lang and mw.language.isSupportedLanguage(args.lang)) then
outString = Navbox._navbox(navboxArgs)
args.lang = frame:callParserFunction( "int", "lang" ) -- get user's chosen language
end
end
 
local yesno = require('Module:Yesno')
if parentArgs.state
local bare  = yesno(args.bare,false)       
and parentArgs.state~=''
and parentArgs.state~=config.i18n.collapsed
-- Convert template arguments to the same format as used on wikidata
and parentArgs.state~=config.i18n.expanded
if (args.gnd == nil or args.gnd == '') and args.pnd ~= nil and args.pnd ~= '' then
and parentArgs.state~=config.i18n.autocollapse then --invalid state parameter
args.gnd = args.pnd --redirect PND to GND
auxCats = auxCats .. needsAttention('S')
end
end
if (args.bnf and args.bnf ~= '') then
if testcases then
args.bnf = string.sub(args.bnf, 3) -- trim first 2 characters
auxCats = mw.ustring.gsub(auxCats, '(%[%[)(' .. config.i18n.category .. ')', '%1:%2') --for easier checking
end
end
if (args.isni and args.isni ~= '') then -- group in sets of 4
 
args.isni = string.sub(args.isni, 1, 4).." "..string.sub(args.isni,5,8).." "..string.sub(args.isni,9,12).." "..string.sub(args.isni,13,16)
--out
end
outString = outString .. auxCats
args.lccn = fixLCCN(args.lccn)
if namespace~=0 then
args.wikidata = args.wikidata or args.q or nil
outString = mw.ustring.gsub(outString, '(%[%[)(' .. config.i18n.category .. ':' .. config.i18n.Articles .. ')([^%|%]]+)%|?[^%|%]]*(%]%])','%1:%2%3%4')
outString = mw.ustring.gsub(outString, '(%[%[)(' .. config.i18n.category .. ':' .. config.i18n.All_articles .. ')([^%|%]]+)%|?[^%|%]]*(%]%])','%1:%2%3%4')
-- call the inner "core" function
end
local results, cats = p._authorityControl(nil, args, args.lang, args.length)
local check = require('Module:Check for unknown parameters')._check
local namespace = mw.title.getCurrentTitle().namespace
local sortkey
if (namespace == 2 or namespace == 6 or namespace == 10 or namespace == 828 or math.fmod(namespace,2)==1) then
if namespace==0 then
cats = '' -- lets not add categories to user pages, files, templates, modules or talk pages and concentrate on templates and categories instead
sortkey = '*' .. title.text
end
else
sortkey = title.fullText
--package results as a infobox if not "bare"
end
if not bare then
outString = outString .. check({
-- Get field name for authority control
['unknown'] = wikilink(config.i18n.category .. ':' .. config.i18n.pageswithparams, sortkey),
local field_name = p.getAuthorityControlTag(args.lang)
['preview'] = config.i18n.previewwarning, 'show', 'country', 'suppress', 'additional', 'qid', 'state'
}, parentArgs)
return outString
end


-- build table
p.makelink = function(id, qid)
results = string.format('<tr><td class="type fileinfo-paramfield">%s</td><td>\n%s\n</td></tr>', field_name, results)
return _makelinks(id, qid)
local style = frame:expandTemplate{ title="Infobar-Layout", args={ ["lang"] = args.lang, ["class"] = 'commons-file-information-table' } }
results = string.format('<table %s>%s</table>\n', style, results)
else
results = string.format('\n%s\n', results)
end
return results..cats
end
end


return p
return p

2024年10月12日 (土) 19:11時点における版

このモジュールについての説明文ページを モジュール:Authority control/doc に作成できます

require('strict')
local p = {}
local frame = mw.getCurrentFrame()
local config_file = frame.args.config and frame.args.config~='' and ('/' .. frame.args.config) or ''
local config = mw.loadData('Module:Authority control/config' .. config_file)
local title = mw.title.getCurrentTitle()
local namespace = title.namespace
local testcases = title.subpageText == config.i18n.testcases

local wikilink = function(target, label)
	return label and '[[' .. target .. '|' .. label .. ']]' or '[[' .. target .. ']]'
end

local needsAttention = function(sortkey)
	return wikilink(config.i18n.category .. ':' .. config.i18n.attentioncat, sortkey .. title.text)
end

local addCat = function(cat, sortkey)
	if cat and cat~='' and (namespace==0 or namespace==14 or testcases) then
		local redlinkcat = ''
		if testcases==false then
			local success, exists = pcall(function() return mw.title.new(cat, 14).exists end)
			if success and not exists then 
				redlinkcat = needsAttention('N')
			end
		end
		return wikilink(config.i18n.category..':'..cat, sortkey and sortkey..title.text) .. redlinkcat
	else
		return ''
	end
end

local tooltip = function(text, label)
	if label and label~='' then
		return frame:expandTemplate{
			title = 'Tooltip',
			args = {text, label}
		}
	else
		return text
	end
end

local _makelink = function(id, val, additional, qid) --validate values and create a link
	local link = mw.html.create('span'):addClass('uid')
	if not additional and id.prefix then --show prefix on primary value
		link:wikitext(id.prefix .. ': ')
	end
	local valid_value = false
	if id.customlink then -- use function to validate and generate link
		local newlink = require(config.auxiliary)[id.customlink](val.id, additional)
		if newlink then
			link:wikitext(newlink)
			valid_value = true
		end
	else
		if id.pattern then -- check pattern to determine validity
			valid_value = string.match(val.id, '^' .. id.pattern .. '$')
		elseif id.patterns then -- check multiple patterns to determine validity
			for _, pattern in ipairs(id.patterns) do
				valid_value = val.id:match('^' .. pattern .. '$')
				if valid_value then break end
			end
		elseif id.valid then -- use function to determine validity
			valid_value = require(config.auxiliary)[id.valid](val.id)
		else -- no validation possible
			valid_value = val.id
		end
		if valid_value then
			local label = id.label
			if not label or additional then
				label = tostring(additional)
			end
			local newlink
			if id.link then
				valid_value = valid_value:gsub('%%', '%%%%')
				newlink = '[' .. mw.ustring.gsub(id.link, '%$1', valid_value) .. ' ' .. label .. ']'
			else
				newlink = valid_value
			end
			link:wikitext(tooltip(newlink, val.name))
		end
	end
	if valid_value then
		local cat =  id.category and string.format(config.i18n.cat, id.category)
		link:wikitext(addCat(cat))
	else
		local wdlink = qid and wikilink(':wikidata:' .. qid .. '#P' .. id.property) or ''
		local name = mw.wikibase.getLabel('P' .. id.property) or ''
		local tooltip = string.format(
			config.i18n.idnotvalid,
			name,
			val.id
		)
		local cat = id.category and string.format(
			config.i18n.cat,
			config.i18n.faulty .. ' ' .. id.category
		)
		link:wikitext(wikilink('File:' .. config.i18n.warningicon .. '|20px|frameless|link=' .. wdlink, tooltip .. '.'))
			:wikitext(addCat(cat))
			:wikitext(addCat(config.i18n.allfaultycat, name))
	end
	return link
end

local _makelinks = function(id, qid)
--[[==================================]]
--[[            Make links            ]]
--[[==================================]]
local getquals = function(statement, qualid)
	if statement.qualifiers and statement.qualifiers['P'..qualid] then
		return mw.wikibase.renderSnak(statement.qualifiers['P'..qualid][1])
	end
end
local ids = {}
if qid then
	for _, statement in ipairs(mw.wikibase.getBestStatements(qid, 'P'..id.property)) do
		if statement.mainsnak.datavalue then
			local val = statement.mainsnak.datavalue.value
			if val then
				local namedas = getquals(statement, 1810) or getquals(statement, 742) or ''
				table.insert(ids, {id=val, name=namedas})
end end end end
local links
if ids[1] then
	links = mw.html.create('li'):node(_makelink(id, ids[1], false, qid))
	if ids[2] then
		local sublinks = mw.html.create('ul')
		for n = 2, #ids do
			sublinks:tag('li'):node(_makelink(id, ids[n], n, qid)):done()
		end
		links:node(sublinks)
	end
end
return links
end

p.authorityControl = function(frame)
--[[==================================]]
--[[               Main               ]]
--[[==================================]]
local resolveQID = function(qid)
	if qid then
		qid = 'Q' .. mw.ustring.gsub(qid, '^[Qq]', '')
		if mw.wikibase.isValidEntityId(qid) and mw.wikibase.entityExists(qid) then
			local sitelink = mw.wikibase.getSitelink(qid)
			if sitelink then
				return mw.wikibase.getEntityIdForTitle(sitelink) or mw.wikibase.getEntity(qid).id
			end
			return mw.wikibase.getEntity(qid).id
end end end
local conf = config.config
local parentArgs = frame:getParent().args
local auxCats = ''
local rct = false -- boolean to track if there are any links to be returned
local qid, topic
if namespace==0 then
	qid = mw.wikibase.getEntityIdForCurrentPage()
end
if qid then -- article is connected to a Wikidata item
	if parentArgs.qid and resolveQID(parentArgs.qid)~=qid then -- non-matching qid parameter
		auxCats = auxCats .. needsAttention('D')
	end
else -- page is not connected to any Wikidata item
	qid = resolveQID(parentArgs.qid) -- check qid parameter if no wikidata item is connected
	if qid then -- qid parameter is valid, set topic to display
		topic = mw.wikibase.getLabel(qid)
		if topic then
			if mw.ustring.lower(title.subpageText)==mw.ustring.lower(topic) then -- suppress topic display if subpagename equals topic up to case change
				topic = nil
			end
			if topic and mw.wikibase.getSitelink(qid) then -- make wikilink to article
				topic = wikilink(mw.wikibase.getSitelink(qid), topic)
			end
		else
			auxCats = auxCats .. needsAttention('L')
		end
	elseif parentArgs.qid and parentArgs.qid~='' then -- invalid qid has been supplied, add to tracking cat
		auxCats = auxCats .. needsAttention('Q')
	end
end
local qids = {} -- setup any additional QIDs
if parentArgs.additional=='auto' and qid then  -- check P527 for parts to add additional qids
	local checkparts = function(property)
		local parts = mw.wikibase.getBestStatements(qid, property)
		if parts then
			for _, part in ipairs(parts) do
				if part.mainsnak.datavalue and part.mainsnak.datavalue.value.id then
					local resolvedqid = resolveQID(part.mainsnak.datavalue.value.id)
					if resolvedqid then
						table.insert(qids,resolvedqid)
	end end end end end
	for _, part in ipairs(config.auto_additional) do
		checkparts('P' .. part)
	end
elseif parentArgs.additional and parentArgs.additional~='' then
	for _, v in ipairs(mw.text.split(parentArgs.additional, '%s*,%s*')) do
		v = resolveQID(v)
		if v then
			if v==qid then -- duplicate of qid parameter
				auxCats = auxCats .. needsAttention('R')
			end
			table.insert(qids, v)
		else -- invalid QID specified
			auxCats = auxCats .. needsAttention('A')
		end
	end
end
local numsections, sections = 0, {}
for _, _ in ipairs(config.sections) do -- count number of regular sections
	numsections = numsections + 1
end
for _ = 1, #qids+numsections do
	table.insert(sections, {})
end

-- check which identifiers to show/suppress in template
local show, show_all_unsuppressed = {}, true
local stripP = function(pid) --strip P from property number
	if pid:match('^[Pp]%d+$') then
		pid = mw.ustring.gsub(pid, '[Pp]', '')
	end
	if pid:match('^%d+$') then
		return tonumber(pid)
	end
end
local addshowlist = function(list)
	if list and list~='' then
		for _, v in ipairs(mw.text.split(string.lower(list), '%s*,%s*')) do
			local vprop = stripP(v)
			if vprop then -- e.g. show=P214 to show one particular property
				show[vprop] = true
			else -- e.g. show=arts to use whitelist
				if config.whitelists[v] then
					for _, w in ipairs(config.whitelists[v].properties) do
						show[w] = true
		end end end end
		show_all_unsuppressed = false
end end
addshowlist(frame.args.show) -- check show parameter on wrapper template
addshowlist(parentArgs.show) -- check show parameter on article
addshowlist(parentArgs.country) -- check country parameter on article
if parentArgs.suppress then
	local suppresslist = mw.text.split(parentArgs.suppress, '%s*,%s*') -- split parameter by comma
	for _, v in ipairs(suppresslist) do
		v = stripP(v)
		if v then
			show[v] = false
			auxCats = auxCats .. wikilink(config.i18n.category .. ':' .. config.i18n.suppressedcat)
		else
			auxCats = auxCats .. needsAttention('P')
		end
	end
end

local makeSections = function(qid, addit)
	for _, id in ipairs(conf) do
		if id.suppressedbyproperty then
			for _, property in ipairs(id.suppressedbyproperty) do
				if show[property]=='used' then -- property is in use
					show[id.property] = false -- suppressed by another property
		end end end
		if show[id.property]==nil then
			show[id.property] = show_all_unsuppressed
		end
		if show[id.property] then
			local links = _makelinks(id, qid)
			if links then
				table.insert(
					sections[addit or id.section],
					links
				)
				show[id.property] = 'used'
				rct = true
end end end end
local pencil = function(qid)
	if qid then
		return require('Module:EditAtWikidata')._showMessage{
			pid = 'identifiers',
			qid = qid
		}
	else
		return ''
	end
end
makeSections(qid, false)
for c = 1, #qids do
	makeSections(qids[c], numsections+c)
end

--configure Navbox
local outString = ''
if rct then -- there is at least one link to display
	local Navbox = require('Module:Navbox')
	local sect, lastsect = 0, 0
	local navboxArgs = {
		name  = 'Authority control',
		navboxclass = 'authority-control',
		bodyclass = 'hlist',
		state = parentArgs.state or config.i18n.autocollapse,
		navbar = 'off'
	}
	for c = 1, numsections+#qids do
		if #sections[c]>0 then -- section is non-empty
			sect = sect + 1
			lastsect = c
			local sectname
			if c<=numsections then -- regular section
				sectname = config.sections[c].name
			else -- section from additional qid
				local qid = qids[c-numsections]
				local label, sitelink = mw.wikibase.getLabel(qid), mw.wikibase.getSitelink(qid)
				if label then
					if sitelink then
						local target = mw.title.new(sitelink)
						if target==title or (target.isRedirect and target.redirectTarget==title) then -- do not link
							sectname = label
						else -- make wikilink to article
							sectname = wikilink(sitelink, label)
						end
					else
						sectname = label
					end
				else
					auxCats = auxCats .. needsAttention('L')
					sectname = qid
				end
				sectname = sectname .. pencil(qid)
			end
			navboxArgs['group' .. c] = sectname
			local list = mw.html.create('ul')
			for _, link in ipairs(sections[c]) do
				list:node(link)
			end
			navboxArgs['list' .. c] = tostring(list)
		end
	end
	if topic then -- display in expanded form with topic
		navboxArgs.title = config.i18n.aclink .. ' &ndash; ' .. topic .. pencil(qid)
	elseif sect==1 then -- special display when only one section
		if lastsect<=numsections then
			if config.sections[lastsect].hidelabelwhenalone then -- no special label when only general or other IDs are present
				navboxArgs['group' .. lastsect] = config.i18n.aclink .. pencil(qid)
			else -- other regular section
				navboxArgs['group' .. lastsect] = config.i18n.aclink .. ': ' .. navboxArgs['group' .. lastsect] .. pencil(qid)
			end
		else -- section from additional qid
			navboxArgs['group' .. lastsect] = config.i18n.aclink .. ': ' .. navboxArgs['group' .. lastsect]
		end
	else -- add title to navbox
		navboxArgs.title = config.i18n.aclink .. pencil(qid)
	end
	outString = Navbox._navbox(navboxArgs)
end

if parentArgs.state
	and parentArgs.state~=''
	and parentArgs.state~=config.i18n.collapsed
	and parentArgs.state~=config.i18n.expanded
	and parentArgs.state~=config.i18n.autocollapse then --invalid state parameter
	auxCats = auxCats .. needsAttention('S')
end
if testcases then
	auxCats = mw.ustring.gsub(auxCats, '(%[%[)(' .. config.i18n.category .. ')', '%1:%2') --for easier checking
end

--out
outString = outString .. auxCats
if namespace~=0 then
	outString = mw.ustring.gsub(outString, '(%[%[)(' .. config.i18n.category .. ':' .. config.i18n.Articles .. ')([^%|%]]+)%|?[^%|%]]*(%]%])','%1:%2%3%4')
	outString = mw.ustring.gsub(outString, '(%[%[)(' .. config.i18n.category .. ':' .. config.i18n.All_articles .. ')([^%|%]]+)%|?[^%|%]]*(%]%])','%1:%2%3%4')
end
local check = require('Module:Check for unknown parameters')._check
local sortkey
if namespace==0 then
	sortkey = '*' .. title.text
else
	sortkey = title.fullText
end
outString = outString .. check({
	['unknown'] = wikilink(config.i18n.category .. ':' .. config.i18n.pageswithparams, sortkey),
	['preview'] = config.i18n.previewwarning, 'show', 'country', 'suppress', 'additional', 'qid', 'state'
	}, parentArgs)
return outString
end

p.makelink = function(id, qid)
	return _makelinks(id, qid)
end

return p