<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="he">
	<id>https://text.chabadpedia.com/index.php?action=history&amp;feed=atom&amp;title=%D7%99%D7%97%D7%99%D7%93%D7%94%3AWikidata</id>
	<title>יחידה:Wikidata - היסטוריית גרסאות</title>
	<link rel="self" type="application/atom+xml" href="https://text.chabadpedia.com/index.php?action=history&amp;feed=atom&amp;title=%D7%99%D7%97%D7%99%D7%93%D7%94%3AWikidata"/>
	<link rel="alternate" type="text/html" href="https://text.chabadpedia.com/index.php?title=%D7%99%D7%97%D7%99%D7%93%D7%94:Wikidata&amp;action=history"/>
	<updated>2026-05-11T03:51:02Z</updated>
	<subtitle>היסטוריית הגרסאות של הדף הזה בוויקי</subtitle>
	<generator>MediaWiki 1.40.3</generator>
	<entry>
		<id>https://text.chabadpedia.com/index.php?title=%D7%99%D7%97%D7%99%D7%93%D7%94:Wikidata&amp;diff=23705&amp;oldid=prev</id>
		<title>מ. רובין: גרסה אחת יובאה</title>
		<link rel="alternate" type="text/html" href="https://text.chabadpedia.com/index.php?title=%D7%99%D7%97%D7%99%D7%93%D7%94:Wikidata&amp;diff=23705&amp;oldid=prev"/>
		<updated>2025-09-07T08:02:26Z</updated>

		<summary type="html">&lt;p&gt;גרסה אחת יובאה&lt;/p&gt;
&lt;table style=&quot;background-color: #fff; color: #202122;&quot; data-mw=&quot;interface&quot;&gt;
				&lt;tr class=&quot;diff-title&quot; lang=&quot;he&quot;&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;→ הגרסה הקודמת&lt;/td&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;גרסה מ־11:02, 7 בספטמבר 2025&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-notice&quot; lang=&quot;he&quot;&gt;&lt;div class=&quot;mw-diff-empty&quot;&gt;(אין הבדלים)&lt;/div&gt;
&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;</summary>
		<author><name>מ. רובין</name></author>
	</entry>
	<entry>
		<id>https://text.chabadpedia.com/index.php?title=%D7%99%D7%97%D7%99%D7%93%D7%94:Wikidata&amp;diff=23704&amp;oldid=prev</id>
		<title>ויקיטקסט&gt;Effib: ייבוא מויקי גרסה מתאריך  04:14, 24 במרץ 2021‏</title>
		<link rel="alternate" type="text/html" href="https://text.chabadpedia.com/index.php?title=%D7%99%D7%97%D7%99%D7%93%D7%94:Wikidata&amp;diff=23704&amp;oldid=prev"/>
		<updated>2022-05-12T17:51:22Z</updated>

		<summary type="html">&lt;p&gt;ייבוא מויקי גרסה מתאריך  04:14, 24 במרץ 2021‏&lt;/p&gt;
&lt;p&gt;&lt;b&gt;דף חדש&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;המאפיין לא נמצא.&amp;quot;,&lt;br /&gt;
        [&amp;quot;entity-not-found&amp;quot;] = &amp;quot;היישות לא נמצאה&amp;quot;,&lt;br /&gt;
        [&amp;quot;unknown-claim-type&amp;quot;] = &amp;quot;מאפיין לא מוכר&amp;quot;,&lt;br /&gt;
        [&amp;quot;unknown-snak-type&amp;quot;] = &amp;quot;Unbekannter Snak-Typ.&amp;quot;,&lt;br /&gt;
        [&amp;quot;unknown-datavalue-type&amp;quot;] = &amp;quot;סוג נתון לא ידוע&amp;quot;,&lt;br /&gt;
        [&amp;quot;unknown-entity-type&amp;quot;] = &amp;quot;סוג יישות לא ידוע&amp;quot;,&lt;br /&gt;
        [&amp;quot;qualifier-not-found&amp;quot;] = &amp;quot;המבחין לא נמצא.&amp;quot;,&lt;br /&gt;
        [&amp;quot;site-not-found&amp;quot;] = &amp;quot;האתר לא נמצא.&amp;quot;,&lt;br /&gt;
    },&lt;br /&gt;
    [&amp;quot;somevalue&amp;quot;] = &amp;quot;Unbekannter Wert&amp;quot;,&lt;br /&gt;
    [&amp;quot;novalue&amp;quot;] = &amp;quot;Kein Wert&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 מיליארד שנים&amp;quot;,		-- precision: billion years&lt;br /&gt;
		[1] = &amp;quot;$100 מיליון שנים&amp;quot;,	-- precision: hundred million years&lt;br /&gt;
		[2] = &amp;quot;$10 מיליון שנים&amp;quot;,	-- precision: ten million years&lt;br /&gt;
		[3] = &amp;quot;$1 מיליון שנים&amp;quot;,		-- precision: million years&lt;br /&gt;
		[4] = &amp;quot;$100,000 שנים&amp;quot;,	-- precision: hundred thousand years&lt;br /&gt;
		[5] = &amp;quot;$10,000 שנים&amp;quot;,		-- precision: ten thousand years&lt;br /&gt;
		[6] = &amp;quot;המילוניום ה-$1&amp;quot;, 	-- precision: millenium&lt;br /&gt;
		[7] = &amp;quot;המאה ה-$1&amp;quot;,	-- precision: century&lt;br /&gt;
		[8] = &amp;quot;$1er&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 xg Y&amp;quot;,			-- precision: day&lt;br /&gt;
		[12] = &amp;#039;j xg Y, G &amp;quot;Uhr&amp;quot;&amp;#039;,	-- precision: hour&lt;br /&gt;
		[13] = &amp;quot;j xg Y G:i&amp;quot;,		-- precision: minute&lt;br /&gt;
		[14] = &amp;quot;j xg Y G:i:s&amp;quot;,		-- precision: second&lt;br /&gt;
		[&amp;quot;beforenow&amp;quot;] = &amp;quot;vor $1&amp;quot;,	-- how to format negative numbers for precisions 0 to 5&lt;br /&gt;
		[&amp;quot;afternow&amp;quot;] = &amp;quot;in $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;ס&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;
function p.descriptionIn(frame)&lt;br /&gt;
	local langcode = frame.args[1]&lt;br /&gt;
	local id = frame.args[2]	-- &amp;quot;id&amp;quot; must be nil, as access to other Wikidata objects is disabled in Mediawiki configuration&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]	-- &amp;quot;id&amp;quot; must be nil, as access to other Wikidata objects is disabled in Mediawiki configuration&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[paramater]&lt;br /&gt;
	else&lt;br /&gt;
		return tonumber(data.amount)&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)&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;
		return mw.language.new(wiki.langcode):formatDate(formatstr, date)&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;
		return data[parameter]&lt;br /&gt;
	else&lt;br /&gt;
		return formatDate(data.time, data.precision, data.timezone)&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;
			return &amp;quot;[[&amp;quot; .. (mw.wikibase.sitelink(id) 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 mw.ustring.format(&amp;#039;%s%s&amp;#039;, id, &amp;#039;[[קטגוריה:ויקינתונים:ערכים_חסרי_תווית_בעברית]]&amp;#039;) 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;
	return entity:getAllStatements(property)&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;
function getQualifierSnak(claim, qualifierId, onlyHebrew)&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&lt;br /&gt;
				-- only hebrew qualifiers for monolingualtext type&lt;br /&gt;
				if onlyHebrew and qualifier[1].datatype == &amp;#039;monolingualtext&amp;#039; then&lt;br /&gt;
					for idx,eachForm in pairs(qualifier) do&lt;br /&gt;
						if eachForm.datavalue.value.language == &amp;#039;he&amp;#039; then&lt;br /&gt;
							return qualifier[idx]&lt;br /&gt;
						end&lt;br /&gt;
					end&lt;br /&gt;
				else&lt;br /&gt;
					return qualifier[1]&lt;br /&gt;
				end&lt;br /&gt;
			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;
function getValueOfClaim(claim, qualifierId, parameter)&lt;br /&gt;
	local error&lt;br /&gt;
	local snak&lt;br /&gt;
	&lt;br /&gt;
	local onlyHebrew&lt;br /&gt;
	if qualifierId == &amp;#039;P2096&amp;#039; then onlyHebrew = true end&lt;br /&gt;
	&lt;br /&gt;
	snak, error = getQualifierSnak(claim, qualifierId, onlyHebrew)&lt;br /&gt;
	if snak then&lt;br /&gt;
&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;
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;
-- Check if the &amp;#039;qualifierId&amp;#039; exists on the &amp;#039;property&amp;#039; of given &amp;#039;id&amp;#039;&lt;br /&gt;
function p.isClaimExist(property, qualifierId, id)&lt;br /&gt;
	-- get wikidata entity&lt;br /&gt;
	local entity = mw.wikibase.getEntityObject(id or nil)&lt;br /&gt;
	&lt;br /&gt;
	if not entity then&lt;br /&gt;
		return false&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;
	&lt;br /&gt;
	if not claims or not claims[1] then&lt;br /&gt;
		return false&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;
	&lt;br /&gt;
	-- check if there is an element	&lt;br /&gt;
	local claim = claims[sortindices[1]]&lt;br /&gt;
	result, error = getValueOfClaim(claim, qualifierId, parameter)&lt;br /&gt;
	return result ~= nil&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;]	-- &amp;quot;id&amp;quot; must be nil, as access to other Wikidata objects is disabled in Mediawiki configuration&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;
	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;
	return mw.wikibase.getEntityIdForCurrentPage()&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]	-- &amp;quot;id&amp;quot; must be nil, as access to other Wikidata objects is disabled in Mediawiki configuration&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;
function printTable(data, level)&lt;br /&gt;
	level = tonumber(level) or 0&lt;br /&gt;
	local result = &amp;quot;&amp;quot;&lt;br /&gt;
	local prefix = &amp;quot;&amp;quot;&lt;br /&gt;
	for idx = 1, level do prefix = prefix .. &amp;quot;　&amp;quot; end&lt;br /&gt;
	&lt;br /&gt;
	if type(data) == &amp;quot;table&amp;quot; then&lt;br /&gt;
		for key, val in pairs(data) do&lt;br /&gt;
			result = result .. prefix .. key .. &amp;quot;: &amp;quot;&lt;br /&gt;
			if type(val) == &amp;quot;table&amp;quot; then result = result .. &amp;quot;\n&amp;quot; .. printTable(val, level + 1) else result = result .. tostring(val) .. &amp;quot;\n&amp;quot; end&lt;br /&gt;
		end&lt;br /&gt;
	else&lt;br /&gt;
		result = prefix .. tostring(data)&lt;br /&gt;
	end&lt;br /&gt;
	if level == 0 then result = &amp;quot;&amp;lt;pre&amp;gt;&amp;quot; .. mw.text.encode(result) .. &amp;quot;&amp;lt;/pre&amp;gt;&amp;quot; end&lt;br /&gt;
	return result&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- look into entity object&lt;br /&gt;
function p.ViewSomething(frame)&lt;br /&gt;
	local i = 1&lt;br /&gt;
	local f = frame.args[1] and frame or frame:getParent()&lt;br /&gt;
	local data&lt;br /&gt;
	if f.args[1] ==&amp;#039;claims&amp;#039; and f.args[2] then&lt;br /&gt;
		data = mw.wikibase.getAllStatements( mw.wikibase.getEntityIdForCurrentPage(), f.args[2] )&lt;br /&gt;
		i=i+2&lt;br /&gt;
	else&lt;br /&gt;
		data = mw.wikibase.getEntityObject()&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	if not data then&lt;br /&gt;
		return nil&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	while true do&lt;br /&gt;
		local index = f.args[i]&lt;br /&gt;
		if not index then&lt;br /&gt;
			if type(data) == &amp;quot;table&amp;quot; then&lt;br /&gt;
				return mw.text.jsonEncode(data, mw.text.JSON_PRESERVE_KEYS + mw.text.JSON_PRETTY)&lt;br /&gt;
			else&lt;br /&gt;
				return tostring(data)&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
		&lt;br /&gt;
		data = data[index] or data[tonumber(index)]&lt;br /&gt;
		if not data then&lt;br /&gt;
			return&lt;br /&gt;
		end&lt;br /&gt;
		&lt;br /&gt;
		i = i + 1&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.printEntity(frame)&lt;br /&gt;
	local id = frame.args[1] -- &amp;quot;id&amp;quot; must be nil, as access to other Wikidata objects is disabled in Mediawiki configuration&lt;br /&gt;
	local entity = mw.wikibase.getEntityObject(id)&lt;br /&gt;
	return printTable(entity)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function computeLinkToItem(entityId, capitalize, callFunction)&lt;br /&gt;
	local sitelink = mw.wikibase.sitelink(StringUtils._prependIfMissing({tostring(entityId), &amp;#039;Q&amp;#039;}))&lt;br /&gt;
	local label = nil&lt;br /&gt;
	local object = mw.wikibase.getEntityObject(StringUtils._prependIfMissing({tostring(entityId), &amp;#039;Q&amp;#039;}))&lt;br /&gt;
	if callFunction and type(callFunction) == &amp;#039;function&amp;#039; then&lt;br /&gt;
		label = callFunction(object)&lt;br /&gt;
	end&lt;br /&gt;
	if label == nil then label = mw.wikibase.label(StringUtils._prependIfMissing({tostring(entityId), &amp;#039;Q&amp;#039;})) end&lt;br /&gt;
	if label == nil and object ~= nil then label = object:getLabel(&amp;#039;en&amp;#039;) end&lt;br /&gt;
	if label == nil then label = StringUtils._prependIfMissing({tostring(entityId), &amp;#039;Q&amp;#039;}) end&lt;br /&gt;
&lt;br /&gt;
	if capitalize then&lt;br /&gt;
		label = lang:ucfirst(label)&lt;br /&gt;
	end&lt;br /&gt;
	if sitelink then&lt;br /&gt;
		return &amp;quot;[[:&amp;quot; .. sitelink .. &amp;quot;|&amp;quot; .. label .. &amp;quot;]]&amp;quot;&lt;br /&gt;
	else&lt;br /&gt;
		return &amp;quot;[[:d:&amp;quot; .. StringUtils._prependIfMissing({tostring(entityId), &amp;#039;Q&amp;#039;}) .. &amp;quot;|&amp;quot; .. label .. &amp;quot;]]&amp;lt;abbr title=&amp;#039;הערך אינו קיים בויקי זה&amp;#039;&amp;gt;[*]&amp;lt;/abbr&amp;gt;&amp;quot;&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
p.findLinkToItem = function(entityId, capitalize, feminine, shortestAlias)&lt;br /&gt;
	if capitalize == nil then capitalize = false end&lt;br /&gt;
	local callFunction = nil&lt;br /&gt;
	if shortestAlias then&lt;br /&gt;
		callFunction = function(object)&lt;br /&gt;
			local returnedAlias = nil&lt;br /&gt;
			if object then&lt;br /&gt;
				if object.claims and object.claims[&amp;#039;P1813&amp;#039;] then&lt;br /&gt;
					local shortNameEn = nil&lt;br /&gt;
					for shortNameIdx,shortNameClaim in pairs(object.claims[&amp;#039;P1813&amp;#039;]) do&lt;br /&gt;
						if shortNameClaim.mainsnak.datavalue.value.language == &amp;#039;en&amp;#039; then shortNameEn = shortNameClaim.mainsnak.datavalue.value.text end&lt;br /&gt;
						if shortNameClaim.mainsnak.datavalue.value.language == &amp;#039;ro&amp;#039; then returnedAlias = shortNameClaim.mainsnak.datavalue.value.text end&lt;br /&gt;
					end&lt;br /&gt;
					returnedAlias = returnedAlias or shortNameEn&lt;br /&gt;
				end&lt;br /&gt;
			end&lt;br /&gt;
			return returnedAlias&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	if feminine then&lt;br /&gt;
		callFunction = function(object)&lt;br /&gt;
			if object then&lt;br /&gt;
				local feminineForms = object:getBestStatements(&amp;#039;P2521&amp;#039;)&lt;br /&gt;
				if feminineForms then&lt;br /&gt;
					for _idx, eachFForm in pairs(feminineForms) do&lt;br /&gt;
						if eachFForm.type == &amp;#039;statement&amp;#039; and eachFForm.mainsnak.datatype == &amp;#039;monolingualtext&amp;#039; and eachFForm.mainsnak.datavalue.type == &amp;#039;monolingualtext&amp;#039; and eachFForm.mainsnak.datavalue.value and eachFForm.mainsnak.datavalue.value.language == &amp;#039;he&amp;#039; then&lt;br /&gt;
							return eachFForm.mainsnak.datavalue.value.text&lt;br /&gt;
						end&lt;br /&gt;
					end&lt;br /&gt;
				end&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	return computeLinkToItem(entityId, capitalize, callFunction)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- check whether entityId has a claim with propertyId referencing to claimedEntity&lt;br /&gt;
p.hasClaim = function(entityId, propertyId, claimedEntity)&lt;br /&gt;
	if entityId==nil or propertyId==nil then return false end&lt;br /&gt;
	local propertyVals = mw.wikibase.getBestStatements(entityId, propertyId)&lt;br /&gt;
	if (not propertyVals) or (#propertyVals==0) then return false end&lt;br /&gt;
	for i, property in ipairs(propertyVals) do&lt;br /&gt;
	    local propValue = property.mainsnak and property.mainsnak.datavalue&lt;br /&gt;
	    if not propValue then return false end&lt;br /&gt;
	    if propValue.value[&amp;#039;id&amp;#039;] == claimedEntity then&lt;br /&gt;
	    	return true&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	return false&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
p.getValueOfClaim = getValueOfClaim&lt;br /&gt;
return p&lt;/div&gt;</summary>
		<author><name>ויקיטקסט&gt;Effib</name></author>
	</entry>
</feed>