Module:WikidataIB and Module:WikidataIB/sandbox: Difference between pages

(Difference between pages)
Jump to navigation Jump to search
Page 1
Page 2
m (1 revision imported)
 
m (1 revision imported)
 
Line 1: Line 1:
-- Version: 2021-02-06
-- Module to implement use of a blacklist and whitelist for infobox fields
-- Module to implement use of a blacklist and whitelist for infobox fields
-- Can take a named parameter |qid which is the Wikidata ID for the article
-- Can take a named parameter |qid which is the Wikidata ID for the article
Line 11: Line 10:
-- whitelist is passed in named parameter |fetchwikidata (or |fwd)
-- whitelist is passed in named parameter |fetchwikidata (or |fwd)


require("strict")
local p = {}
local p = {}


local cdate -- initialise as nil and only load _complex_date function if needed
local cdate -- initialise as nil and only load _complex_date function if needed
-- Module:Complex date is loaded lazily and has the following dependencies:
-- [[Module:Complex date]] is loaded lazily and has the following dependencies:
-- Module:Calendar
-- Module:I18n/complex date, Module:ISOdate, Module:DateI18n (alternative for Module:Date),
-- Module:ISOdate
-- Module:Formatnum, Module:I18n/date, Module:Yesno, Module:Linguistic, Module:Calendar
-- Module:DateI18n
-- Module:I18n/complex date
-- Module:Ordinal
-- Module:I18n/ordinal
-- Module:Yesno
-- Module:Formatnum
-- Module:Linguistic
--
-- The following, taken from https://www.mediawiki.org/wiki/Wikibase/DataModel#Dates_and_times,
-- The following, taken from https://www.mediawiki.org/wiki/Wikibase/DataModel#Dates_and_times,
-- is needed to use Module:Complex date which seemingly requires date precision as a string.
-- is needed to use Module:Complex date which seemingly requires date precision as a string.
Line 160: Line 150:
langobj = mw.language.new( langcode )
langobj = mw.language.new( langcode )
else
else
langcode = mw.getCurrentFrame():callParserFunction('int', {'lang'})
langcode = mw.getCurrentFrame():preprocess( '{{int:lang}}' )
if mw.language.isKnownLanguageTag(langcode) then
if mw.language.isKnownLanguageTag(langcode) then
langobj = mw.language.new( langcode )
langobj = mw.language.new( langcode )
Line 574: Line 564:
-- shortname is boolean switch to use P1813 (short name) instead of label if true.
-- shortname is boolean switch to use P1813 (short name) instead of label if true.
-- lang is the current language code.
-- lang is the current language code.
-- uselbl is boolean switch to force display of the label instead of the sitelink (default: false)
-- linkredir is boolean switch to allow linking to a redirect (default: false)
-- formatvalue is boolean switch to allow formatting as italics or quoted (default: false)
-------------------------------------------------------------------------------
-------------------------------------------------------------------------------
-- Dependencies: labelOrId(); donotlink[]
-- Dependencies: labelOrId(); donotlink[]
-------------------------------------------------------------------------------
-------------------------------------------------------------------------------
local linkedItem = function(id, args)
local linkedItem = function(id, lprefix, lpostfix, prefix, postfix, dtxt, shortname, lang)
local lprefix = (args.lp or args.lprefix or args.linkprefix or ""):gsub('"', '') -- toughen against nil values passed
lprefix = lprefix or "" -- toughen against nil values passed
local lpostfix = (args.lpostfix or ""):gsub('"', '')
lpostfix = lpostfix or ""
local prefix = (args.prefix or ""):gsub('"', '')
prefix = prefix or ""
local postfix = (args.postfix or ""):gsub('"', '')
postfix = postfix or ""
local dtxt = args.dtxt
lang = lang or "en" -- fallback to default if missing
local shortname = args.shortname
local lang = args.lang or "en" -- fallback to default if missing
local uselbl = args.uselabel or args.uselbl
uselbl = parseParam(uselbl, false)
local linkredir = args.linkredir
linkredir = parseParam(linkredir, false)
local formatvalue = args.formatvalue or args.fv
formatvalue = parseParam(formatvalue, false)
-- see if item might need italics or quotes
-- see if item might need italics or quotes
local fmt = ""
local fmt = ""
if next(formats) and formatvalue then
for k, v in ipairs( mw.wikibase.getBestStatements(id, "P31") ) do
for k, v in ipairs( mw.wikibase.getBestStatements(id, "P31") ) do
if v.mainsnak.datavalue and formats[v.mainsnak.datavalue.value.id] then
if v.mainsnak.datavalue and formats[v.mainsnak.datavalue.value.id] then
fmt = formats[v.mainsnak.datavalue.value.id]
fmt = formats[v.mainsnak.datavalue.value.id]
break -- pick the first match
break -- pick the first match
end
end
end
end
end
Line 628: Line 605:
if sitelink then
if sitelink then
if not (dtxt or shortname) then
if not (dtxt or shortname) then
-- if sitelink and label are the same except for case, no need to process further
-- strip any namespace or dab from the sitelink
if sitelink:lower() ~= label:lower() then
local pos = sitelink:find(":") or 0
-- strip any namespace or dab from the sitelink
local slink = sitelink
local pos = sitelink:find(":") or 0
if pos > 0 then
local slink = sitelink
local prefix = sitelink:sub(1,pos-1)
if pos > 0 then
if mw.site.namespaces[prefix] then -- that prefix is a valid namespace, so remove it
local pfx = sitelink:sub(1,pos-1)
slink = sitelink:sub(pos+1)
if mw.site.namespaces[pfx] then -- that prefix is a valid namespace, so remove it
slink = sitelink:sub(pos+1)
end
end
-- remove stuff after commas or inside parentheses - ie. dabs
slink = slink:gsub("%s%(.+%)$", ""):gsub(",.+$", "")
-- if uselbl is false, use sitelink instead of label
if not uselbl then
--  use slink as display, preserving label case - find("^%u") is true for 1st char uppercase
if label:find("^%u") then
label = slink:gsub("^(%l)", string.upper)
else
label = slink:gsub("^(%u)", string.lower)
end
end
end
end
-- remove stuff after commas or inside parentheses - ie. dabs
slink = slink:gsub("%s%(.+%)$", ""):gsub(",.+$", "")
--  use that as label, preserving label case - find("^%u") is true for 1st char uppercase
if label:find("^%u") then
label = slink:gsub("^(%l)", string.upper)
else
label = slink:gsub("^(%u)", string.lower)
end
end
end
end
Line 658: Line 629:
end
end
elseif islabel then
elseif islabel then
-- no sitelink, label exists, so check if a redirect with that title exists, if linkredir is true
-- no sitelink, label exists, so check if a redirect with that title exists
-- display plain label by default
local artitle = mw.title.new(label, 0) -- only nil if label has invalid chars
disp = prefix .. fmt .. label .. fmt .. postfix
if not donotlink[label] and artitle and artitle.redirectTarget then
if linkredir then
-- there's a redirect with the same title as the label, so let's link to that
local artitle = mw.title.new(label, 0) -- only nil if label has invalid chars
disp = "[[".. lprefix .. label .. lpostfix .. "|" .. prefix .. fmt .. label .. fmt .. postfix .. "]]"
if not donotlink[label] and artitle and artitle.redirectTarget then
else
-- there's a redirect with the same title as the label, so let's link to that
-- either (donotlink is true) or (no sitelink, label exists, not redirect)
disp = "[[".. lprefix .. label .. lpostfix .. "|" .. prefix .. fmt .. label .. fmt .. postfix .. "]]"
-- so output unlinked label with italics or quotes as needed
end
disp = prefix .. fmt .. label .. fmt .. postfix
end -- test if article title exists as redirect on current Wiki
end -- test if article title exists as redirect on current Wiki
else
else
Line 823: Line 794:
-- createicon assembles the "Edit at Wikidata" pen icon.
-- createicon assembles the "Edit at Wikidata" pen icon.
-- It returns a wikitext string inside a span class="penicon"
-- It returns a wikitext string inside a span class="penicon"
-- if entityID is nil or empty, the ID associated with current page is used
-- langcode and propertyID may be nil or empty
-------------------------------------------------------------------------------
-------------------------------------------------------------------------------
-- Dependencies: i18n[];
-- Dependencies: i18n[];
-------------------------------------------------------------------------------
-------------------------------------------------------------------------------
local createicon = function(langcode, entityID, propertyID)
local createicon = function(langcode, entityID, propertyID)
langcode = langcode or ""
local icon = "&nbsp;<span class='penicon'>[["
if not entityID or entityID == "" then entityID= mw.wikibase.getEntityIdForCurrentPage() end
propertyID = propertyID or ""
local icon = "&nbsp;<span class='penicon autoconfirmed-show'>[["
-- "&nbsp;<span data-bridge-edit-flow='overwrite' class='penicon'>[[" -> enable Wikidata Bridge
-- "&nbsp;<span data-bridge-edit-flow='overwrite' class='penicon'>[[" -> enable Wikidata Bridge
.. i18n["filespace"]
.. i18n["filespace"]
Line 838: Line 804:
.. i18n["editonwikidata"]
.. i18n["editonwikidata"]
.. "|link=https://www.wikidata.org/wiki/" .. entityID
.. "|link=https://www.wikidata.org/wiki/" .. entityID
if langcode ~= "" then icon = icon .. "?uselang=" .. langcode end
.. "?uselang=" .. langcode
if propertyID ~= "" then icon = icon .. "#" .. propertyID end
if propertyID then icon = icon .. "#" .. propertyID end
icon = icon .. "|" .. i18n["editonwikidata"] .. "]]</span>"
icon = icon .. "|" .. i18n["editonwikidata"] .. "]]</span>"
return icon
return icon
Line 848: Line 814:
-- assembleoutput takes the sequence table containing the property values
-- assembleoutput takes the sequence table containing the property values
-- and formats it according to switches given. It returns a string or nil.
-- and formats it according to switches given. It returns a string or nil.
-- It uses the entityID (and optionally propertyID) to create a link in the pen icon.
-- It needs the entityID and propertyID to create a link in the pen icon.
-------------------------------------------------------------------------------
-------------------------------------------------------------------------------
-- Dependencies: parseParam();
-- Dependencies: parseParam();
Line 972: Line 938:
local qnumber = dv.id
local qnumber = dv.id
if linked then
if linked then
val = linkedItem(qnumber, args)
val = linkedItem(qnumber, lpre, lpost, pre, post, dtxt, shortname, args.lang)
else -- no link wanted so check for display-text, otherwise test for lang code
else -- no link wanted so check for display-text, otherwise test for lang code
local label, islabel
local label, islabel
Line 1,280: Line 1,246:
args.pd = pd
args.pd = pd


-- allow qualifiers to have a different date format; default to year unless qualsonly is set
-- allow qualifiers to have a different date format; default to year
args.qdf = args.qdf or args.qualifierdateformat or args.df or (not qualsonly and "y")
args.qdf = args.qdf or args.qualifierdateformat or args.df or "y"


local lang = args.lang or findLang().code
local lang = args.lang or findlang().code


     -- qualID is a string list of wanted qualifiers or "ALL"
     -- qualID is a string list of wanted qualifiers or "ALL"
Line 1,408: Line 1,374:
elseif t ~= "" then
elseif t ~= "" then
if qualsonly then
if qualsonly then
if timestart == "" then
out[#out+1] = timestart .. dsep .. timeend
out[#out+1] = timeend
elseif timeend == "" then
out[#out+1] = timestart
else
out[#out+1] = timestart .. dsep .. timeend
end
else
else
out[#out] = out[#out] .. " (" .. timestart .. dsep .. timeend .. ")"
out[#out] = out[#out] .. " (" .. timestart .. dsep .. timeend .. ")"
Line 1,494: Line 1,454:
local uabbr = parseParam(args.unitabbr or args.uabbr, false)
local uabbr = parseParam(args.unitabbr or args.uabbr, false)
local filter = (args.unit or ""):upper()
local filter = (args.unit or ""):upper()
local maxvals = tonumber(args.maxvals) or 0
if filter == "" then filter = nil end
if filter == "" then filter = nil end


Line 1,526: Line 1,485:
return nil
return nil
end -- of check for string
end -- of check for string
if maxvals > 0 and #out >= maxvals then break end
end -- of loop through values of propertyID
end -- of loop through values of propertyID
return assembleoutput(out, frame.args, qid, propertyID)
return assembleoutput(out, frame.args, qid, propertyID)
Line 1,569: Line 1,527:
end
end
for i2, v2 in ipairs(proptbl) do
for i2, v2 in ipairs(proptbl) do
local parttbl = v2.qualifiers and v2.qualifiers.P518
parttbl = v2.qualifiers and v2.qualifiers.P518
if parttbl then
if parttbl then
-- this higher location has qualifier 'applies to part' (P518)
-- this higher location has qualifier 'applies to part' (P518)
Line 1,596: Line 1,554:
end
end


-- check if it's an instance of (P31) a country (Q6256) or sovereign state (Q3624078)
-- check if it's an instance of (P31) a country (Q6256) and terminate the chain if it is
-- and terminate the chain if it is
local inst = mw.wikibase.getAllStatements(qid, "P31")
local inst = mw.wikibase.getAllStatements(qid, "P31")
if #inst > 0 then
if #inst > 0 then
for k, v in ipairs(inst) do
for k, v in ipairs(inst) do
local instid = v.mainsnak.datavalue and v.mainsnak.datavalue.value.id
local instid = v.mainsnak.datavalue.value.id
-- stop if it's a country (or a country within the United Kingdom if skip is true)
-- stop if it's a country (or a country within the United Kingdom if skip is true)
if instid == "Q6256" or instid == "Q3624078" or (skip and instid == "Q3336843") then
if instid == "Q6256" or (skip and instid == "Q3336843") then
prop = nil -- this will ensure this is treated as top-level location
prop = nil -- this will ensure this is treated as top-level location
break
break
Line 1,613: Line 1,570:
if prop and prop.mainsnak.datavalue then
if prop and prop.mainsnak.datavalue then
if not skip or count == 0 then
if not skip or count == 0 then
local args = { lprefix = ":" }
out[#out+1] = linkedItem(qid, ":", "", "", "") -- get a linked value if we can
out[#out+1] = linkedItem(qid, args) -- get a linked value if we can
end
end
qid, prevqid = prop.mainsnak.datavalue.value.id, qid
qid, prevqid = prop.mainsnak.datavalue.value.id, qid
Line 1,846: Line 1,802:
-- getCoords is used to get coordinates for display in an infobox
-- getCoords is used to get coordinates for display in an infobox
-- whitelist and blacklist are implemented
-- whitelist and blacklist are implemented
-- optional 'display' parameter is allowed, defaults to nil - was "inline, title"
-- optional 'display' parameter is allowed, defaults to "inline, title"
-------------------------------------------------------------------------------
-------------------------------------------------------------------------------
-- Dependencies: setRanks(); parseInput(); decimalPrecision();
-- Dependencies: setRanks(); parseInput(); decimalPrecision();
Line 1,854: Line 1,810:


-- if there is a 'display' parameter supplied, use it
-- if there is a 'display' parameter supplied, use it
-- otherwise default to nothing
-- otherwise default to "inline, title"
local disp = frame.args.display or ""
local disp = frame.args.display or ""
if disp == "" then
if disp == "" then
disp = nil -- default to not supplying display parameter, was "inline, title"
disp = "inline, title"
end
end


Line 1,915: Line 1,871:
-- whose value is to be returned is passed in named parameter |qual=
-- whose value is to be returned is passed in named parameter |qual=
local qualifierID = frame.args.qual
local qualifierID = frame.args.qual
-- A filter can be set like this: filter=P642==Q22674854
local filter, fprop, fval
local ftable = mw.text.split(frame.args.filter or "", "==")
if ftable[2] then
fprop = mw.text.trim(ftable[1])
fval = mw.text.trim(ftable[2])
filter = true
end


-- onlysourced is a boolean passed to return qualifiers
-- onlysourced is a boolean passed to return qualifiers
Line 1,949: Line 1,896:
for k1, v1 in pairs(props) do
for k1, v1 in pairs(props) do
if v1.mainsnak.snaktype == "value" and v1.mainsnak.datavalue.type == "wikibase-entityid" then
if v1.mainsnak.snaktype == "value" and v1.mainsnak.datavalue.type == "wikibase-entityid" then
-- It's a wiki-linked value, so check if it's the target (in propvalue) and if it has qualifiers
-- It's a wiki-linked value, so check if it's the target (in propvalue)
-- and if it has qualifiers
if v1.mainsnak.datavalue.value.id == propvalue and v1.qualifiers then
if v1.mainsnak.datavalue.value.id == propvalue and v1.qualifiers then
if onlysrc == false or sourced(v1) then
if onlysrc == false or sourced(v1) then
-- if we've got this far, we have a (sourced) claim with qualifiers
-- if we've got this far, we have a (sourced) claim with qualifiers
-- which matches the target, so apply the filter and find the value(s) of the qualifier we want
-- which matches the target, so find the value(s) of the qualifier we want
if not filter or (v1.qualifiers[fprop] and v1.qualifiers[fprop][1].datavalue.value.id == fval) then
local quals = v1.qualifiers[qualifierID]
local quals = v1.qualifiers[qualifierID]
if quals then
if quals then
-- can't reference qualifer, so set onlysourced = "no" (not boolean)
-- can't reference qualifer, so set onlysourced = "no" (args are strings, not boolean)
local qargs = frame.args
local qargs = frame.args
qargs.onlysourced = "no"
qargs.onlysourced = "no"
local vals = propertyvalueandquals(quals, qargs, qid)
local vals = propertyvalueandquals(quals, qargs, qid)
for k, v in ipairs(vals) do
for k, v in ipairs(vals) do
out[#out + 1] = v
out[#out + 1] = v
end
end
end
end
end
Line 2,146: Line 2,092:
-- Dependencies: parseParam; setRanks; parseInput; sourced; propertyvalueandquals assembleoutput;
-- Dependencies: parseParam; setRanks; parseInput; sourced; propertyvalueandquals assembleoutput;
-------------------------------------------------------------------------------
-------------------------------------------------------------------------------
p._getPropertyIDs = function(args)
p.getPropertyIDs = function(frame)
local args = frame.args
args.reqranks = setRanks(args.rank)
args.reqranks = setRanks(args.rank)
args.langobj = findLang(args.lang)
args.langobj = findLang(args.lang)
Line 2,163: Line 2,110:
local maxvals = tonumber(args.maxvals) or 0
local maxvals = tonumber(args.maxvals) or 0


local out = {}
out = {}
for i, v in ipairs(props) do
for i, v in ipairs(props) do
local snak = v.mainsnak
local snak = v.mainsnak
Line 2,177: Line 2,124:


return assembleoutput(out, args, qid, pid)
return assembleoutput(out, args, qid, pid)
end
p.getPropertyIDs = function(frame)
local args = frame.args
return p._getPropertyIDs(args)
end
end


Line 2,217: Line 2,159:
qlist = qlist:gsub("[%p%s]+", " ") .. " "
qlist = qlist:gsub("[%p%s]+", " ") .. " "


local out = {}
out = {}
for i, v in ipairs(props) do
for i, v in ipairs(props) do
local snak = v.mainsnak
local snak = v.mainsnak
Line 2,251: Line 2,193:
-- Dependencies: parseParam; setRanks; parseInput; sourced; propertyvalueandquals assembleoutput;
-- Dependencies: parseParam; setRanks; parseInput; sourced; propertyvalueandquals assembleoutput;
-------------------------------------------------------------------------------
-------------------------------------------------------------------------------
p._getPropOfProp = function(args)
p.getPropOfProp = function(frame)
-- parameter sets for commonly used groups of parameters
frame.args.reqranks = setRanks(frame.args.rank)
local paraset = tonumber(args.ps or args.parameterset or 0)
frame.args.langobj = findLang(frame.args.lang)
if paraset == 1 then
frame.args.lang = frame.args.langobj.code
-- a common setting
local args = frame.args
args.rank = "best"
local pid1 = args.prop1 or args.pid1 or ""
args.fetchwikidata = "ALL"
args.onlysourced = "no"
args.noicon = "true"
elseif paraset == 2 then
-- equivalent to raw
args.rank = "best"
args.fetchwikidata = "ALL"
args.onlysourced = "no"
args.noicon = "true"
args.linked = "no"
args.pd = "true"
elseif paraset == 3 then
-- third set goes here
end
 
args.reqranks = setRanks(args.rank)
args.langobj = findLang(args.lang)
args.lang = args.langobj.code
local pid1 = args.prop1 or args.pid1 or ""
local pid2 = args.prop2 or args.pid2 or ""
local pid2 = args.prop2 or args.pid2 or ""
local localval = mw.text.trim(args[1] or "")
if pid1 == "" or pid2 == "" then return nil end
if pid1 == "" or pid2 == "" then return nil end
 
local qid1, statements1 = parseInput(frame, localval, pid1)
local f = {}
if not qid1 then return localval end
f.args = args
local qid1, statements1 = parseInput(f, args[1], pid1)
-- parseInput nulls empty args[1] and returns args[1] if nothing on Wikidata
if not qid1 then return statements1 end
-- otherwise it returns the qid and a table for the statement
local onlysrc = parseParam(args.onlysourced or args.osd, true)
local onlysrc = parseParam(args.onlysourced or args.osd, true)
local maxvals = tonumber(args.maxvals) or 0
local maxvals = tonumber(args.maxvals) or 0
Line 2,310: Line 2,229:
end -- of loop through values of property1
end -- of loop through values of property1
return assembleoutput(out, args, qid1, pid1)
return assembleoutput(out, args, qid1, pid1)
end
p.getPropOfProp = function(frame)
local args= frame.args
if not args.prop1 and not args.pid1 then
args = frame:getParent().args
if not args.prop1 and not args.pid1 then return i18n.errors["No property supplied"] end
end
return p._getPropOfProp(args)
end
end


Line 2,500: Line 2,409:
if maxvals > 0 and #cat2 >= maxvals then break end
if maxvals > 0 and #cat2 >= maxvals then break end
end
end
local out = {}
out = {}
for k1, v1 in ipairs(cat1) do
for k1, v1 in ipairs(cat1) do
for k2, v2 in ipairs(cat2) do
for k2, v2 in ipairs(cat2) do
Line 2,784: Line 2,693:
if not (whitelist == 'ALL' or whitelist:find(fieldname)) then return nil end
if not (whitelist == 'ALL' or whitelist:find(fieldname)) then return nil end


local qid = args.qid or ""
local qid = mw.text.trim(args.qid or "")
if qid == "" then qid = mw.wikibase.getEntityIdForCurrentPage() end
if qid == "" then qid = nil end
if not qid or not mw.wikibase.entityExists(qid) then return nil end


local aliases = mw.wikibase.getEntity(qid).aliases
local entity = mw.wikibase.getEntity(qid)
if not entity then return nil end
local aliases = entity.aliases
if not aliases then return nil end
if not aliases then return nil end
if not qid then qid= mw.wikibase.getEntityIdForCurrentPage() end


args.langobj = findLang(args.lang)
args.langobj = findLang(args.lang)
Line 2,992: Line 2,903:


-------------------------------------------------------------------------------
-------------------------------------------------------------------------------
-- followQid takes four optional parameters: qid, props, list and all.
-- followQid takes three optional parameters: qid, props, and all.
-- If qid is not given, it uses the qid for the connected page
-- If qid is not given, it uses the qid for the connected page
-- or returns nil if there isn't one.
-- or returns nil if there isn't one.
Line 2,998: Line 2,909:
-- If props is given, the Wikidata item for the qid is examined for each property in turn.
-- If props is given, the Wikidata item for the qid is examined for each property in turn.
-- If that property contains a value that is another Wikibase-item, that item's qid is returned,
-- If that property contains a value that is another Wikibase-item, that item's qid is returned,
-- and the search terminates, unless |all=y when all of the qids are returned, separated by spaces.
-- and the search terminates, unless |all=y when all of the qids are returned, sparated by spaces.
-- If |list= is set to a template, the qids are passed as arguments to the template.
-- If props is not given, the qid is returned.
-- If props is not given, the qid is returned.
-------------------------------------------------------------------------------
-------------------------------------------------------------------------------
-- Dependencies: parseParam()
-- Dependencies: parseParam()
-------------------------------------------------------------------------------
-------------------------------------------------------------------------------
p._followQid = function(args)
p.followQid = function(frame)
local qid = (args.qid or ""):upper()
local qid = (frame.args.qid or ""):upper()
local all = parseParam(args.all, false)
local all = parseParam(frame.args.all, false)
local list = args.list or ""
if list == "" then list = nil end
if qid == "" then
if qid == "" then
qid = mw.wikibase.getEntityIdForCurrentPage()
qid = mw.wikibase.getEntityIdForCurrentPage()
Line 3,014: Line 2,922:
if not qid then return nil end
if not qid then return nil end
local out = {}
local out = {}
local props = (args.props or ""):upper()
local props = (frame.args.props or ""):upper()
if props ~= "" then
if props ~= "" then
for p in mw.text.gsplit(props, "%p") do -- split at punctuation and iterate
for p in mw.text.gsplit(props, "%p") do -- split at punctuation and iterate
Line 3,031: Line 2,939:
end
end
if #out > 0 then
if #out > 0 then
local ret = ""
return table.concat(out, " ")
if list then
ret = mw.getCurrentFrame():expandTemplate{title = list, args = out}
else
ret = table.concat(out, " ")
end
return ret
else
else
return qid
return qid
end
end
end
p.followQid = function(frame)
return p._followQid(frame.args)
end
end


Line 3,067: Line 2,965:
-------------------------------------------------------------------------------
-------------------------------------------------------------------------------
p.siteID = function(frame)
p.siteID = function(frame)
local txtlang = frame:callParserFunction('int', {'lang'}) or ""
local txtlang = frame:preprocess( "{{int:lang}}" ) or ""
-- This deals with specific exceptions: be-tarask -> be-x-old
-- This deals with specific exceptions: be-tarask -> be-x-old
if txtlang == "be-tarask" then
if txtlang == "be-tarask" then
Line 3,091: Line 2,989:
-------------------------------------------------------------------------------
-------------------------------------------------------------------------------
p.projID = function(frame)
p.projID = function(frame)
local txtlang = frame:callParserFunction('int', {'lang'}) or ""
local txtlang = frame:preprocess( "{{int:lang}}" ) or ""
-- This deals with specific exceptions: be-tarask -> be-x-old
-- This deals with specific exceptions: be-tarask -> be-x-old
if txtlang == "be-tarask" then
if txtlang == "be-tarask" then
Line 3,160: Line 3,058:
-- from the item given by the parameter 'qid'
-- from the item given by the parameter 'qid'
-- or from the Wikidata item associated with the current page if qid is not supplied.
-- or from the Wikidata item associated with the current page if qid is not supplied.
-- It only checks ranks that are requested (preferred and normal by default)
-- If property is not supplied, then P31 (instance of) is assumed.
-- If property is not supplied, then P31 (instance of) is assumed.
-- It returns val if found or nothing if not found.
-- It returns val if found or nothing if not found.
Line 3,184: Line 3,081:
if qid:sub(1,1) ~= "Q" then qid = mw.wikibase.getEntityIdForCurrentPage() end
if qid:sub(1,1) ~= "Q" then qid = mw.wikibase.getEntityIdForCurrentPage() end
if not qid then return nil end
if not qid then return nil end
local ranks = setRanks(args.rank)
local stats = mw.wikibase.getAllStatements( qid, pid )
local stats = {}
if ranks.b then
stats = mw.wikibase.getBestStatements(qid, pid)
else
stats = mw.wikibase.getAllStatements( qid, pid )
end
if not stats[1] then return nil end
if not stats[1] then return nil end
if stats[1].mainsnak.datatype == "wikibase-item" then
if stats[1].mainsnak.datatype == "wikibase-item" then
for k, v in pairs( stats ) do
for k, v in pairs( stats ) do
local ms = v.mainsnak
if v.mainsnak.snaktype == "value" and v.mainsnak.datavalue.value.id == val then
if ranks[v.rank:sub(1,1)] and ms.snaktype == "value" and ms.datavalue.value.id == val then
return val
return val
end
end
Line 3,210: Line 3,100:
-- but it keeps the "edit at Wikidata" pen icon out of the microformat.
-- but it keeps the "edit at Wikidata" pen icon out of the microformat.
-- Usually it will take its url parameter directly from a Wikidata call:
-- Usually it will take its url parameter directly from a Wikidata call:
-- e.g. {{#invoke:WikidataIB |url2 |url={{wdib |P856 |qid=Q23317 |fwd=ALL |osd=no}} }}
-- e.g. {{#invoke:WikidataIB |url2 |url={{wdib |P856 |qid=Q23317 |fwd=ALL |osd=no}}
-------------------------------------------------------------------------------
-------------------------------------------------------------------------------
-- Dependencies: none
-- Dependencies: none
Line 3,217: Line 3,107:
local txt = frame.args.url or ""
local txt = frame.args.url or ""
if txt == "" then return nil end
if txt == "" then return nil end
-- extract any icon
local url, icon = txt:match("(.+)&nbsp;(.+)")
local url, icon = txt:match("(.+)&nbsp;(.+)")
-- make sure there's at least a space at the end
url = url or txt
url = (url or txt) .. " "
icon = icon or ""
icon = icon or ""
-- extract any protocol like https://
local prot, addr = url:match("(http[s]*://)(.+)")
local prot = url:match("(https*://).+[ \"\']")
prot = prot or url
-- extract address
addr = addr or ""
local addr = ""
local disp, n = addr:gsub("%.", "<wbr/>%.")
if prot then
addr = url:match("https*://(.+)[ \"\']") or " "
else
prot = "//"
addr = url:match("[^%p%s]+%.(.+)[ \"\']") or " "
end
-- strip trailing / from end of domain-only url and add <wbr/> before . and /
local disp, n = addr:gsub( "^([^/]+)/$", "%1" ):gsub("%/", "<wbr/>/"):gsub("%.", "<wbr/>.")
return '<span class="url">[' .. prot .. addr .. " " .. disp .. "]</span>&nbsp;" .. icon
return '<span class="url">[' .. prot .. addr .. " " .. disp .. "]</span>&nbsp;" .. icon
end
end
Line 3,250: Line 3,130:
local url = frame.args.url or ""
local url = frame.args.url or ""
if url:upper() == "NONE" then return nil end
if url:upper() == "NONE" then return nil end
local qid = frame.args.qid or ""
if qid == "" then qid = mw.wikibase.getEntityIdForCurrentPage() end
if not qid then return nil end
local urls = {}
local urls = {}
local quals = {}
local quals = {}
local qid = frame.args.qid or ""
if url == "" then
if url and url ~= "" then
urls[1] = url
else
if qid == "" then qid = mw.wikibase.getEntityIdForCurrentPage() end
if not qid then return nil end
 
local prop856 = mw.wikibase.getBestStatements(qid, "P856")
local prop856 = mw.wikibase.getBestStatements(qid, "P856")
for k, v in pairs(prop856) do
for k, v in pairs(prop856) do
Line 3,272: Line 3,151:
end -- test for website having a value
end -- test for website having a value
end -- loop through website(s)
end -- loop through website(s)
else
urls[1] = url
end
end
if #urls == 0 then return nil end
if #urls == 0 then return nil end
Line 3,310: Line 3,191:
local args = frame.args or frame:getParent().args or {}
local args = frame.args or frame:getParent().args or {}


local qid = args.qid or ""
local qid = args.qid
if qid == "" then qid = mw.wikibase.getEntityIdForCurrentPage() end
if qid == "" then qid = nil end
if not qid or not mw.wikibase.entityExists(qid) then return i18n["entity-not-found"] end
 
local entity = mw.wikibase.getEntity(qid)
if not entity then return i18n["entity-not-found"] end


local labels = mw.wikibase.getEntity(qid).labels
local labels = entity.labels
if not labels then return i18n["labels-not-found"] end
if not labels then return i18n["labels-not-found"] end


Line 3,335: Line 3,218:
local args = frame.args or frame:getParent().args or {}
local args = frame.args or frame:getParent().args or {}


local qid = args.qid or ""
local qid = args.qid
if qid == "" then qid = mw.wikibase.getEntityIdForCurrentPage() end
if qid == "" then qid = nil end
if not qid or not mw.wikibase.entityExists(qid) then return i18n["entity-not-found"] end
 
local entity = mw.wikibase.getEntity(qid)
if not entity then return i18n["entity-not-found"] end


local descriptions = mw.wikibase.getEntity(qid).descriptions
local descriptions = entity.descriptions
if not descriptions then return i18n["descriptions-not-found"] end
if not descriptions then return i18n["descriptions-not-found"] end


Line 3,360: Line 3,245:
local args = frame.args or frame:getParent().args or {}
local args = frame.args or frame:getParent().args or {}


local qid = args.qid or ""
local qid = args.qid
if qid == "" then qid = mw.wikibase.getEntityIdForCurrentPage() end
if qid == "" then qid = nil end
if not qid or not mw.wikibase.entityExists(qid) then return i18n["entity-not-found"] end
 
local entity = mw.wikibase.getEntity(qid)
if not entity then return i18n["entity-not-found"] end


local aliases = mw.wikibase.getEntity(qid).aliases
local aliases = entity.aliases
if not aliases then return i18n["aliases-not-found"] end
if not aliases then return i18n["aliases-not-found"] end


Line 3,431: Line 3,318:
local site = args.site or ""
local site = args.site or ""
local showdab = parseParam(args.showdab, true)
local showdab = parseParam(args.showdab, true)
local qid = mw.wikibase.getEntityIdForTitle(title, site)
qid = mw.wikibase.getEntityIdForTitle(title, site)
if qid then
if qid then
local prop31 = mw.wikibase.getBestStatements(qid, "P31")[1]
local prop31 = mw.wikibase.getBestStatements(qid, "P31")[1]