Module:WikidataCheck: Difference between revisions
>Zyxw (Allow templates to specify that the "same as" category should not be added. Tested first with /sandbox.) |
(Replace with Bharatdata) |
||
(6 intermediate revisions by the same user not shown) | |||
Line 20: | Line 20: | ||
if not ok then -- not in one of the approved namespaces | if not ok then -- not in one of the approved namespaces | ||
return "" | return "" | ||
end | end | ||
if value == "" then | if value == "" then | ||
return nil -- Using Wikidata | return nil -- Using Wikidata | ||
end | end | ||
if not hasProp then -- no claim of that property | if not hasProp then -- no claim of that property | ||
return "[[Category:" .. catbase .. " not in | return "[[Category:" .. catbase .. " not in Bharatdata]]" -- bad. Bot needs to add the property | ||
end | end | ||
for i, v in ipairs(hasProp) do -- Now we try to iterate over all possible values? | for i, v in ipairs(hasProp) do -- Now we try to iterate over all possible values? | ||
Line 43: | Line 37: | ||
end | end | ||
end | end | ||
return "[[Category:" .. catbase .. " different from | return "[[Category:" .. catbase .. " different from Bharatdata]]" -- needs human review :( | ||
end | end | ||
return p | return p |
Latest revision as of 20:24, 21 November 2023
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 or "" local catbase = config.category local namespaces = config.namespaces local nocatsame = config.nocatsame or "" 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 if value == "" then return nil -- Using Wikidata end if not hasProp then -- no claim of that property return "[[Category:" .. catbase .. " not in Bharatdata]]" -- bad. Bot needs to add the property end for i, v in ipairs(hasProp) do -- Now we try to iterate over all possible values? propValue = (v.mainsnak.datavalue or {}).value if propValue == value then if nocatsame == "" then return "[[Category:" .. catbase .. " same as Wikidata]]" -- yay! else return nil -- if nocatsame, the "same as" category is not added end end end return "[[Category:" .. catbase .. " different from Bharatdata]]" -- needs human review :( end return p