Module:WikidataCheck: Difference between revisions
Jump to navigation
Jump to search
>Rschen7754 m (Changed protection level of Module:WikidataCheck: Highly visible template ([Edit=Allow only autoconfirmed users] (indefinite) [Move=Block all non-admin users] (indefinite))) |
>Legoktm (documentation) |
||
Line 10: | Line 10: | ||
local catbase = config.category | local catbase = config.category | ||
local namespaces = config.namespaces | local namespaces = config.namespaces | ||
local ok = false | local ok = false -- one-way flag to check if we're in a good namespace | ||
local ns = mw.title.getCurrentTitle().namespace | local ns = mw.title.getCurrentTitle().namespace | ||
for v in mw.text.gsplit( namespaces, ",", true) do | for v in mw.text.gsplit( namespaces, ",", true) do | ||
Line 17: | Line 17: | ||
end | end | ||
end | end | ||
if not ok then | if not ok then -- not in one of the approved namespaces | ||
return "" | return "" | ||
end | end | ||
local entity = mw.wikibase.getEntity() | local entity = mw.wikibase.getEntity() | ||
if not entity then | if not entity then -- no Wikidata item | ||
return "[[Category:" .. catbase .. " not in Wikidata]]" | return "[[Category:" .. catbase .. " not in Wikidata]]" | ||
end | end | ||
local hasProp = entity.claims[property] | local hasProp = entity.claims[property] | ||
if not hasProp then | if not hasProp then -- no claim of that property | ||
return "[[Category:" .. catbase .. " not in Wikidata]]" | return "[[Category:" .. catbase .. " not in Wikidata]]" -- bad. Bot needs to add the property | ||
end | end | ||
local propValue = hasProp[0].mainsnak.datavalue.value | local propValue = hasProp[0].mainsnak.datavalue.value -- This should eventually iterate over all possible values? | ||
if propValue == value then | if propValue == value then | ||
return "[[Category:" .. catbase .. " same as Wikidata]]" | return "[[Category:" .. catbase .. " same as Wikidata]]" -- yay! | ||
else | else | ||
return "[[Category:" .. catbase .. " different from Wikidata]]" | return "[[Category:" .. catbase .. " different from Wikidata]]" -- needs human review :( | ||
end | end | ||
end | end | ||
return p | return p |
Revision as of 02:10, 30 April 2013
Documentation for this module may be created at Module:WikidataCheck/doc
local p = {} function p.wikidatacheck(frame) local pframe = frame:getParent() local config = frame.args -- the arguments passed BY the template, in the wikitext of the template itself local args = pframe.args -- the arguments passed TO the template, in the wikitext that transcludes the template local property = config.property local value = config.value local catbase = config.category local namespaces = config.namespaces local ok = false -- one-way flag to check if we're in a good namespace local ns = mw.title.getCurrentTitle().namespace for v in mw.text.gsplit( namespaces, ",", true) do if tonumber(v) == ns then ok = true end end if not ok then -- not in one of the approved namespaces return "" end local entity = mw.wikibase.getEntity() if not entity then -- no Wikidata item return "[[Category:" .. catbase .. " not in Wikidata]]" end local hasProp = entity.claims[property] if not hasProp then -- no claim of that property return "[[Category:" .. catbase .. " not in Wikidata]]" -- bad. Bot needs to add the property end local propValue = hasProp[0].mainsnak.datavalue.value -- This should eventually iterate over all possible values? if propValue == value then return "[[Category:" .. catbase .. " same as Wikidata]]" -- yay! else return "[[Category:" .. catbase .. " different from Wikidata]]" -- needs human review :( end end return p