<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="nl">
	<id>https://wiki-raamsdonk.nl/index.php?action=history&amp;feed=atom&amp;title=Module%3AWikidata</id>
	<title>Module:Wikidata - Bewerkingsoverzicht</title>
	<link rel="self" type="application/atom+xml" href="https://wiki-raamsdonk.nl/index.php?action=history&amp;feed=atom&amp;title=Module%3AWikidata"/>
	<link rel="alternate" type="text/html" href="https://wiki-raamsdonk.nl/index.php?title=Module:Wikidata&amp;action=history"/>
	<updated>2026-04-12T03:44:40Z</updated>
	<subtitle>Bewerkingsoverzicht voor deze pagina op de wiki</subtitle>
	<generator>MediaWiki 1.43.6</generator>
	<entry>
		<id>https://wiki-raamsdonk.nl/index.php?title=Module:Wikidata&amp;diff=187119&amp;oldid=prev</id>
		<title>Colani: 1 versie geïmporteerd</title>
		<link rel="alternate" type="text/html" href="https://wiki-raamsdonk.nl/index.php?title=Module:Wikidata&amp;diff=187119&amp;oldid=prev"/>
		<updated>2026-03-14T12:10:21Z</updated>

		<summary type="html">&lt;p&gt;1 versie geïmporteerd&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Nieuwe pagina&lt;/b&gt;&lt;/p&gt;&lt;div&gt;-- module local variables&lt;br /&gt;
local wiki = &lt;br /&gt;
{&lt;br /&gt;
	langcode = mw.language.getContentLanguage().code&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
-- internationalisation&lt;br /&gt;
local i18n = {&lt;br /&gt;
	[&amp;quot;errors&amp;quot;] = {&lt;br /&gt;
		[&amp;quot;property-not-found&amp;quot;] = &amp;quot;Eigenschap niet gevonden.&amp;quot;,&lt;br /&gt;
		[&amp;quot;entity-not-found&amp;quot;] = &amp;quot;Wikidata-entiteit niet gevonden.&amp;quot;,&lt;br /&gt;
		[&amp;quot;unknown-claim-type&amp;quot;] = &amp;quot;Onbekend statementtype.&amp;quot;,&lt;br /&gt;
		[&amp;quot;unknown-snak-type&amp;quot;] = &amp;quot;Onbekend snaktype.&amp;quot;,&lt;br /&gt;
		[&amp;quot;unknown-datavalue-type&amp;quot;] = &amp;quot;Onbekend gegevenstype.&amp;quot;,&lt;br /&gt;
		[&amp;quot;unknown-entity-type&amp;quot;] = &amp;quot;Onbekend entiteitstype.&amp;quot;,&lt;br /&gt;
		[&amp;quot;qualifier-not-found&amp;quot;] = &amp;quot;Kwalificatie niet gevonden.&amp;quot;,&lt;br /&gt;
		[&amp;quot;site-not-found&amp;quot;] = &amp;quot;Wikimedia-project niet gevonden.&amp;quot;&lt;br /&gt;
	},&lt;br /&gt;
	[&amp;quot;somevalue&amp;quot;] = &amp;quot;Onbekende waarde&amp;quot;,&lt;br /&gt;
	[&amp;quot;novalue&amp;quot;] = &amp;quot;Geen waarde&amp;quot;,&lt;br /&gt;
	[&amp;quot;datetime&amp;quot;] =&lt;br /&gt;
	{&lt;br /&gt;
		-- $1 is a placeholder for the actual number&lt;br /&gt;
		[0] = &amp;quot;$1 mld. jaar&amp;quot;,		-- precision: billion years&lt;br /&gt;
		[1] = &amp;quot;$100 mln. jaar&amp;quot;,		-- precision: hundred million years&lt;br /&gt;
		[2] = &amp;quot;$10 mln. jaar&amp;quot;,		-- precision: ten million years&lt;br /&gt;
		[3] = &amp;quot;$1 mln. jaar&amp;quot;,		-- precision: million years&lt;br /&gt;
		[4] = &amp;quot;$100.000 jaar&amp;quot;,		-- precision: hundred thousand years&lt;br /&gt;
		[5] = &amp;quot;$10.000 jaar&amp;quot;,		-- precision: ten thousand years&lt;br /&gt;
		[6] = &amp;quot;$1e millennium&amp;quot;,		-- precision: millennium&lt;br /&gt;
		[7] = &amp;quot;$1e eeuw&amp;quot;,			-- precision: century&lt;br /&gt;
		[8] = &amp;quot;jaren $1&amp;quot;,			-- precision: decade&lt;br /&gt;
		-- the following use the format of #time parser function&lt;br /&gt;
		[9] = &amp;quot;Y&amp;quot;,					-- precision: year&lt;br /&gt;
		[10] = &amp;quot;F Y&amp;quot;,				-- precision: month&lt;br /&gt;
		[11] = &amp;quot;j F Y&amp;quot;,				-- precision: day&lt;br /&gt;
		[12] = &amp;#039;j F Y, G &amp;quot;uur&amp;quot;&amp;#039;,	-- precision: hour&lt;br /&gt;
		[13] = &amp;quot;j F Y G:i&amp;quot;,			-- precision: minute&lt;br /&gt;
		[14] = &amp;quot;j F Y G:i:s&amp;quot;,		-- precision: second&lt;br /&gt;
		[&amp;quot;beforenow&amp;quot;] = &amp;quot;$1 geleden&amp;quot;,	-- how to format negative numbers for precisions 0 to 5&lt;br /&gt;
		[&amp;quot;afternow&amp;quot;] = &amp;quot;over $1&amp;quot;,		-- how to format positive numbers for precisions 0 to 5&lt;br /&gt;
		[&amp;quot;bc&amp;quot;] = &amp;#039;$1 &amp;quot;v.Chr.&amp;quot;&amp;#039;,		-- how print negative years&lt;br /&gt;
		[&amp;quot;ad&amp;quot;] = &amp;quot;$1&amp;quot;				-- how print positive years&lt;br /&gt;
	},&lt;br /&gt;
	[&amp;quot;monolingualtext&amp;quot;] = &amp;#039;&amp;lt;span lang=&amp;quot;%language&amp;quot;&amp;gt;%text&amp;lt;/span&amp;gt;&amp;#039;&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
local p = { }&lt;br /&gt;
&lt;br /&gt;
local function printError(code)&lt;br /&gt;
	return &amp;#039;&amp;lt;span class=&amp;quot;error&amp;quot;&amp;gt;&amp;#039; .. i18n.errors[code] .. &amp;#039;&amp;lt;/span&amp;gt;&amp;#039;&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- the &amp;quot;qualifiers&amp;quot; and &amp;quot;snaks&amp;quot; field have a respective &amp;quot;qualifiers-order&amp;quot; and &amp;quot;snaks-order&amp;quot; field&lt;br /&gt;
-- use these as the second parameter and this function instead of the built-in &amp;quot;pairs&amp;quot; function&lt;br /&gt;
-- to iterate over all qualifiers and snaks in the intended order.&lt;br /&gt;
local function orderedpairs(array, order)&lt;br /&gt;
	if not order then return pairs(array) end&lt;br /&gt;
&lt;br /&gt;
	-- return iterator function&lt;br /&gt;
	local i = 0&lt;br /&gt;
	return function()&lt;br /&gt;
		i = i + 1&lt;br /&gt;
		if order[i] then&lt;br /&gt;
			return order[i], array[order[i]]&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- getting sitelink of a given wiki&lt;br /&gt;
-- source: https://en.wikipedia.org/w/index.php?title=Module:Wikidata&amp;amp;oldid=757775054 line 1102&lt;br /&gt;
function p.getSiteLink(frame)&lt;br /&gt;
	local siteId = frame.args[1]&lt;br /&gt;
	local wikidataId = frame.args[&amp;quot;id&amp;quot;]&lt;br /&gt;
	local entity = mw.wikibase.getEntity( wikidataId )&lt;br /&gt;
	if not entity then&lt;br /&gt;
		return&lt;br /&gt;
	end&lt;br /&gt;
	local link = entity:getSitelink( siteId )&lt;br /&gt;
	if not link then&lt;br /&gt;
		return&lt;br /&gt;
	end&lt;br /&gt;
	return link&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.descriptionIn(frame)&lt;br /&gt;
	local langcode = frame.args[1]&lt;br /&gt;
	local id = frame.args[2]&lt;br /&gt;
	-- return description of a Wikidata entity in the given language or the default language of this Wikipedia site&lt;br /&gt;
	return mw.wikibase.getEntityObject(id).descriptions[langcode or wiki.langcode].value&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.labelIn(frame)&lt;br /&gt;
	local langcode = frame.args[1]&lt;br /&gt;
	local id = frame.args[2]&lt;br /&gt;
	-- return label of a Wikidata entity in the given language or the default language of this Wikipedia site&lt;br /&gt;
	return mw.wikibase.getEntityObject(id).labels[langcode or wiki.langcode].value&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function printDatavalueCoordinate(data, parameter)&lt;br /&gt;
	-- data fields: latitude [double], longitude [double], altitude [double], precision [double], globe [wikidata URI, usually http://www.wikidata.org/entity/Q2 [earth]]&lt;br /&gt;
	if parameter then&lt;br /&gt;
		if parameter == &amp;quot;globe&amp;quot; then data.globe = mw.ustring.match(data.globe, &amp;quot;Q%d+&amp;quot;) end -- extract entity id from the globe URI&lt;br /&gt;
		return data[parameter]&lt;br /&gt;
	else&lt;br /&gt;
		return data.latitude .. &amp;quot;/&amp;quot; .. data.longitude -- combine latitude and longitude, which can be decomposed using the #titleparts wiki function&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function printDatavalueQuantity(data, parameter)&lt;br /&gt;
	-- data fields: amount [number], unit [string], upperBound [number], lowerBound [number]&lt;br /&gt;
	if parameter then&lt;br /&gt;
		return data[parameter]&lt;br /&gt;
	else&lt;br /&gt;
		return string.gsub(tonumber(data.amount),&amp;quot;%.&amp;quot;,&amp;quot;,&amp;quot;) -- nl: replace dot decimal separator by comma decimal separator&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- precision: 0 - billion years, 1 - hundred million years, ..., 6 - millenia, 7 - century, 8 - decade, 9 - year, 10 - month, 11 - day, 12 - hour, 13 - minute, 14 - second&lt;br /&gt;
local function normalizeDate(date)&lt;br /&gt;
	date = mw.text.trim(date, &amp;quot;+&amp;quot;)&lt;br /&gt;
	-- extract year&lt;br /&gt;
	local yearstr = mw.ustring.match(date, &amp;quot;^\-?%d+&amp;quot;)&lt;br /&gt;
	local year = tonumber(yearstr)&lt;br /&gt;
	-- remove leading zeros of year&lt;br /&gt;
	return year .. mw.ustring.sub(date, #yearstr + 1), year&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function formatDate(date, precision, timezone, calendarmodel)&lt;br /&gt;
	precision = precision or 11&lt;br /&gt;
	date, year = normalizeDate(date)&lt;br /&gt;
	if year == 0 and precision &amp;lt;= 9 then return &amp;quot;&amp;quot; end&lt;br /&gt;
&lt;br /&gt;
	-- precision is 10000 years or more&lt;br /&gt;
	if precision &amp;lt;= 5 then&lt;br /&gt;
		local factor = 10 ^ ((5 - precision) + 4)&lt;br /&gt;
		local y2 = math.ceil(math.abs(year) / factor)&lt;br /&gt;
		local relative = mw.ustring.gsub(i18n.datetime[precision], &amp;quot;$1&amp;quot;, tostring(y2))&lt;br /&gt;
		if year &amp;lt; 0 then&lt;br /&gt;
			relative = mw.ustring.gsub(i18n.datetime.beforenow, &amp;quot;$1&amp;quot;, relative)&lt;br /&gt;
		else&lt;br /&gt;
			relative = mw.ustring.gsub(i18n.datetime.afternow, &amp;quot;$1&amp;quot;, relative)&lt;br /&gt;
		end&lt;br /&gt;
		return relative&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- precision is decades, centuries and millenia&lt;br /&gt;
	local era&lt;br /&gt;
	if precision == 6 then era = mw.ustring.gsub(i18n.datetime[6], &amp;quot;$1&amp;quot;, tostring(math.floor((math.abs(year) - 1) / 1000) + 1)) end&lt;br /&gt;
	if precision == 7 then era = mw.ustring.gsub(i18n.datetime[7], &amp;quot;$1&amp;quot;, tostring(math.floor((math.abs(year) - 1) / 100) + 1)) end&lt;br /&gt;
	if precision == 8 then era = mw.ustring.gsub(i18n.datetime[8], &amp;quot;$1&amp;quot;, tostring(math.floor(math.abs(year) / 10) * 10)) end&lt;br /&gt;
	if era then&lt;br /&gt;
		if year &amp;lt; 0 then era = mw.ustring.gsub(mw.ustring.gsub(i18n.datetime.bc, &amp;#039;&amp;quot;&amp;#039;, &amp;quot;&amp;quot;), &amp;quot;$1&amp;quot;, era)&lt;br /&gt;
		elseif year &amp;gt; 0 then era = mw.ustring.gsub(mw.ustring.gsub(i18n.datetime.ad, &amp;#039;&amp;quot;&amp;#039;, &amp;quot;&amp;quot;), &amp;quot;$1&amp;quot;, era) end&lt;br /&gt;
		return era&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- precision is year&lt;br /&gt;
	if precision == 9 then&lt;br /&gt;
		return year&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- precision is less than years&lt;br /&gt;
	if precision &amp;gt; 9 then&lt;br /&gt;
		--[[ the following code replaces the UTC suffix with the given negated timezone to convert the global time to the given local time&lt;br /&gt;
		timezone = tonumber(timezone)&lt;br /&gt;
		if timezone and timezone ~= 0 then&lt;br /&gt;
			timezone = -timezone&lt;br /&gt;
			timezone = string.format(&amp;quot;%.2d%.2d&amp;quot;, timezone / 60, timezone % 60)&lt;br /&gt;
			if timezone[1] ~= &amp;#039;-&amp;#039; then timezone = &amp;quot;+&amp;quot; .. timezone end&lt;br /&gt;
			date = mw.text.trim(date, &amp;quot;Z&amp;quot;) .. &amp;quot; &amp;quot; .. timezone&lt;br /&gt;
		end&lt;br /&gt;
		]]--&lt;br /&gt;
&lt;br /&gt;
		local formatstr = i18n.datetime[precision]&lt;br /&gt;
		if year == 0 then formatstr = mw.ustring.gsub(formatstr, i18n.datetime[9], &amp;quot;&amp;quot;)&lt;br /&gt;
		elseif year &amp;lt; 0 then&lt;br /&gt;
			-- Mediawiki formatDate doesn&amp;#039;t support negative years&lt;br /&gt;
			date = mw.ustring.sub(date, 2)&lt;br /&gt;
			formatstr = mw.ustring.gsub(formatstr, i18n.datetime[9], mw.ustring.gsub(i18n.datetime.bc, &amp;quot;$1&amp;quot;, i18n.datetime[9]))&lt;br /&gt;
		elseif year &amp;gt; 0 and i18n.datetime.ad ~= &amp;quot;$1&amp;quot; then&lt;br /&gt;
			formatstr = mw.ustring.gsub(formatstr, i18n.datetime[9], mw.ustring.gsub(i18n.datetime.ad, &amp;quot;$1&amp;quot;, i18n.datetime[9]))&lt;br /&gt;
		end&lt;br /&gt;
		if (mw.ustring.find(calendarmodel, &amp;#039;Q1985786&amp;#039;, 1, true)) and year &amp;gt; 1582 then&lt;br /&gt;
			return mw.language.new(wiki.langcode):formatDate(formatstr, date) .. &amp;#039;&amp;lt;sup&amp;gt;&amp;amp;thinsp;[[Juliaanse kalender|jul.]]&amp;lt;/sup&amp;gt;&amp;#039;&lt;br /&gt;
		else&lt;br /&gt;
			return mw.language.new(wiki.langcode):formatDate(formatstr, date)&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function formatDateLink(time, precision, calendarmodel)&lt;br /&gt;
	precision = precision or 11&lt;br /&gt;
	local year, m, d = mw.ustring.match( time, &amp;quot;(%-?%d+)%-(%d+)%-(%d+)T&amp;quot; )&lt;br /&gt;
	local maanden = {&amp;#039;januari&amp;#039;, &amp;#039;februari&amp;#039;, &amp;#039;maart&amp;#039;, &amp;#039;april&amp;#039;, &amp;#039;mei&amp;#039;, &amp;#039;juni&amp;#039;, &amp;#039;juli&amp;#039;, &amp;#039;augustus&amp;#039;, &amp;#039;september&amp;#039;, &amp;#039;oktober&amp;#039;, &amp;#039;november&amp;#039;, &amp;#039;december&amp;#039;}&lt;br /&gt;
	m = tonumber(m)&lt;br /&gt;
	d = tonumber(d)&lt;br /&gt;
	year = tonumber(year)&lt;br /&gt;
&lt;br /&gt;
	-- precision is decades, centuries and millenia&lt;br /&gt;
	local era&lt;br /&gt;
	if precision == 6 then era = mw.ustring.gsub(i18n.datetime[6], &amp;quot;$1&amp;quot;, tostring(math.floor((math.abs(year) - 1) / 1000) + 1)) end&lt;br /&gt;
	if precision == 7 then era = mw.ustring.gsub(i18n.datetime[7], &amp;quot;$1&amp;quot;, tostring(math.floor((math.abs(year) - 1) / 100) + 1)) end&lt;br /&gt;
	if precision == 8 then era = mw.ustring.gsub(i18n.datetime[8], &amp;quot;$1&amp;quot;, tostring(math.floor(math.abs(year) / 10) * 10)) end&lt;br /&gt;
	if era then&lt;br /&gt;
		if year &amp;lt; 0 then era = mw.ustring.gsub(mw.ustring.gsub(i18n.datetime.bc, &amp;#039;&amp;quot;&amp;#039;, &amp;quot;&amp;quot;), &amp;quot;$1&amp;quot;, era)&lt;br /&gt;
		elseif year &amp;gt; 0 then era = mw.ustring.gsub(mw.ustring.gsub(i18n.datetime.ad, &amp;#039;&amp;quot;&amp;#039;, &amp;quot;&amp;quot;), &amp;quot;$1&amp;quot;, era) end&lt;br /&gt;
		return era&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	if precision == 9 then&lt;br /&gt;
		return &amp;#039;[[&amp;#039; .. year .. &amp;#039;]]&amp;#039;&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	if precision == 10 then&lt;br /&gt;
		if m == 8 then&lt;br /&gt;
			return &amp;#039;[[Augustus (maand)|augustus]] [[&amp;#039; .. year .. &amp;#039;]]&amp;#039;&lt;br /&gt;
		else&lt;br /&gt;
			return &amp;#039;[[&amp;#039; .. maanden[m] .. &amp;#039;]] [[&amp;#039; .. year .. &amp;#039;]]&amp;#039;&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	if precision &amp;gt; 10 then&lt;br /&gt;
		if (mw.ustring.find(calendarmodel, &amp;#039;Q1985786&amp;#039;, 1, true)) and year &amp;gt; 1582 then&lt;br /&gt;
			return d .. &amp;#039; &amp;#039; .. maanden[m] .. &amp;#039; &amp;#039; .. year .. &amp;#039;&amp;lt;sup&amp;gt;&amp;amp;thinsp;[[Juliaanse kalender|jul.]]&amp;lt;/sup&amp;gt;&amp;#039;&lt;br /&gt;
		else&lt;br /&gt;
			return &amp;#039;[[&amp;#039; .. d .. &amp;#039; &amp;#039; .. maanden[m] .. &amp;#039;]] [[&amp;#039; .. year .. &amp;#039;]]&amp;#039;&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function printDatavalueTime(data, parameter)&lt;br /&gt;
	-- data fields: time [ISO 8601 time], timezone [int in minutes], before [int], after [int], precision [int], calendarmodel [wikidata URI]&lt;br /&gt;
	--   precision: 0 - billion years, 1 - hundred million years, ..., 6 - millenia, 7 - century, 8 - decade, 9 - year, 10 - month, 11 - day, 12 - hour, 13 - minute, 14 - second&lt;br /&gt;
	--   calendarmodel: e.g. http://www.wikidata.org/entity/Q1985727 for the proleptic Gregorian calendar or http://www.wikidata.org/wiki/Q11184 for the Julian calendar]&lt;br /&gt;
	if parameter then&lt;br /&gt;
		if parameter == &amp;quot;calendarmodel&amp;quot; then data.calendarmodel = mw.ustring.match(data.calendarmodel, &amp;quot;Q%d+&amp;quot;) -- extract entity id from the calendar model URI&lt;br /&gt;
		elseif parameter == &amp;quot;time&amp;quot; then data.time = normalizeDate(data.time) end&lt;br /&gt;
		if parameter == &amp;quot;link&amp;quot; then&lt;br /&gt;
			return formatDateLink(data.time, data.precision, data.calendarmodel)&lt;br /&gt;
		end&lt;br /&gt;
		return data[parameter]&lt;br /&gt;
	else&lt;br /&gt;
		return formatDate(data.time, data.precision, data.timezone, data.calendarmodel)&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function printDatavalueEntity(data, parameter)&lt;br /&gt;
	-- data fields: entity-type [string], numeric-id [int, Wikidata id]&lt;br /&gt;
	local id = &amp;quot;Q&amp;quot; .. data[&amp;quot;numeric-id&amp;quot;]&lt;br /&gt;
	if parameter then&lt;br /&gt;
		if parameter == &amp;quot;link&amp;quot; then&lt;br /&gt;
			local target = mw.wikibase.sitelink(id)&lt;br /&gt;
			if target and string.byte(target, #target) ~= 41 then -- &amp;quot;)&amp;quot;&lt;br /&gt;
				local hbTarget = target .. &amp;quot; (hoofdbetekenis)&amp;quot;&lt;br /&gt;
				local hbTitle = mw.title.new(hbTarget)&lt;br /&gt;
				if hbTitle.isRedirect and hbTitle.redirectTarget.fullText == target then&lt;br /&gt;
					target = hbTarget&lt;br /&gt;
				end&lt;br /&gt;
			end&lt;br /&gt;
			return &amp;quot;[[&amp;quot; .. (target or (&amp;quot;:d:&amp;quot; .. id)) .. &amp;quot;|&amp;quot; .. (mw.wikibase.label(id) or id) .. &amp;quot;]]&amp;quot;&lt;br /&gt;
		else&lt;br /&gt;
			return data[parameter]&lt;br /&gt;
		end&lt;br /&gt;
	else&lt;br /&gt;
		if data[&amp;quot;entity-type&amp;quot;] == &amp;quot;item&amp;quot; then return mw.wikibase.label(&amp;quot;Q&amp;quot; .. data[&amp;quot;numeric-id&amp;quot;]) or id else printError(&amp;quot;unknown-entity-type&amp;quot;) end&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function printDatavalueMonolingualText(data, parameter)&lt;br /&gt;
	-- data fields: language [string], text [string]&lt;br /&gt;
	if parameter then&lt;br /&gt;
		return data[parameter]&lt;br /&gt;
	else&lt;br /&gt;
		return mw.ustring.gsub(mw.ustring.gsub(i18n.monolingualtext, &amp;quot;%%language&amp;quot;, data[&amp;quot;language&amp;quot;]), &amp;quot;%%text&amp;quot;, data[&amp;quot;text&amp;quot;])&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function findClaims(entity, property)&lt;br /&gt;
	if not property or not entity or not entity.claims then return end&lt;br /&gt;
&lt;br /&gt;
	if mw.ustring.match(property, &amp;quot;^P%d+$&amp;quot;) then&lt;br /&gt;
		-- if the property is given by an id (P..) access the claim list by this id&lt;br /&gt;
		return entity.claims[property]&lt;br /&gt;
	else&lt;br /&gt;
		property = mw.wikibase.resolvePropertyId(property)&lt;br /&gt;
		if not property then return end&lt;br /&gt;
&lt;br /&gt;
		return entity.claims[property]&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function getSnakValue(snak, parameter)&lt;br /&gt;
	-- snaks have three types: &amp;quot;novalue&amp;quot; for null/nil, &amp;quot;somevalue&amp;quot; for not null/not nil, or &amp;quot;value&amp;quot; for actual data&lt;br /&gt;
	if snak.snaktype == &amp;quot;novalue&amp;quot; then return i18n[&amp;quot;novalue&amp;quot;]&lt;br /&gt;
	elseif snak.snaktype == &amp;quot;somevalue&amp;quot; then return i18n[&amp;quot;somevalue&amp;quot;]&lt;br /&gt;
	elseif snak.snaktype ~= &amp;quot;value&amp;quot; then return nil, printError(&amp;quot;unknown-snak-type&amp;quot;)&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- call the respective snak parser&lt;br /&gt;
	if snak.datavalue.type == &amp;quot;string&amp;quot; then return snak.datavalue.value&lt;br /&gt;
	elseif snak.datavalue.type == &amp;quot;globecoordinate&amp;quot; then return printDatavalueCoordinate(snak.datavalue.value, parameter)&lt;br /&gt;
	elseif snak.datavalue.type == &amp;quot;quantity&amp;quot; then return printDatavalueQuantity(snak.datavalue.value, parameter)&lt;br /&gt;
	elseif snak.datavalue.type == &amp;quot;time&amp;quot; then return printDatavalueTime(snak.datavalue.value, parameter)&lt;br /&gt;
	elseif snak.datavalue.type == &amp;quot;wikibase-entityid&amp;quot; then return printDatavalueEntity(snak.datavalue.value, parameter)&lt;br /&gt;
	elseif snak.datavalue.type == &amp;quot;monolingualtext&amp;quot; then return printDatavalueMonolingualText(snak.datavalue.value, parameter)&lt;br /&gt;
	else return nil, printError(&amp;quot;unknown-datavalue-type&amp;quot;)&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function getQualifierSnak(claim, qualifierId)&lt;br /&gt;
	-- a &amp;quot;snak&amp;quot; is Wikidata terminology for a typed key/value pair&lt;br /&gt;
	-- a claim consists of a main snak holding the main information of this claim,&lt;br /&gt;
	-- as well as a list of attribute snaks and a list of references snaks&lt;br /&gt;
	if qualifierId then&lt;br /&gt;
		-- search the attribute snak with the given qualifier as key&lt;br /&gt;
		if claim.qualifiers then&lt;br /&gt;
			local qualifier = claim.qualifiers[qualifierId]&lt;br /&gt;
			if qualifier then return qualifier[1] end&lt;br /&gt;
		end&lt;br /&gt;
		return nil, printError(&amp;quot;qualifier-not-found&amp;quot;)&lt;br /&gt;
	else&lt;br /&gt;
		-- otherwise return the main snak&lt;br /&gt;
		return claim.mainsnak&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function getValueOfClaim(claim, qualifierId, parameter)&lt;br /&gt;
	local error&lt;br /&gt;
	local snak&lt;br /&gt;
	snak, error = getQualifierSnak(claim, qualifierId)&lt;br /&gt;
	if snak then&lt;br /&gt;
		return getSnakValue(snak, parameter)&lt;br /&gt;
	else&lt;br /&gt;
		return nil, error&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function getReferences(frame, claim)&lt;br /&gt;
	local result = &amp;quot;&amp;quot;&lt;br /&gt;
	-- traverse through all references&lt;br /&gt;
	for ref in pairs(claim.references or {}) do&lt;br /&gt;
		local refparts&lt;br /&gt;
		-- traverse through all parts of the current reference&lt;br /&gt;
		for snakkey, snakval in orderedpairs(claim.references[ref].snaks or {}, claim.references[ref][&amp;quot;snaks-order&amp;quot;]) do&lt;br /&gt;
			if refparts then refparts = refparts .. &amp;quot;, &amp;quot; else refparts = &amp;quot;&amp;quot; end&lt;br /&gt;
			-- output the label of the property of the reference part, e.g. &amp;quot;imported from&amp;quot; for P143&lt;br /&gt;
			refparts = refparts .. tostring(mw.wikibase.label(snakkey)) .. &amp;quot;: &amp;quot;&lt;br /&gt;
			-- output all values of this reference part, e.g. &amp;quot;German Wikipedia&amp;quot; and &amp;quot;English Wikipedia&amp;quot; if the referenced claim was imported from both sites&lt;br /&gt;
			for snakidx = 1, #snakval do&lt;br /&gt;
				if snakidx &amp;gt; 1 then refparts = refparts .. &amp;quot;, &amp;quot; end&lt;br /&gt;
				refparts = refparts .. getSnakValue(snakval[snakidx])&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
		if refparts then result = result .. frame:extensionTag(&amp;quot;ref&amp;quot;, refparts) end&lt;br /&gt;
	end&lt;br /&gt;
	return result&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.claim(frame)&lt;br /&gt;
	local property = frame.args[1] or &amp;quot;&amp;quot;&lt;br /&gt;
	local id = frame.args[&amp;quot;id&amp;quot;]&lt;br /&gt;
	local qualifierId = frame.args[&amp;quot;qualifier&amp;quot;]&lt;br /&gt;
	local parameter = frame.args[&amp;quot;parameter&amp;quot;]&lt;br /&gt;
	local list = frame.args[&amp;quot;list&amp;quot;]&lt;br /&gt;
	local references = frame.args[&amp;quot;references&amp;quot;]&lt;br /&gt;
	local showerrors = frame.args[&amp;quot;showerrors&amp;quot;]&lt;br /&gt;
	local default = frame.args[&amp;quot;default&amp;quot;]&lt;br /&gt;
	if default then showerrors = nil end&lt;br /&gt;
&lt;br /&gt;
	-- get wikidata entity&lt;br /&gt;
	local entity = mw.wikibase.getEntityObject(id)&lt;br /&gt;
	if not entity then&lt;br /&gt;
		if showerrors then return printError(&amp;quot;entity-not-found&amp;quot;) else return default end&lt;br /&gt;
	end&lt;br /&gt;
	-- fetch the first claim of satisfying the given property&lt;br /&gt;
	local claims = findClaims(entity, property)&lt;br /&gt;
	if not claims or not claims[1] then&lt;br /&gt;
		if showerrors then return printError(&amp;quot;property-not-found&amp;quot;) else return default end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- get initial sort indices&lt;br /&gt;
	local sortindices = {}&lt;br /&gt;
	for idx in pairs(claims) do&lt;br /&gt;
		sortindices[#sortindices + 1] = idx&lt;br /&gt;
	end&lt;br /&gt;
	-- sort by claim rank&lt;br /&gt;
	local comparator = function(a, b)&lt;br /&gt;
		local rankmap = { deprecated = 2, normal = 1, preferred = 0 }&lt;br /&gt;
		local ranka = rankmap[claims[a].rank or &amp;quot;normal&amp;quot;] .. string.format(&amp;quot;%08d&amp;quot;, a)&lt;br /&gt;
		local rankb = rankmap[claims[b].rank or &amp;quot;normal&amp;quot;] .. string.format(&amp;quot;%08d&amp;quot;, b)&lt;br /&gt;
		return ranka &amp;lt; rankb&lt;br /&gt;
	end&lt;br /&gt;
	table.sort(sortindices, comparator)&lt;br /&gt;
&lt;br /&gt;
	local result&lt;br /&gt;
	local error&lt;br /&gt;
	if list then&lt;br /&gt;
		local value&lt;br /&gt;
		-- iterate over all elements and return their value (if existing)&lt;br /&gt;
		result = {}&lt;br /&gt;
		for idx in pairs(claims) do&lt;br /&gt;
			local claim = claims[sortindices[idx]]&lt;br /&gt;
			value, error = getValueOfClaim(claim, qualifierId, parameter)&lt;br /&gt;
			if not value and showerrors then value = error end&lt;br /&gt;
			if value and references then value = value .. getReferences(frame, claim) end&lt;br /&gt;
			result[#result + 1] = value&lt;br /&gt;
		end&lt;br /&gt;
		result = table.concat(result, list)&lt;br /&gt;
	elseif parameter == &amp;quot;count&amp;quot; then&lt;br /&gt;
		result = #claims&lt;br /&gt;
	else&lt;br /&gt;
		-- return first element&lt;br /&gt;
		local claim = claims[sortindices[1]]&lt;br /&gt;
		result, error = getValueOfClaim(claim, qualifierId, parameter)&lt;br /&gt;
		if result and references then result = result .. getReferences(frame, claim) end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	if result then return result else&lt;br /&gt;
		if showerrors then return error else return default end&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.getValue(frame)&lt;br /&gt;
	local param = frame.args[2]&lt;br /&gt;
	if param == &amp;quot;FETCH_WIKIDATA&amp;quot; then return p.claim(frame) else return param end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.pageId(frame)&lt;br /&gt;
	local entity = mw.wikibase.getEntityObject()&lt;br /&gt;
	if not entity then return nil else return entity.id end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.labelOf(frame)&lt;br /&gt;
	local id = frame.args[1]&lt;br /&gt;
	-- returns the label of the given entity/property id&lt;br /&gt;
	-- if no id is given, the one from the entity associated with the calling Wikipedia article is used&lt;br /&gt;
	if not id then&lt;br /&gt;
		local entity = mw.wikibase.getEntityObject()&lt;br /&gt;
		if not entity then return printError(&amp;quot;entity-not-found&amp;quot;) end&lt;br /&gt;
		id = entity.id&lt;br /&gt;
	end&lt;br /&gt;
	return mw.wikibase.label(id)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.sitelinkOf(frame)&lt;br /&gt;
	local id = frame.args[1]&lt;br /&gt;
	-- returns the Wikipedia article name of the given entity&lt;br /&gt;
	-- if no id is given, the one from the entity associated with the calling Wikipedia article is used&lt;br /&gt;
	if not id then&lt;br /&gt;
		local entity = mw.wikibase.getEntityObject()&lt;br /&gt;
		if not entity then return printError(&amp;quot;entity-not-found&amp;quot;) end&lt;br /&gt;
		id = entity.id&lt;br /&gt;
	end&lt;br /&gt;
	return mw.wikibase.sitelink(id)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.badges(frame)&lt;br /&gt;
	local site = frame.args[1]&lt;br /&gt;
	local id = frame.args[2]&lt;br /&gt;
	if not site then return printError(&amp;quot;site-not-found&amp;quot;) end&lt;br /&gt;
	local entity = mw.wikibase.getEntityObject(id)&lt;br /&gt;
	if not entity then return printError(&amp;quot;entity-not-found&amp;quot;) end&lt;br /&gt;
	local badges = entity.sitelinks[site].badges&lt;br /&gt;
	if badges then&lt;br /&gt;
		local result&lt;br /&gt;
		for idx = 1, #badges do&lt;br /&gt;
			if result then result = result .. &amp;quot;/&amp;quot; .. badges[idx] else result = badges[idx] end&lt;br /&gt;
		end&lt;br /&gt;
		return result&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- call this in cases of script errors within a function instead of {{#invoke:Wikidata|&amp;lt;method&amp;gt;|...}} call {{#invoke:Wikidata|debug|&amp;lt;method&amp;gt;|...}}&lt;br /&gt;
function p.debug(frame)&lt;br /&gt;
	local func = frame.args[1]&lt;br /&gt;
	if func then&lt;br /&gt;
		-- create new parameter set, where the first parameter with the function name is removed&lt;br /&gt;
		local newargs = {}&lt;br /&gt;
		for key, val in pairs(frame.args) do&lt;br /&gt;
			if type(key) == &amp;quot;number&amp;quot; then&lt;br /&gt;
				if key &amp;gt; 1 then newargs[key - 1] = val end&lt;br /&gt;
			else&lt;br /&gt;
				newargs[key] = val&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
		frame.args = newargs&lt;br /&gt;
		local status, result = pcall(p[func], frame)&lt;br /&gt;
		if status then return result else return &amp;#039;&amp;lt;span class=&amp;quot;error&amp;quot;&amp;gt;&amp;#039; .. result .. &amp;#039;&amp;lt;/span&amp;gt;&amp;#039; end&lt;br /&gt;
	else&lt;br /&gt;
		return &amp;#039;&amp;lt;span class=&amp;quot;error&amp;quot;&amp;gt;invalid parameters&amp;lt;/span&amp;gt;&amp;#039;&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
return p&lt;/div&gt;</summary>
		<author><name>Colani</name></author>
	</entry>
</feed>