<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="en">
	<id>https://edubase.wiki/api.php?action=feedcontributions&amp;feedformat=atom&amp;user=Aron.hives%40edubase.net</id>
	<title>EduBase Wiki - User contributions [en]</title>
	<link rel="self" type="application/atom+xml" href="https://edubase.wiki/api.php?action=feedcontributions&amp;feedformat=atom&amp;user=Aron.hives%40edubase.net"/>
	<link rel="alternate" type="text/html" href="https://edubase.wiki/index.php?title=Special:Contributions/Aron.hives@edubase.net"/>
	<updated>2026-05-10T12:56:14Z</updated>
	<subtitle>User contributions</subtitle>
	<generator>MediaWiki 1.42.7</generator>
	<entry>
		<id>https://edubase.wiki/index.php?title=Test_page&amp;diff=27371</id>
		<title>Test page</title>
		<link rel="alternate" type="text/html" href="https://edubase.wiki/index.php?title=Test_page&amp;diff=27371"/>
		<updated>2023-03-19T16:29:54Z</updated>

		<summary type="html">&lt;p&gt;Aron.hives@edubase.net: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;Hello World!&lt;/div&gt;</summary>
		<author><name>Aron.hives@edubase.net</name></author>
	</entry>
	<entry>
		<id>https://edubase.wiki/index.php?title=Test_page&amp;diff=27370</id>
		<title>Test page</title>
		<link rel="alternate" type="text/html" href="https://edubase.wiki/index.php?title=Test_page&amp;diff=27370"/>
		<updated>2023-03-19T16:29:46Z</updated>

		<summary type="html">&lt;p&gt;Aron.hives@edubase.net: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;Hello World!!&lt;/div&gt;</summary>
		<author><name>Aron.hives@edubase.net</name></author>
	</entry>
	<entry>
		<id>https://edubase.wiki/index.php?title=Test_page&amp;diff=27369</id>
		<title>Test page</title>
		<link rel="alternate" type="text/html" href="https://edubase.wiki/index.php?title=Test_page&amp;diff=27369"/>
		<updated>2023-03-19T16:29:34Z</updated>

		<summary type="html">&lt;p&gt;Aron.hives@edubase.net: Created page with &amp;quot;Hello World!&amp;quot;&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;Hello World!&lt;/div&gt;</summary>
		<author><name>Aron.hives@edubase.net</name></author>
	</entry>
	<entry>
		<id>https://edubase.wiki/index.php?title=MediaWiki:Pluggableauth-loginbutton-label&amp;diff=27368</id>
		<title>MediaWiki:Pluggableauth-loginbutton-label</title>
		<link rel="alternate" type="text/html" href="https://edubase.wiki/index.php?title=MediaWiki:Pluggableauth-loginbutton-label&amp;diff=27368"/>
		<updated>2019-12-30T13:48:25Z</updated>

		<summary type="html">&lt;p&gt;Aron.hives@edubase.net: Created page with &amp;quot;Log in with EduBase&amp;quot;&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;Log in with EduBase&lt;/div&gt;</summary>
		<author><name>Aron.hives@edubase.net</name></author>
	</entry>
	<entry>
		<id>https://edubase.wiki/index.php?title=Template:Fmbox&amp;diff=27366</id>
		<title>Template:Fmbox</title>
		<link rel="alternate" type="text/html" href="https://edubase.wiki/index.php?title=Template:Fmbox&amp;diff=27366"/>
		<updated>2018-11-12T22:47:36Z</updated>

		<summary type="html">&lt;p&gt;Aron.hives@edubase.net: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;{{#invoke:Message box|fmbox}}&amp;lt;noinclude&amp;gt;&lt;br /&gt;
{{documentation}}&lt;br /&gt;
&amp;lt;!-- Add categories and interwikis to the /doc subpage, not here! --&amp;gt;&lt;br /&gt;
&amp;lt;/noinclude&amp;gt;&lt;/div&gt;</summary>
		<author><name>Aron.hives@edubase.net</name></author>
	</entry>
	<entry>
		<id>https://edubase.wiki/index.php?title=Template:Editnotice&amp;diff=27364</id>
		<title>Template:Editnotice</title>
		<link rel="alternate" type="text/html" href="https://edubase.wiki/index.php?title=Template:Editnotice&amp;diff=27364"/>
		<updated>2018-11-12T22:47:35Z</updated>

		<summary type="html">&lt;p&gt;Aron.hives@edubase.net: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;{{#ifeq:{{FULLROOTPAGENAME}}|Template:Editnotices&lt;br /&gt;
 |{{Editnotice/notice&lt;br /&gt;
  |expiry={{{expiry|¬}}}&lt;br /&gt;
  |redirect={{{redirect|}}}&lt;br /&gt;
 }}&lt;br /&gt;
}}{{#ifexpr:{{#ifeq:{{FULLROOTPAGENAME}}|Template:Editnotices&lt;br /&gt;
  |1&lt;br /&gt;
  |0&lt;br /&gt;
 }}+{{#switch:{{{expiry|¬}}}&lt;br /&gt;
  |indefinite = 1&lt;br /&gt;
  |&lt;br /&gt;
  |¬          = 1 &amp;lt;!-- Expiry not specified --&amp;gt;&lt;br /&gt;
  |#default   = {{#iferror:{{#time:U|{{{expiry}}}}}&lt;br /&gt;
   |0 &amp;lt;!-- Invalid expiry time --&amp;gt;&lt;br /&gt;
   |{{#ifexpr:{{#time:U|{{{expiry}}}}}-{{#time:U|{{CURRENTTIMESTAMP}}}}&amp;gt;0&lt;br /&gt;
    |1 &amp;lt;!-- Notice current --&amp;gt;&lt;br /&gt;
    |0 &amp;lt;!-- Notice expired --&amp;gt;&lt;br /&gt;
   }}&lt;br /&gt;
  }}&lt;br /&gt;
 }}&lt;br /&gt;
 |{{fmbox&lt;br /&gt;
  |type      = {{{type|editnotice}}}&lt;br /&gt;
  |id        = {{{id|}}}&lt;br /&gt;
  |textstyle = {{{textstyle|}}}&lt;br /&gt;
  |style     = {{{style|}}}&lt;br /&gt;
  |class     = {{{class|}}}&lt;br /&gt;
  |image     = {{#if:{{{image|}}}&lt;br /&gt;
   |{{#invoke:InfoboxImage|InfoboxImage|image={{{image}}}|size={{{imagesize|}}}|sizedefault=40x40px}}&lt;br /&gt;
   |none&lt;br /&gt;
  }}&lt;br /&gt;
  |imageright= {{#if:{{{imageright|}}}&lt;br /&gt;
   |{{#invoke:InfoboxImage|InfoboxImage|image={{{imageright}}}|size={{{imagerightsize|}}}|sizedefault=40x40px}}&lt;br /&gt;
  }}&lt;br /&gt;
  |text      = {{#if:{{{header|}}}&lt;br /&gt;
   |&amp;lt;div style=&amp;quot;font-weight: bold; {{{headerstyle|}}}&amp;quot;&amp;gt;{{{header}}}&amp;lt;/div&amp;gt;&lt;br /&gt;
  }}&lt;br /&gt;
{{{text|{{{1}}}}}}&lt;br /&gt;
 }}&lt;br /&gt;
}}{{#ifeq:{{FULLROOTPAGENAME}}|Template:Editnotices|{{#switch:{{{expiry|¬}}}&lt;br /&gt;
  |indefinite&lt;br /&gt;
  |&lt;br /&gt;
  |¬          = &amp;lt;!-- Expiry not specified --&amp;gt;&lt;br /&gt;
  |#default   = {{#iferror:{{#time:U|{{{expiry}}}}}&lt;br /&gt;
   | &amp;lt;!-- Invalid expiry time --&amp;gt;&lt;br /&gt;
   |{{#ifexpr:{{#time:U|{{{expiry}}}}}-{{#time:U|{{CURRENTTIMESTAMP}}}}&amp;gt;0&lt;br /&gt;
    | &amp;lt;!-- Notice current --&amp;gt;&lt;br /&gt;
    |[[Category:Expired editnotices]] &amp;lt;!-- Notice expired --&amp;gt;&lt;br /&gt;
   }}&lt;br /&gt;
  }}&lt;br /&gt;
 }}&lt;br /&gt;
}}&amp;lt;noinclude&amp;gt;&lt;br /&gt;
{{documentation}}&lt;br /&gt;
&amp;lt;/noinclude&amp;gt;&lt;/div&gt;</summary>
		<author><name>Aron.hives@edubase.net</name></author>
	</entry>
	<entry>
		<id>https://edubase.wiki/index.php?title=Module:WikidataIB/sandbox&amp;diff=27362</id>
		<title>Module:WikidataIB/sandbox</title>
		<link rel="alternate" type="text/html" href="https://edubase.wiki/index.php?title=Module:WikidataIB/sandbox&amp;diff=27362"/>
		<updated>2018-11-12T22:47:35Z</updated>

		<summary type="html">&lt;p&gt;Aron.hives@edubase.net: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;-- Module to implement use of a blacklist and whitelist for infobox fields&lt;br /&gt;
-- Can take a named parameter |qid which is the Wikidata ID for the article&lt;br /&gt;
-- if not supplied, it will use the Wikidata ID associated with the current page.&lt;br /&gt;
-- Fields in blacklist are never to be displayed, i.e. module must return nil in all circumstances&lt;br /&gt;
-- Fields in whitelist return local value if it exists or the Wikidata value otherwise&lt;br /&gt;
-- The name of the field that this function is called from is passed in named parameter |name&lt;br /&gt;
-- The name is compulsory when blacklist or whitelist is used,&lt;br /&gt;
-- so the module returns nil if it is not supplied.&lt;br /&gt;
-- blacklist is passed in named parameter |suppressfields (or |spf)&lt;br /&gt;
-- whitelist is passed in named parameter |fetchwikidata (or |fwd)&lt;br /&gt;
&lt;br /&gt;
local p = {}&lt;br /&gt;
&lt;br /&gt;
local cdate = require(&amp;quot;Module:Complex date&amp;quot;)._complex_date&lt;br /&gt;
-- [[Module:Complex date]] has the following dependencies:&lt;br /&gt;
-- Module:i18n/complex date, Module:ISOdate, Module:DateI18n (Module:Date), Module:Formatnum,&lt;br /&gt;
-- Module:I18n/date, Module:Yesno, Module:Linguistic, Module:Calendar&lt;br /&gt;
-- The following, taken from https://www.mediawiki.org/wiki/Wikibase/DataModel#Dates_and_times,&lt;br /&gt;
-- is needed to use Module:Complex date which seemingly requires date precision as a string.&lt;br /&gt;
-- It would work better if only the authors of the mediawiki page could spell &#039;millennium&#039;.&lt;br /&gt;
local dp = {&lt;br /&gt;
	[6] = &amp;quot;millennium&amp;quot;,&lt;br /&gt;
	[7] = &amp;quot;century&amp;quot;,&lt;br /&gt;
	[8] = &amp;quot;decade&amp;quot;,&lt;br /&gt;
	[9] = &amp;quot;year&amp;quot;,&lt;br /&gt;
	[10] = &amp;quot;month&amp;quot;,&lt;br /&gt;
	[11] = &amp;quot;day&amp;quot;,&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
local i18n =&lt;br /&gt;
{&lt;br /&gt;
	[&amp;quot;errors&amp;quot;] =&lt;br /&gt;
	{&lt;br /&gt;
		[&amp;quot;property-not-found&amp;quot;] = &amp;quot;Property not found.&amp;quot;,&lt;br /&gt;
		[&amp;quot;No property supplied&amp;quot;] = &amp;quot;No property supplied&amp;quot;,&lt;br /&gt;
		[&amp;quot;entity-not-found&amp;quot;] = &amp;quot;Wikidata entity not found.&amp;quot;,&lt;br /&gt;
		[&amp;quot;unknown-claim-type&amp;quot;] = &amp;quot;Unknown claim type.&amp;quot;,&lt;br /&gt;
		[&amp;quot;unknown-entity-type&amp;quot;] = &amp;quot;Unknown entity type.&amp;quot;,&lt;br /&gt;
		[&amp;quot;qualifier-not-found&amp;quot;] = &amp;quot;Qualifier not found.&amp;quot;,&lt;br /&gt;
		[&amp;quot;site-not-found&amp;quot;] = &amp;quot;Wikimedia project not found.&amp;quot;,&lt;br /&gt;
		[&amp;quot;labels-not-found&amp;quot;] = &amp;quot;No labels found.&amp;quot;,&lt;br /&gt;
		[&amp;quot;descriptions-not-found&amp;quot;] = &amp;quot;No descriptions found.&amp;quot;,&lt;br /&gt;
		[&amp;quot;aliases-not-found&amp;quot;] = &amp;quot;No aliases found.&amp;quot;,&lt;br /&gt;
		[&amp;quot;unknown-datetime-format&amp;quot;] = &amp;quot;Unknown datetime format.&amp;quot;,&lt;br /&gt;
		[&amp;quot;local-article-not-found&amp;quot;] = &amp;quot;Article is available on Wikidata, but not on Wikipedia&amp;quot;,&lt;br /&gt;
		[&amp;quot;dab-page&amp;quot;] = &amp;quot; (dab)&amp;quot;,&lt;br /&gt;
	},&lt;br /&gt;
	[&amp;quot;months&amp;quot;] =&lt;br /&gt;
	{&lt;br /&gt;
		&amp;quot;January&amp;quot;, &amp;quot;February&amp;quot;, &amp;quot;March&amp;quot;, &amp;quot;April&amp;quot;, &amp;quot;May&amp;quot;, &amp;quot;June&amp;quot;,&lt;br /&gt;
		&amp;quot;July&amp;quot;, &amp;quot;August&amp;quot;, &amp;quot;September&amp;quot;, &amp;quot;October&amp;quot;, &amp;quot;November&amp;quot;, &amp;quot;December&amp;quot;&lt;br /&gt;
	},&lt;br /&gt;
	[&amp;quot;century&amp;quot;] = &amp;quot;century&amp;quot;,&lt;br /&gt;
	[&amp;quot;BC&amp;quot;] = &amp;quot;BC&amp;quot;,&lt;br /&gt;
	[&amp;quot;BCE&amp;quot;] = &amp;quot;BCE&amp;quot;,&lt;br /&gt;
	[&amp;quot;ordinal&amp;quot;] =&lt;br /&gt;
	{&lt;br /&gt;
		[1] = &amp;quot;st&amp;quot;,&lt;br /&gt;
		[2] = &amp;quot;nd&amp;quot;,&lt;br /&gt;
		[3] = &amp;quot;rd&amp;quot;,&lt;br /&gt;
		[&amp;quot;default&amp;quot;] = &amp;quot;th&amp;quot;&lt;br /&gt;
	},&lt;br /&gt;
	[&amp;quot;filespace&amp;quot;] = &amp;quot;File&amp;quot;,&lt;br /&gt;
	[&amp;quot;Unknown&amp;quot;] = &amp;quot;Unknown&amp;quot;,&lt;br /&gt;
	[&amp;quot;NaN&amp;quot;] = &amp;quot;Not a number&amp;quot;,&lt;br /&gt;
	-- set the following to the name of a tracking category,&lt;br /&gt;
	-- e.g. &amp;quot;[[Category:Articles with missing Wikidata information]]&amp;quot;, or &amp;quot;&amp;quot; to disable:&lt;br /&gt;
	[&amp;quot;missinginfocat&amp;quot;] = &amp;quot;[[Category:Articles with missing Wikidata information]]&amp;quot;,&lt;br /&gt;
	[&amp;quot;editonwikidata&amp;quot;] = &amp;quot;Edit this on Wikidata&amp;quot;,&lt;br /&gt;
	[&amp;quot;latestdatequalifier&amp;quot;] = function (date) return &amp;quot;before &amp;quot; .. date end,&lt;br /&gt;
	-- some languages, e.g. Bosnian use a period as a suffix after each number in a date&lt;br /&gt;
	[&amp;quot;datenumbersuffix&amp;quot;] = &amp;quot;&amp;quot;,&lt;br /&gt;
	[&amp;quot;list separator&amp;quot;] = &amp;quot;, &amp;quot;,&lt;br /&gt;
	[&amp;quot;multipliers&amp;quot;] = {&lt;br /&gt;
		[0]  = &amp;quot;&amp;quot;,&lt;br /&gt;
		[3]  = &amp;quot; thousand&amp;quot;,&lt;br /&gt;
		[6]  = &amp;quot; million&amp;quot;,&lt;br /&gt;
		[9]  = &amp;quot; billion&amp;quot;,&lt;br /&gt;
		[12] = &amp;quot; trillion&amp;quot;,&lt;br /&gt;
	}&lt;br /&gt;
}&lt;br /&gt;
-- This allows a internationisation module to override the above table&lt;br /&gt;
require(&amp;quot;Module:i18n&amp;quot;).loadI18n(&amp;quot;Module:WikidataIB/i18n&amp;quot;, i18n)&lt;br /&gt;
&lt;br /&gt;
-- This piece of html implements a collapsible container. Check the classes exist on your wiki.&lt;br /&gt;
local collapsediv = &#039;&amp;lt;div class=&amp;quot;mw-collapsible mw-collapsed&amp;quot; style=&amp;quot;width:100%; overflow:auto;&amp;quot; data-expandtext=&amp;quot;{{int:show}}&amp;quot; data-collapsetext=&amp;quot;{{int:hide}}&amp;quot;&amp;gt;&#039;&lt;br /&gt;
&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- Private functions&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
--&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- makeOrdinal needs to be internationalised along with the above:&lt;br /&gt;
-- takes cardinal numer as a numeric and returns the ordinal as a string&lt;br /&gt;
-- we need three exceptions in English for 1st, 2nd, 3rd, 21st, .. 31st, etc.&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- Dependencies: none&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
local makeOrdinal = function(cardinal)&lt;br /&gt;
	local ordsuffix = i18n.ordinal.default&lt;br /&gt;
	if cardinal % 10 == 1 then&lt;br /&gt;
		ordsuffix = i18n.ordinal[1]&lt;br /&gt;
	elseif cardinal % 10 == 2 then&lt;br /&gt;
		ordsuffix = i18n.ordinal[2]&lt;br /&gt;
	elseif cardinal % 10 == 3 then&lt;br /&gt;
		ordsuffix = i18n.ordinal[3]&lt;br /&gt;
	end&lt;br /&gt;
	-- In English, 1, 21, 31, etc. use &#039;st&#039;, but 11, 111, etc. use &#039;th&#039;&lt;br /&gt;
	-- similarly for 12 and 13, etc.&lt;br /&gt;
	if (cardinal % 100 == 11) or (cardinal % 100 == 12) or (cardinal % 100 == 13) then&lt;br /&gt;
		ordsuffix = i18n.ordinal.default&lt;br /&gt;
	end&lt;br /&gt;
	return tostring(cardinal) .. ordsuffix&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- findLang takes a &amp;quot;langcode&amp;quot; parameter if if supplied and valid&lt;br /&gt;
-- otherwise it tries to create it from the user&#039;s set language ({{int:lang}})&lt;br /&gt;
-- failing that it uses the wiki&#039;s content language.&lt;br /&gt;
-- It returns a language object&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- Dependencies: none&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
local findLang = function(langcode)&lt;br /&gt;
	local langobj&lt;br /&gt;
	langcode = mw.text.trim(langcode or &amp;quot;&amp;quot;)&lt;br /&gt;
	if mw.language.isKnownLanguageTag(langcode) then&lt;br /&gt;
		langobj = mw.language.new( langcode )&lt;br /&gt;
	else&lt;br /&gt;
		langcode = mw.getCurrentFrame():preprocess( &#039;{{int:lang}}&#039; )&lt;br /&gt;
		if mw.language.isKnownLanguageTag(langcode) then&lt;br /&gt;
			langobj = mw.language.new( langcode )&lt;br /&gt;
		else&lt;br /&gt;
			langobj = mw.language.getContentLanguage()&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	return langobj&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- roundto takes a number (x)&lt;br /&gt;
-- and returns it rounded to (sf) significant figures&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- Dependencies: none&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
local roundto = function(x, sf)&lt;br /&gt;
	if x == 0 then return 0 end&lt;br /&gt;
	local s = 1&lt;br /&gt;
	if x &amp;lt; 0 then&lt;br /&gt;
		x = -x&lt;br /&gt;
		s = -1&lt;br /&gt;
	end&lt;br /&gt;
	if sf &amp;lt; 1 then sf = 1 end&lt;br /&gt;
	local p = 10 ^ (math.floor(math.log10(x)) - sf + 1)&lt;br /&gt;
	x = math.floor(x / p + 0.5) * p * s&lt;br /&gt;
	-- if it&#039;s integral, cast to an integer:&lt;br /&gt;
	if x == math.floor(x) then x = math.floor(x) end&lt;br /&gt;
	return x&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- decimalToDMS takes a decimal degrees (x) with precision (p)&lt;br /&gt;
-- and returns degrees/minutes/seconds according to the precision&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- Dependencies: none&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
local decimalToDMS = function(x, p)&lt;br /&gt;
	-- if p is not supplied, use a precision around 0.1 seconds&lt;br /&gt;
	if not tonumber(p) then p = 1e-4 end&lt;br /&gt;
	local d = math.floor(x)&lt;br /&gt;
	local ms = (x - d) * 60&lt;br /&gt;
	if p &amp;gt; 0.5 then -- precision is &amp;gt; 1/2 a degree&lt;br /&gt;
		if ms &amp;gt; 30 then d = d + 1 end&lt;br /&gt;
		ms = 0&lt;br /&gt;
	end&lt;br /&gt;
	local m = math.floor(ms)&lt;br /&gt;
	local s = (ms - m) * 60&lt;br /&gt;
	if p &amp;gt; 0.008 then -- precision is &amp;gt; 1/2 a minute&lt;br /&gt;
		if s &amp;gt; 30 then m = m +1 end&lt;br /&gt;
		s = 0&lt;br /&gt;
	elseif p &amp;gt; 0.00014 then -- precision is &amp;gt; 1/2 a second&lt;br /&gt;
		s = math.floor(s + 0.5)&lt;br /&gt;
	elseif p &amp;gt; 0.000014 then -- precision is &amp;gt; 1/20 second&lt;br /&gt;
		s = math.floor(10 * s + 0.5) / 10&lt;br /&gt;
	elseif p &amp;gt; 0.0000014 then -- precision is &amp;gt; 1/200 second&lt;br /&gt;
		s = math.floor(100 * s + 0.5) / 100&lt;br /&gt;
	else -- cap it at 3 dec places for now&lt;br /&gt;
		s = math.floor(1000 * s + 0.5) / 1000&lt;br /&gt;
	end&lt;br /&gt;
	return d, m, s&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- decimalPrecision takes a decimal (x) with precision (p)&lt;br /&gt;
-- and returns x rounded approximately to the given precision&lt;br /&gt;
-- precision should be between 1 and 1e-6, preferably a power of 10.&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- Dependencies: none&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
local decimalPrecision = function(x, p)&lt;br /&gt;
	local s = 1&lt;br /&gt;
	if x &amp;lt; 0 then&lt;br /&gt;
		x = -x&lt;br /&gt;
		s = -1&lt;br /&gt;
	end&lt;br /&gt;
	-- if p is not supplied, pick an arbitrary precision&lt;br /&gt;
	if not tonumber(p) then p = 1e-4&lt;br /&gt;
	elseif p &amp;gt; 1 then p = 1&lt;br /&gt;
	elseif p &amp;lt; 1e-6 then p = 1e-6&lt;br /&gt;
	else p = 10 ^ math.floor(math.log10(p))&lt;br /&gt;
	end&lt;br /&gt;
	x = math.floor(x / p + 0.5) * p * s&lt;br /&gt;
	-- if it&#039;s integral, cast to an integer:&lt;br /&gt;
	if  x == math.floor(x) then x = math.floor(x) end&lt;br /&gt;
	-- if it&#039;s less than 1e-4, it will be in exponent form, so return a string with 6dp&lt;br /&gt;
	-- 9e-5 becomes 0.000090&lt;br /&gt;
	if math.abs(x) &amp;lt; 1e-4 then x = string.format(&amp;quot;%f&amp;quot;, x) end&lt;br /&gt;
	return x&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- formatDate takes a datetime of the usual format from mw.wikibase.entity:formatPropertyValues&lt;br /&gt;
-- like &amp;quot;1 August 30 BCE&amp;quot; as parameter 1&lt;br /&gt;
-- and formats it according to the df (date format) and bc parameters&lt;br /&gt;
-- df = [&amp;quot;dmy&amp;quot; / &amp;quot;mdy&amp;quot; / &amp;quot;y&amp;quot;] default will be &amp;quot;dmy&amp;quot;&lt;br /&gt;
-- bc = [&amp;quot;BC&amp;quot; / &amp;quot;BCE&amp;quot;] default will be &amp;quot;BCE&amp;quot;&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- Dependencies: none&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
local format_Date = function(datetime, dateformat, bc)&lt;br /&gt;
	local datetime = datetime or &amp;quot;1 August 30 BCE&amp;quot; -- in case of nil value&lt;br /&gt;
	-- chop off multiple vales and/or any hours, mins, etc.&lt;br /&gt;
	-- keep anything before punctuation - we just want a single date:&lt;br /&gt;
	local dateval = string.match( datetime, &amp;quot;[%w ]+&amp;quot;)&lt;br /&gt;
&lt;br /&gt;
	local dateformat = string.lower(dateformat or &amp;quot;dmy&amp;quot;) -- default to dmy&lt;br /&gt;
&lt;br /&gt;
	local bc = string.upper(bc or &amp;quot;&amp;quot;) -- can&#039;t use nil for bc&lt;br /&gt;
	-- we only want to accept two possibilities: BC or default to BCE&lt;br /&gt;
	if bc == &amp;quot;BC&amp;quot; then&lt;br /&gt;
		bc = &amp;quot;&amp;amp;nbsp;&amp;quot; .. i18n[&amp;quot;BC&amp;quot;] -- prepend a non-breaking space.&lt;br /&gt;
	else&lt;br /&gt;
		bc = &amp;quot;&amp;amp;nbsp;&amp;quot; .. i18n[&amp;quot;BCE&amp;quot;]&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	local postchrist = true -- start by assuming no BCE&lt;br /&gt;
	local dateparts = {}&lt;br /&gt;
	for word in string.gmatch(dateval, &amp;quot;%w+&amp;quot;) do&lt;br /&gt;
		if word == &amp;quot;BCE&amp;quot; or word == &amp;quot;BC&amp;quot; then -- *** internationalise later ***&lt;br /&gt;
			postchrist = false&lt;br /&gt;
		else&lt;br /&gt;
			-- we&#039;ll keep the parts that are not &#039;BCE&#039; in a table&lt;br /&gt;
			dateparts[#dateparts + 1] = word&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	if postchrist then bc = &amp;quot;&amp;quot; end -- set AD dates to no suffix *** internationalise later ***&lt;br /&gt;
&lt;br /&gt;
	local sep = &amp;quot;&amp;amp;nbsp;&amp;quot; -- separator is nbsp&lt;br /&gt;
	local fdate = table.concat(dateparts, sep) -- set formatted date to same order as input&lt;br /&gt;
&lt;br /&gt;
	-- if we have day month year, check dateformat&lt;br /&gt;
	if #dateparts == 3 then&lt;br /&gt;
		if dateformat == &amp;quot;y&amp;quot; then&lt;br /&gt;
			fdate = dateparts[3]&lt;br /&gt;
		elseif dateformat == &amp;quot;mdy&amp;quot; then&lt;br /&gt;
			fdate = dateparts[2] .. sep .. dateparts[1] .. &amp;quot;,&amp;quot; .. sep .. dateparts[3]&lt;br /&gt;
		end&lt;br /&gt;
	elseif #dateparts == 2 and dateformat == &amp;quot;y&amp;quot; then&lt;br /&gt;
		fdate = dateparts[2]&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	return fdate .. bc&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- dateFormat is the handler for properties that are of type &amp;quot;time&amp;quot;&lt;br /&gt;
-- It takes timestamp, precision (6 to 11 per mediawiki), dateformat (y/dmy/mdy), BC format (BC/BCE),&lt;br /&gt;
-- a plaindate switch (yes/no/adj) to en/disable &amp;quot;sourcing cirumstances&amp;quot;/use adjectival form,&lt;br /&gt;
-- any qualifiers for the property, the language, and any adjective to use like &#039;before&#039;.&lt;br /&gt;
-- It passes the date through the &amp;quot;complex date&amp;quot; function&lt;br /&gt;
-- and returns a string with the internatonalised date formatted according to preferences.&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- Dependencies: findLang(); cdate(); dp[]&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
local dateFormat = function(timestamp, dprec, df, bcf, pd, qualifiers, lang, adj)&lt;br /&gt;
	-- A year can be stored like this: &amp;quot;+1872-00-00T00:00:00Z&amp;quot;,&lt;br /&gt;
	-- which is processed here as if it were the day before &amp;quot;+1872-01-01T00:00:00Z&amp;quot;,&lt;br /&gt;
	-- and that&#039;s the last day of 1871, so the year is wrong.&lt;br /&gt;
	-- So fix the month 0, day 0 timestamp to become 1 January instead:&lt;br /&gt;
	timestamp = timestamp:gsub(&amp;quot;%-00%-00T&amp;quot;, &amp;quot;-01-01T&amp;quot;)&lt;br /&gt;
	-- output formatting according to preferences (y/dmy/mdy)&lt;br /&gt;
	df = (df or &amp;quot;&amp;quot;):lower()&lt;br /&gt;
	-- just in case date precision is missing&lt;br /&gt;
	dprec = dprec or 11&lt;br /&gt;
	-- override more precise dates if required dateformat is year alone:&lt;br /&gt;
	if df == &amp;quot;y&amp;quot; and dprec &amp;gt; 9 then dprec = 9 end&lt;br /&gt;
	-- complex date only deals with precisions from 6 to 11, so clip range&lt;br /&gt;
	dprec = dprec&amp;gt;11 and 11 or dprec&lt;br /&gt;
	dprec = dprec&amp;lt;6 and 6 or dprec&lt;br /&gt;
	-- BC format is &amp;quot;BC&amp;quot; or &amp;quot;BCE&amp;quot;&lt;br /&gt;
	bcf = (bcf or &amp;quot;&amp;quot;):upper()&lt;br /&gt;
	-- plaindate only needs the first letter (y/n/a)&lt;br /&gt;
	pd = (pd or &amp;quot;&amp;quot;):sub(1,1)&lt;br /&gt;
	if pd == &amp;quot;&amp;quot; or pd == &amp;quot;n&amp;quot; or pd == &amp;quot;f&amp;quot; or pd == &amp;quot;0&amp;quot; then pd = false end&lt;br /&gt;
	-- in case language isn&#039;t passed&lt;br /&gt;
	lang = lang or findLang().code&lt;br /&gt;
	-- set adj as empty if nil&lt;br /&gt;
	adj = adj or &amp;quot;&amp;quot;&lt;br /&gt;
	-- extract the day, month, year from the timestamp&lt;br /&gt;
	local bc = timestamp:sub(1, 1)==&amp;quot;-&amp;quot; and &amp;quot;BC&amp;quot; or &amp;quot;&amp;quot;&lt;br /&gt;
	local year, month, day = timestamp:match(&amp;quot;[+-](%d*)-(%d*)-(%d*)T&amp;quot;)&lt;br /&gt;
	local iso = tonumber(year) -- if year is missing, let it throw an error&lt;br /&gt;
	-- this will adjust the date format to be compatible with cdate&lt;br /&gt;
	-- possible formats are Y, YY, YYY0, YYYY, YYYY-MM, YYYY-MM-DD&lt;br /&gt;
	if dprec == 6 then iso = math.floor( (iso - 1) / 1000 ) + 1 end&lt;br /&gt;
	if dprec == 7 then iso = math.floor( (iso - 1) / 100 ) + 1 end&lt;br /&gt;
	if dprec == 8 then iso = math.floor( iso / 10 ) .. &amp;quot;0&amp;quot; end&lt;br /&gt;
	if dprec == 10 then iso = year .. &amp;quot;-&amp;quot; .. month end&lt;br /&gt;
	if dprec == 11 then iso = year .. &amp;quot;-&amp;quot; .. month .. &amp;quot;-&amp;quot; .. day end&lt;br /&gt;
	-- add &amp;quot;circa&amp;quot; (Q5727902) from &amp;quot;sourcing circumstances&amp;quot; (P1480)&lt;br /&gt;
	local sc = not pd and qualifiers and qualifiers.P1480&lt;br /&gt;
	if sc then&lt;br /&gt;
		for k1, v1 in pairs(sc) do&lt;br /&gt;
			if v1.datavalue and v1.datavalue.value.id == &amp;quot;Q5727902&amp;quot; then&lt;br /&gt;
				adj = &amp;quot;circa&amp;quot;&lt;br /&gt;
				break&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	local fdate = cdate(&amp;quot;&amp;quot;, adj, tostring(iso), dp[dprec], bc, &amp;quot;&amp;quot;, &amp;quot;&amp;quot;, &amp;quot;&amp;quot;, &amp;quot;&amp;quot;, lang, 1)&lt;br /&gt;
	-- this may have QuickStatements info appended to it in a div, so remove that&lt;br /&gt;
	fdate = fdate:gsub(&#039; &amp;lt;div style=&amp;quot;display: none;&amp;quot;&amp;gt;[^&amp;lt;]*&amp;lt;/div&amp;gt;&#039;, &#039;&#039;)&lt;br /&gt;
	-- it may also be returned wrapped in a microformat, so remove that&lt;br /&gt;
	fdate = fdate:gsub(&amp;quot;&amp;lt;[^&amp;gt;]*&amp;gt;&amp;quot;, &amp;quot;&amp;quot;)&lt;br /&gt;
	-- if &#039;circa&#039;, use the abbreviated form *** internationalise later ***&lt;br /&gt;
	fdate = fdate:gsub(&#039;circa &#039;, &#039;&amp;lt;abbr title=&amp;quot;circa&amp;quot;&amp;gt;c.&amp;lt;/abbr&amp;gt;&amp;amp;nbsp;&#039;)&lt;br /&gt;
	-- deal with BC/BCE&lt;br /&gt;
	if bcf == &amp;quot;BCE&amp;quot; then&lt;br /&gt;
		fdate = fdate:gsub(&#039;BC&#039;, &#039;BCE&#039;)&lt;br /&gt;
	end&lt;br /&gt;
	-- deal with mdy format&lt;br /&gt;
	if df == &amp;quot;mdy&amp;quot; then&lt;br /&gt;
		fdate = fdate:gsub(&amp;quot;(%d+) (%w+) (%d+)&amp;quot;, &amp;quot;%2 %1, %3&amp;quot;)&lt;br /&gt;
	end&lt;br /&gt;
	-- deal with adjectival form *** internationalise later ***&lt;br /&gt;
	if pd == &amp;quot;a&amp;quot; then&lt;br /&gt;
		fdate = fdate:gsub(&#039; century&#039;, &#039;-century&#039;)&lt;br /&gt;
	end&lt;br /&gt;
	return fdate&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- parseParam takes a (string) parameter, e.g. from the list of frame arguments,&lt;br /&gt;
-- and makes &amp;quot;false&amp;quot;, &amp;quot;no&amp;quot;, and &amp;quot;0&amp;quot; into the (boolean) false&lt;br /&gt;
-- it makes the empty string and nil into the (boolean) value passed as default&lt;br /&gt;
-- allowing the parameter to be true or false by default.&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- Dependencies: none&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
local parseParam = function(param, default)&lt;br /&gt;
	if param and param ~= &amp;quot;&amp;quot; then&lt;br /&gt;
		param = param:lower()&lt;br /&gt;
		if (param == &amp;quot;false&amp;quot;) or (param:sub(1,1) == &amp;quot;n&amp;quot;) or (param == &amp;quot;0&amp;quot;) then&lt;br /&gt;
			return false&lt;br /&gt;
		else&lt;br /&gt;
			return true&lt;br /&gt;
		end&lt;br /&gt;
	else&lt;br /&gt;
		return default&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- _getSitelink takes the qid of a Wikidata entity passed as |qid=&lt;br /&gt;
-- It takes an optional parameter |wiki= to determine which wiki is to be checked for a sitelink&lt;br /&gt;
-- If the parameter is blank, then it uses the local wiki.&lt;br /&gt;
-- If there is a sitelink to an article available, it returns the plain text link to the article&lt;br /&gt;
-- If there is no sitelink, it returns nil.&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- Dependencies: none&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
local _getSitelink = function(qid, wiki)&lt;br /&gt;
	qid = (qid or &amp;quot;&amp;quot;):upper()&lt;br /&gt;
	if qid == &amp;quot;&amp;quot; then return nil end&lt;br /&gt;
	wiki = wiki or &amp;quot;&amp;quot;&lt;br /&gt;
	local sitelink&lt;br /&gt;
	if wiki == &amp;quot;&amp;quot; then&lt;br /&gt;
		sitelink = mw.wikibase.sitelink(qid)&lt;br /&gt;
	else&lt;br /&gt;
		sitelink = mw.wikibase.sitelink(qid, wiki)&lt;br /&gt;
	end&lt;br /&gt;
	return sitelink&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- _getCommonslink takes an optional qid of a Wikidata entity passed as |qid=&lt;br /&gt;
-- It returns one of the following in order of preference:&lt;br /&gt;
-- 	the Commons sitelink of the linked Wikidata item;&lt;br /&gt;
-- 	the Commons sitelink of the topic&#039;s main category of the linked Wikidata item;&lt;br /&gt;
-- 	the Commons category.&lt;br /&gt;
-- If the optional parameter onlycat is true/yes/1 then only categories are returned&lt;br /&gt;
-- defaults to false.&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- Dependencies: _getSitelink(); parseParam()&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
local _getCommonslink = function(qid, onlycat)&lt;br /&gt;
	qid = (qid or &amp;quot;&amp;quot;):upper()&lt;br /&gt;
	if qid == &amp;quot;&amp;quot; then qid = mw.wikibase.getEntityIdForCurrentPage() end&lt;br /&gt;
	if not qid then return nil end&lt;br /&gt;
	onlycat = parseParam(onlycat, false)&lt;br /&gt;
	local sitelink = _getSitelink(qid, &amp;quot;commonswiki&amp;quot;)&lt;br /&gt;
	if onlycat and sitelink and sitelink:sub(1,9) ~= &amp;quot;Category:&amp;quot; then sitelink = nil end&lt;br /&gt;
	if not sitelink then&lt;br /&gt;
		-- check for topic&#039;s main category&lt;br /&gt;
		local prop910 = mw.wikibase.getBestStatements(qid, &amp;quot;P910&amp;quot;)[1]&lt;br /&gt;
		if prop910 then&lt;br /&gt;
			local tmcid = prop910.mainsnak.datavalue.value.id&lt;br /&gt;
			sitelink = _getSitelink(tmcid, &amp;quot;commonswiki&amp;quot;)&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	if not sitelink then&lt;br /&gt;
		-- check for Commons category (string value)&lt;br /&gt;
		local prop373 = mw.wikibase.getBestStatements(qid, &amp;quot;P373&amp;quot;)[1]&lt;br /&gt;
		if prop373 then&lt;br /&gt;
			sitelink = prop373.mainsnak.datavalue.value&lt;br /&gt;
			if sitelink then sitelink = &amp;quot;Category:&amp;quot; .. sitelink end&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	return sitelink&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- The label in a Wikidata item is subject to vulnerabilities&lt;br /&gt;
-- that an attacker might try to exploit.&lt;br /&gt;
-- It needs to be &#039;sanitised&#039; by removing any wikitext before use.&lt;br /&gt;
-- If it doesn&#039;t exist, return the id for the item&lt;br /&gt;
-- a second (boolean) value is also returned, value is true when the label exists&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- Dependencies: none&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
local labelOrId = function(id)&lt;br /&gt;
	local label = mw.wikibase.label(id)&lt;br /&gt;
	if label then&lt;br /&gt;
		return mw.text.nowiki(label), true&lt;br /&gt;
	else&lt;br /&gt;
		return id, false&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- linkedItem takes an entity-id and returns a string, linked if possible.&lt;br /&gt;
-- This is the handler for &amp;quot;wikibase-item&amp;quot;. Preferences:&lt;br /&gt;
-- 1. Display linked disambiguated sitelink if it exists&lt;br /&gt;
-- 2. Display linked label if it is a redirect&lt;br /&gt;
-- 3. TBA: Display an inter-language link for the label if it exists other than in default language&lt;br /&gt;
-- 4. Display unlinked label if it exists&lt;br /&gt;
-- 5. Display entity-id for now to indicate a label could be provided&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- Dependencies: labelOrId()&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
local linkedItem = function(id, lprefix, lpostfix, prefix, postfix)&lt;br /&gt;
	lprefix = lprefix or &amp;quot;&amp;quot; -- toughen against nil values passed&lt;br /&gt;
	lpostfix = lpostfix or &amp;quot;&amp;quot;&lt;br /&gt;
	prefix = prefix or &amp;quot;&amp;quot;&lt;br /&gt;
	postfix = postfix or &amp;quot;&amp;quot;&lt;br /&gt;
	local disp&lt;br /&gt;
	local sitelink = mw.wikibase.sitelink(id)&lt;br /&gt;
	local label, islabel = labelOrId(id)&lt;br /&gt;
	if mw.site.siteName ~= &amp;quot;Wikimedia Commons&amp;quot; then&lt;br /&gt;
		if sitelink then&lt;br /&gt;
			-- strip any namespace or dab from the sitelink and use that as label&lt;br /&gt;
			local pos = sitelink:find(&amp;quot;:&amp;quot;) or 0&lt;br /&gt;
			label = sitelink:sub(pos+1):gsub(&amp;quot;%s%(.+%)$&amp;quot;, &amp;quot;&amp;quot;):gsub(&amp;quot;,.+$&amp;quot;, &amp;quot;&amp;quot;)&lt;br /&gt;
			disp = &amp;quot;[[&amp;quot; .. lprefix .. sitelink .. lpostfix .. &amp;quot;|&amp;quot; .. prefix .. label .. postfix .. &amp;quot;]]&amp;quot;&lt;br /&gt;
		elseif islabel then&lt;br /&gt;
			-- no sitelink, label exists, so check if a redirect with that title exists&lt;br /&gt;
			local artitle = mw.title.new(label, 0)&lt;br /&gt;
			if artitle and artitle.redirectTarget then&lt;br /&gt;
				-- there&#039;s a redirect with the same title as the label, so let&#039;s link to that&lt;br /&gt;
				disp = &amp;quot;[[&amp;quot;.. lprefix .. label .. lpostfix .. &amp;quot;|&amp;quot; .. prefix .. label .. postfix .. &amp;quot;]]&amp;quot;&lt;br /&gt;
			else&lt;br /&gt;
				-- no sitelink, label exists, not a redirect, so output the plain label&lt;br /&gt;
				disp = prefix .. label .. postfix&lt;br /&gt;
			end -- test if article title exists as redirect on current Wiki&lt;br /&gt;
		else&lt;br /&gt;
			-- no sitelink and no label, so return whatever was returned from labelOrId for now&lt;br /&gt;
			-- add tracking category [[Category:Articles with missing Wikidata information]]&lt;br /&gt;
			disp = prefix .. label .. postfix .. i18n.missinginfocat&lt;br /&gt;
		end&lt;br /&gt;
	else&lt;br /&gt;
		local ccat = mw.wikibase.getBestStatements(id, &amp;quot;P373&amp;quot;)[1]&lt;br /&gt;
		if ccat then&lt;br /&gt;
			ccat = ccat.mainsnak.datavalue.value&lt;br /&gt;
			disp = &amp;quot;[[&amp;quot; .. lprefix .. &amp;quot;Category:&amp;quot; .. ccat .. lpostfix .. &amp;quot;|&amp;quot; .. prefix .. label .. postfix .. &amp;quot;]]&amp;quot;&lt;br /&gt;
		elseif sitelink then&lt;br /&gt;
			-- this asumes that if a sitelink exists, then a label also exists&lt;br /&gt;
			disp = &amp;quot;[[&amp;quot; .. lprefix .. sitelink .. lpostfix .. &amp;quot;|&amp;quot; .. prefix .. label .. postfix .. &amp;quot;]]&amp;quot;&lt;br /&gt;
		else&lt;br /&gt;
			-- no sitelink and no Commons cat, so return label from labelOrId for now&lt;br /&gt;
			disp = prefix .. label .. postfix&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	return disp&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- sourced takes a table representing a statement that may or may not have references&lt;br /&gt;
-- it counts how many references are sourced to something not containing the word &amp;quot;wikipedia&amp;quot;&lt;br /&gt;
-- it returns a boolean = true if there are any sourced references.&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- Dependencies: none&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
local sourced = function(claim)&lt;br /&gt;
	if claim.references then&lt;br /&gt;
		for kr, vr in pairs(claim.references) do&lt;br /&gt;
			local ref = mw.wikibase.renderSnaks(vr.snaks)&lt;br /&gt;
			if not ref:find(&amp;quot;Wikipedia&amp;quot;) then&lt;br /&gt;
				return true&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- setRanks takes a flag (parameter passed) that requests the values to return&lt;br /&gt;
-- &amp;quot;b[est]&amp;quot; returns preferred if available, otherwise normal&lt;br /&gt;
-- &amp;quot;p[referred]&amp;quot; returns preferred&lt;br /&gt;
-- &amp;quot;n[ormal]&amp;quot; returns normal&lt;br /&gt;
-- &amp;quot;d[eprecated]&amp;quot; returns deprecated&lt;br /&gt;
-- multiple values are allowed, e.g. &amp;quot;preferred normal&amp;quot; (which is the default)&lt;br /&gt;
-- &amp;quot;best&amp;quot; will override the other flags, and set p and n&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- Dependencies: none&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
local setRanks = function(rank)&lt;br /&gt;
	rank = (rank or &amp;quot;&amp;quot;):lower()&lt;br /&gt;
	-- if nothing passed, return preferred and normal&lt;br /&gt;
	-- if rank == &amp;quot;&amp;quot; then rank = &amp;quot;p n&amp;quot; end&lt;br /&gt;
	local ranks = {}&lt;br /&gt;
	for w in string.gmatch(rank, &amp;quot;%a+&amp;quot;) do&lt;br /&gt;
		w = w:sub(1,1)&lt;br /&gt;
		if w == &amp;quot;b&amp;quot; or w == &amp;quot;p&amp;quot; or w == &amp;quot;n&amp;quot; or w == &amp;quot;d&amp;quot; then&lt;br /&gt;
			ranks[w] = true&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	-- check if &amp;quot;best&amp;quot; is requested or no ranks requested; and if so, set preferred and normal&lt;br /&gt;
	if ranks.b or not next(ranks) then&lt;br /&gt;
		ranks.p = true&lt;br /&gt;
		ranks.n = true&lt;br /&gt;
	end&lt;br /&gt;
	return ranks&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- parseInput processes the Q-id , the blacklist and the whitelist&lt;br /&gt;
-- if an input parameter is supplied, it returns that and ends the call.&lt;br /&gt;
-- it returns (1) either the qid or nil indicating whether or not the call should continue&lt;br /&gt;
-- and (2) a table containing all of the statements for the propertyID and relevant Qid&lt;br /&gt;
-- if &amp;quot;best&amp;quot; ranks are requested, it returns those instead of all non-deprecated ranks&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- Dependencies: none&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
local parseInput = function(frame, input_parm, property_id)&lt;br /&gt;
	-- There may be a local parameter supplied, if it&#039;s blank, set it to nil&lt;br /&gt;
	input_parm = mw.text.trim(input_parm or &amp;quot;&amp;quot;)&lt;br /&gt;
	if input_parm == &amp;quot;&amp;quot; then input_parm = nil end&lt;br /&gt;
&lt;br /&gt;
	local args = frame.args&lt;br /&gt;
&lt;br /&gt;
	-- can take a named parameter |qid which is the Wikidata ID for the article.&lt;br /&gt;
	-- if it&#039;s not supplied, use the id for the current page&lt;br /&gt;
	local qid = args.qid or &amp;quot;&amp;quot;&lt;br /&gt;
	if qid == &amp;quot;&amp;quot; then qid = mw.wikibase.getEntityIdForCurrentPage() end&lt;br /&gt;
	-- if there&#039;s no Wikidata item for the current page return nil&lt;br /&gt;
	if not qid then return false, input_parm end&lt;br /&gt;
&lt;br /&gt;
	-- The blacklist is passed in named parameter |suppressfields&lt;br /&gt;
	local blacklist = args.suppressfields or args.spf&lt;br /&gt;
&lt;br /&gt;
	-- The whitelist is passed in named parameter |fetchwikidata&lt;br /&gt;
	local whitelist = args.fetchwikidata or args.fwd&lt;br /&gt;
	if not whitelist or whitelist == &amp;quot;&amp;quot; then whitelist = &amp;quot;NONE&amp;quot; end&lt;br /&gt;
&lt;br /&gt;
	-- The name of the field that this function is called from is passed in named parameter |name&lt;br /&gt;
	local fieldname = args.name or &amp;quot;&amp;quot;&lt;br /&gt;
&lt;br /&gt;
	if blacklist then&lt;br /&gt;
		-- The name is compulsory when blacklist is used, so return nil if it is not supplied&lt;br /&gt;
		if not fieldname or fieldname == &amp;quot;&amp;quot; then return false, nil end&lt;br /&gt;
		-- If this field is on the blacklist, then return nil&lt;br /&gt;
		if blacklist:find(fieldname) then return false, nil end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- If we got this far then we&#039;re not on the blacklist&lt;br /&gt;
	-- The blacklist overrides any locally supplied parameter as well&lt;br /&gt;
	-- If a non-blank input parameter was supplied return it&lt;br /&gt;
	if input_parm then return false, input_parm end&lt;br /&gt;
&lt;br /&gt;
	-- Otherwise see if this field is on the whitelist:&lt;br /&gt;
	-- needs a bit more logic because find will return its second value = 0 if fieldname is &amp;quot;&amp;quot;&lt;br /&gt;
	-- but nil if fieldname not found on whitelist&lt;br /&gt;
	local _, found = whitelist:find(fieldname)&lt;br /&gt;
	found = ((found or 0) &amp;gt; 0)&lt;br /&gt;
	if whitelist ~= &#039;ALL&#039; and (whitelist:upper() == &amp;quot;NONE&amp;quot; or not found) then&lt;br /&gt;
		return false, nil&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- See what&#039;s on Wikidata (the call always returns a table, but it may be empty):&lt;br /&gt;
	local props = {}&lt;br /&gt;
	if args.reqranks.b then&lt;br /&gt;
		props = mw.wikibase.getBestStatements(qid, property_id)&lt;br /&gt;
	else&lt;br /&gt;
		props = mw.wikibase.getAllStatements(qid, property_id)&lt;br /&gt;
	end&lt;br /&gt;
	if props[1] then&lt;br /&gt;
		return qid, props&lt;br /&gt;
	end&lt;br /&gt;
	-- no property on Wikidata&lt;br /&gt;
	return false, nil&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- createicon assembles the &amp;quot;Edit at Wikidata&amp;quot; pen icon.&lt;br /&gt;
-- It returns a wikitext string.&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- Dependencies: i18n[];&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
local createicon = function(langcode, entityID, propertyID)&lt;br /&gt;
	local icon = &amp;quot;&amp;amp;nbsp;[[&amp;quot; .. i18n[&amp;quot;filespace&amp;quot;]&lt;br /&gt;
	icon = icon .. &amp;quot;:Blue pencil.svg |frameless |text-top |10px |alt=&amp;quot;&lt;br /&gt;
	icon = icon .. i18n[&amp;quot;editonwikidata&amp;quot;]&lt;br /&gt;
	icon = icon .. &amp;quot;|link=https://www.wikidata.org/wiki/&amp;quot; .. entityID&lt;br /&gt;
	icon = icon .. &amp;quot;?uselang=&amp;quot; .. langcode&lt;br /&gt;
	icon = icon .. &amp;quot;#&amp;quot; .. propertyID .. &amp;quot;|&amp;quot; .. i18n[&amp;quot;editonwikidata&amp;quot;] .. &amp;quot;]]&amp;quot;&lt;br /&gt;
	return icon&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- assembleoutput takes the sequence table containing the property values&lt;br /&gt;
-- and formats it according to switches given. It returns a string or nil.&lt;br /&gt;
-- It needs the entityID and propertyID to create a link in the pen icon.&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- Dependencies: parseParam();&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
local assembleoutput = function(out, args, entityID, propertyID)&lt;br /&gt;
&lt;br /&gt;
	-- sorted is a boolean passed to enable sorting of the values returned&lt;br /&gt;
	-- if nothing or an empty string is passed set it false&lt;br /&gt;
	-- if &amp;quot;false&amp;quot; or &amp;quot;no&amp;quot; or &amp;quot;0&amp;quot; is passed set it false&lt;br /&gt;
	local sorted = parseParam(args.sorted, false)&lt;br /&gt;
&lt;br /&gt;
	-- noicon is a boolean passed to suppress the trailing &amp;quot;edit at Wikidata&amp;quot; icon&lt;br /&gt;
	-- for use when the value is processed further by the infobox&lt;br /&gt;
	-- if nothing or an empty string is passed set it false&lt;br /&gt;
	-- if &amp;quot;false&amp;quot; or &amp;quot;no&amp;quot; or &amp;quot;0&amp;quot; is passed set it false&lt;br /&gt;
	local noic = parseParam(args.noicon, false)&lt;br /&gt;
&lt;br /&gt;
	-- list is the name of a template that a list of multiple values is passed through&lt;br /&gt;
	-- examples include &amp;quot;hlist&amp;quot; and &amp;quot;ubl&amp;quot;&lt;br /&gt;
	-- setting it to &amp;quot;prose&amp;quot; produces something like &amp;quot;1, 2, 3, and 4&amp;quot;&lt;br /&gt;
	local list = args.list or &amp;quot;&amp;quot;&lt;br /&gt;
&lt;br /&gt;
	-- sep is a string that is used to separate multiple returned values&lt;br /&gt;
	-- if nothing or an empty string is passed set it to the default&lt;br /&gt;
	-- any double-quotes &amp;quot; are stripped out, so that spaces may be passed&lt;br /&gt;
	-- e.g. |sep=&amp;quot; - &amp;quot;&lt;br /&gt;
	local sepdefault = i18n[&amp;quot;list separator&amp;quot;]&lt;br /&gt;
	local separator = args.sep or &amp;quot;&amp;quot;&lt;br /&gt;
	separator = string.gsub(separator, &#039;&amp;quot;&#039;, &#039;&#039;)&lt;br /&gt;
	if separator == &amp;quot;&amp;quot; then&lt;br /&gt;
		separator = sepdefault&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- collapse is a number that determines the maximum number of returned values&lt;br /&gt;
	-- before the output is collapsed.&lt;br /&gt;
	-- Zero or not a number result in no collapsing (default becomes 0).&lt;br /&gt;
	local collapse = tonumber(args.collapse) or 0&lt;br /&gt;
&lt;br /&gt;
	-- if there&#039;s anything to return, then return a list&lt;br /&gt;
	-- comma-separated by default, but may be specified by the sep parameter&lt;br /&gt;
	-- optionally specify a hlist or ubl or a prose list, etc.&lt;br /&gt;
	local strout&lt;br /&gt;
	if #out &amp;gt; 0 then&lt;br /&gt;
		if sorted then table.sort(out) end&lt;br /&gt;
		-- if a pen icon is wanted add it the end of the last value&lt;br /&gt;
		if not noic then&lt;br /&gt;
			out[#out] = out[#out] .. createicon(args.langobj.code, entityID, propertyID)&lt;br /&gt;
		end&lt;br /&gt;
		if list == &amp;quot;&amp;quot; then&lt;br /&gt;
			strout = table.concat(out, separator)&lt;br /&gt;
		elseif list:lower() == &amp;quot;prose&amp;quot; then&lt;br /&gt;
			strout = mw.text.listToText( out )&lt;br /&gt;
		else&lt;br /&gt;
			strout = mw.getCurrentFrame():expandTemplate{title = list, args = out}&lt;br /&gt;
		end&lt;br /&gt;
		if collapse &amp;gt;0 and #out &amp;gt; collapse then&lt;br /&gt;
			strout = collapsediv .. strout .. &amp;quot;&amp;lt;/div&amp;gt;&amp;quot;&lt;br /&gt;
		end&lt;br /&gt;
	else&lt;br /&gt;
		strout = nil -- no items had valid reference&lt;br /&gt;
	end&lt;br /&gt;
	return strout&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- rendersnak takes a table (propval) containing the information stored on one property value&lt;br /&gt;
-- and returns the value as a string and its language if monolingual text.&lt;br /&gt;
-- It handles data of type:&lt;br /&gt;
--		wikibase-item&lt;br /&gt;
--		time&lt;br /&gt;
--		string, url, commonsMedia, external-id&lt;br /&gt;
--		quantity&lt;br /&gt;
--		globe-coordinate&lt;br /&gt;
--		monolingualtext&lt;br /&gt;
-- It also requires linked, the link/pre/postfixes, uabbr, and the arguments passed from frame.&lt;br /&gt;
-- The optional filter parameter allows quantities to be be filtered by unit.&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- Dependencies: parseParam(); labelOrId(); i18n[]; dateFormat();&lt;br /&gt;
-- roundto(); decimalPrecision(); decimalToDMS();&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
local rendersnak = function(propval, args, linked, lpre, lpost, pre, post, uabbr, filter)&lt;br /&gt;
	lpre = lpre or &amp;quot;&amp;quot;&lt;br /&gt;
	lpost = lpost or &amp;quot;&amp;quot;&lt;br /&gt;
	pre = pre or &amp;quot;&amp;quot;&lt;br /&gt;
	post = post or &amp;quot;&amp;quot;&lt;br /&gt;
	local snak = propval.mainsnak or propval&lt;br /&gt;
	local dv = snak.datavalue&lt;br /&gt;
	local dtype = propval.datatype or propval.mainsnak.datatype&lt;br /&gt;
	dv = dv and dv.value&lt;br /&gt;
	-- value and monolingual text language code returned&lt;br /&gt;
	local val, mlt&lt;br /&gt;
	if propval.rank and not args.reqranks[propval.rank:sub(1, 1)] then&lt;br /&gt;
		-- val is nil: value has a rank that isn&#039;t requested&lt;br /&gt;
		------------------------------------&lt;br /&gt;
	elseif snak.snaktype == &amp;quot;somevalue&amp;quot; then -- value is unknown&lt;br /&gt;
		val = i18n[&amp;quot;Unknown&amp;quot;]&lt;br /&gt;
		------------------------------------&lt;br /&gt;
	elseif snak.snaktype == &amp;quot;novalue&amp;quot; then -- value is none&lt;br /&gt;
		-- val = &amp;quot;No value&amp;quot; -- don&#039;t return anything&lt;br /&gt;
		------------------------------------&lt;br /&gt;
	elseif dtype == &amp;quot;wikibase-item&amp;quot; then -- data type is a wikibase item:&lt;br /&gt;
		-- it&#039;s wiki-linked value, so output as link if enabled and possible&lt;br /&gt;
		local qnumber = dv.id&lt;br /&gt;
		if linked then&lt;br /&gt;
			val = linkedItem(qnumber, lpre, lpost, pre, post)&lt;br /&gt;
		else -- no link wanted so test for lang code&lt;br /&gt;
			local label, islabel = labelOrId(qnumber)&lt;br /&gt;
			local langlabel = mw.wikibase.getLabelByLang(qnumber, args.lang)&lt;br /&gt;
			if langlabel then&lt;br /&gt;
				label = mw.text.nowiki( langlabel )&lt;br /&gt;
			end&lt;br /&gt;
			val = pre .. label .. post&lt;br /&gt;
		end -- test for link required&lt;br /&gt;
		------------------------------------&lt;br /&gt;
	elseif dtype == &amp;quot;time&amp;quot; then -- data type is time:&lt;br /&gt;
		-- time is in timestamp format&lt;br /&gt;
		-- date precision is integer per mediawiki&lt;br /&gt;
		-- output formatting according to preferences (y/dmy/mdy)&lt;br /&gt;
		-- BC format as BC or BCE&lt;br /&gt;
		-- plaindate is passed to disable looking for &amp;quot;sourcing cirumstances&amp;quot;&lt;br /&gt;
		-- or to set the adjectival form&lt;br /&gt;
		-- qualifiers (if any) is a nested table or nil&lt;br /&gt;
		-- lang is given, or user language, or site language&lt;br /&gt;
		val = dateFormat(dv.time, dv.precision, args.df, args.bc, pd, propval.qualifiers, args.lang)&lt;br /&gt;
		------------------------------------&lt;br /&gt;
	-- data types which are strings:&lt;br /&gt;
	elseif dtype == &amp;quot;commonsMedia&amp;quot; or dtype == &amp;quot;external-id&amp;quot; or dtype == &amp;quot;string&amp;quot; or dtype == &amp;quot;url&amp;quot; then&lt;br /&gt;
		-- commonsMedia or external-id or string or url&lt;br /&gt;
		-- all have mainsnak.datavalue.value as string&lt;br /&gt;
		if (lpre == &amp;quot;&amp;quot; or lpre == &amp;quot;:&amp;quot;) and lpost == &amp;quot;&amp;quot; then&lt;br /&gt;
			-- don&#039;t link if no linkpre/postfix or linkprefix is just &amp;quot;:&amp;quot;&lt;br /&gt;
			val = pre .. dv .. post&lt;br /&gt;
		else&lt;br /&gt;
			val = &amp;quot;[[&amp;quot; .. lpre .. dv .. lpost .. &amp;quot;|&amp;quot; .. pre .. dv .. post .. &amp;quot;]]&amp;quot;&lt;br /&gt;
		end -- check for link requested (i.e. either linkprefix or linkpostfix exists)&lt;br /&gt;
		------------------------------------&lt;br /&gt;
	-- data types which are quantities:&lt;br /&gt;
	elseif dtype == &amp;quot;quantity&amp;quot; then&lt;br /&gt;
		-- quantities have mainsnak.datavalue.value.amount and mainsnak.datavalue.value.unit&lt;br /&gt;
		-- the unit is of the form http://www.wikidata.org/entity/Q829073&lt;br /&gt;
		--&lt;br /&gt;
		-- implement a switch to turn on/off numerical formatting later&lt;br /&gt;
		local fnum = true&lt;br /&gt;
		--&lt;br /&gt;
		-- a switch to turn on/off conversions - only for en-wiki&lt;br /&gt;
		local conv = parseParam(args.conv or args.convert, false)&lt;br /&gt;
		-- if we have conversions, we won&#039;t have formatted numbers or scales&lt;br /&gt;
		if conv then&lt;br /&gt;
			fnum = false&lt;br /&gt;
			args.scale = &amp;quot;0&amp;quot;&lt;br /&gt;
		end&lt;br /&gt;
		--&lt;br /&gt;
		-- convert amount to a number&lt;br /&gt;
		local amount = tonumber(dv.amount) or i18n[&amp;quot;NaN&amp;quot;]&lt;br /&gt;
		--&lt;br /&gt;
		-- scale factor for millions, billions, etc.&lt;br /&gt;
		local sc = tostring(args.scale or &amp;quot;&amp;quot;):sub(1,1):lower()&lt;br /&gt;
		local scale&lt;br /&gt;
		if sc == &amp;quot;a&amp;quot; then&lt;br /&gt;
			-- automatic scaling&lt;br /&gt;
			if amount &amp;gt; 1e15 then&lt;br /&gt;
				scale = 12&lt;br /&gt;
			elseif amount &amp;gt; 1e12 then&lt;br /&gt;
				scale = 9&lt;br /&gt;
			elseif amount &amp;gt; 1e9 then&lt;br /&gt;
				scale = 6&lt;br /&gt;
			elseif amount &amp;gt; 1e6 then&lt;br /&gt;
				scale = 3&lt;br /&gt;
			else&lt;br /&gt;
				scale = 0&lt;br /&gt;
			end&lt;br /&gt;
		else&lt;br /&gt;
			scale = tonumber(args.scale) or 0&lt;br /&gt;
			if scale &amp;lt; 0 or scale &amp;gt; 12 then scale = 0 end&lt;br /&gt;
			scale = math.floor(scale/3) * 3&lt;br /&gt;
		end&lt;br /&gt;
		local factor = 10^scale&lt;br /&gt;
		amount = amount / factor&lt;br /&gt;
		-- ranges:&lt;br /&gt;
		local range = &amp;quot;&amp;quot;&lt;br /&gt;
		-- check if upper and/or lower bounds are given and significant&lt;br /&gt;
		local upb = tonumber(dv.upperBound)&lt;br /&gt;
		local lowb = tonumber(dv.lowerBound)&lt;br /&gt;
		if upb and lowb then&lt;br /&gt;
			-- differences rounded to 2 sig fig:&lt;br /&gt;
			local posdif = roundto(upb - amount, 2) / factor&lt;br /&gt;
			local negdif = roundto(amount - lowb, 2) / factor&lt;br /&gt;
			upb, lowb = amount + posdif, amount - negdif&lt;br /&gt;
			-- round scaled numbers to integers or 4 sig fig&lt;br /&gt;
			if (scale &amp;gt; 0 or sc == &amp;quot;a&amp;quot;) then&lt;br /&gt;
				if amount &amp;lt; 1e4 then&lt;br /&gt;
					amount = roundto(amount, 4)&lt;br /&gt;
				else&lt;br /&gt;
					amount = math.floor(amount + 0.5)&lt;br /&gt;
				end&lt;br /&gt;
			end&lt;br /&gt;
			if fnum then amount = args.langobj:formatNum( amount ) end&lt;br /&gt;
			if posdif ~= negdif then&lt;br /&gt;
				-- non-symmetrical&lt;br /&gt;
				range = &amp;quot; +&amp;quot; .. posdif .. &amp;quot; -&amp;quot; .. negdif&lt;br /&gt;
			elseif posdif ~= 0 then&lt;br /&gt;
				-- symmetrical and non-zero&lt;br /&gt;
				range = &amp;quot; ±&amp;quot; .. posdif&lt;br /&gt;
			else&lt;br /&gt;
				-- otherwise range is zero, so leave it as &amp;quot;&amp;quot;&lt;br /&gt;
			end&lt;br /&gt;
		else&lt;br /&gt;
			-- round scaled numbers to integers or 4 sig fig&lt;br /&gt;
			if (scale &amp;gt; 0 or sc == &amp;quot;a&amp;quot;) then&lt;br /&gt;
				if amount &amp;lt; 1e4 then&lt;br /&gt;
					amount = roundto(amount, 4)&lt;br /&gt;
				else&lt;br /&gt;
					amount = math.floor(amount + 0.5)&lt;br /&gt;
				end&lt;br /&gt;
			end&lt;br /&gt;
			if fnum then amount = args.langobj:formatNum( amount ) end&lt;br /&gt;
		end&lt;br /&gt;
		-- unit names and symbols:&lt;br /&gt;
		-- extract the qid in the form &#039;Qnnn&#039; from the value.unit url&lt;br /&gt;
		-- and then fetch the label from that - or symbol if unitabbr is true&lt;br /&gt;
		local unit = &amp;quot;&amp;quot;&lt;br /&gt;
		local usep = &amp;quot;&amp;quot;&lt;br /&gt;
		local usym = &amp;quot;&amp;quot;&lt;br /&gt;
		local unitqid = string.match( dv.unit, &amp;quot;(Q%d+)&amp;quot; )&lt;br /&gt;
		if filter and unitqid ~= filter then return nil end&lt;br /&gt;
		if unitqid then&lt;br /&gt;
			local uname = mw.wikibase.getLabelByLang(unitqid, args.lang) or &amp;quot;&amp;quot;&lt;br /&gt;
			if uname ~= &amp;quot;&amp;quot; then usep, unit = &amp;quot; &amp;quot;, uname end&lt;br /&gt;
			if uabbr then&lt;br /&gt;
				-- see if there&#039;s a unit symbol (P5061)&lt;br /&gt;
				local unitsymbols = mw.wikibase.getAllStatements(unitqid, &amp;quot;P5061&amp;quot;)&lt;br /&gt;
				-- construct fallback table&lt;br /&gt;
				local fbtbl = mw.language.getFallbacksFor( args.lang )&lt;br /&gt;
				table.insert( fbtbl, 1, args.lang )&lt;br /&gt;
				found = false&lt;br /&gt;
				for idx1, us in ipairs(unitsymbols) do&lt;br /&gt;
					for idx2, fblang in ipairs(fbtbl) do&lt;br /&gt;
						if us.mainsnak.datavalue.value.language == fblang then&lt;br /&gt;
							usym = us.mainsnak.datavalue.value.text&lt;br /&gt;
							found = true&lt;br /&gt;
							break&lt;br /&gt;
						end&lt;br /&gt;
					if found then break end&lt;br /&gt;
					end -- loop through fallback table&lt;br /&gt;
				end -- loop through values of P5061&lt;br /&gt;
				if found then usep, unit = &amp;quot;&amp;amp;nbsp;&amp;quot;, usym end&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
		-- format display:&lt;br /&gt;
		if conv and usym ~= &amp;quot;&amp;quot; then&lt;br /&gt;
			if range == &amp;quot;&amp;quot; then&lt;br /&gt;
				val = mw.getCurrentFrame():expandTemplate{title = &amp;quot;cvt&amp;quot;, args = {amount, usym}}&lt;br /&gt;
			else&lt;br /&gt;
				val = mw.getCurrentFrame():expandTemplate{title = &amp;quot;cvt&amp;quot;, args = {lowb, &amp;quot;to&amp;quot;, upb, usym}}&lt;br /&gt;
			end&lt;br /&gt;
		elseif unit == &amp;quot;$&amp;quot; or unit == &amp;quot;£&amp;quot; then&lt;br /&gt;
			val = unit .. amount .. range .. i18n.multipliers[scale]&lt;br /&gt;
		else&lt;br /&gt;
			val = amount .. range .. i18n.multipliers[scale] .. usep .. unit&lt;br /&gt;
		end&lt;br /&gt;
		------------------------------------&lt;br /&gt;
	-- datatypes which are global coordinates:&lt;br /&gt;
	elseif dtype == &amp;quot;globe-coordinate&amp;quot; then&lt;br /&gt;
		-- &#039;display&#039; parameter defaults to &amp;quot;inline, title&amp;quot; *** unused for now ***&lt;br /&gt;
		-- local disp = args.display or &amp;quot;&amp;quot;&lt;br /&gt;
		-- if disp == &amp;quot;&amp;quot; then disp = &amp;quot;inline, title&amp;quot; end&lt;br /&gt;
		--&lt;br /&gt;
		-- format parameter switches from deg/min/sec to decimal degrees&lt;br /&gt;
		-- default is deg/min/sec -- decimal degrees needs |format = dec&lt;br /&gt;
		local form = (args.format or &amp;quot;&amp;quot;):lower():sub(1,3)&lt;br /&gt;
		if form ~= &amp;quot;dec&amp;quot; then form = &amp;quot;dms&amp;quot; end&lt;br /&gt;
		--&lt;br /&gt;
		-- show parameter allows just the latitude or longitude to be shown&lt;br /&gt;
		local show = (args.show or &amp;quot;&amp;quot;):lower()&lt;br /&gt;
		if show ~= &amp;quot;longlat&amp;quot; then show = show:sub(1,3) end&lt;br /&gt;
		--&lt;br /&gt;
		local lat, long, prec = dv.latitude, dv.longitude, dv.precision&lt;br /&gt;
		if show == &amp;quot;lat&amp;quot; then&lt;br /&gt;
			val = decimalPrecision(lat, prec)&lt;br /&gt;
		elseif show == &amp;quot;lon&amp;quot; then&lt;br /&gt;
			val = decimalPrecision(long, prec)&lt;br /&gt;
		elseif show == &amp;quot;longlat&amp;quot; then&lt;br /&gt;
			val = decimalPrecision(long, prec) .. &amp;quot;, &amp;quot; .. decimalPrecision(lat, prec)&lt;br /&gt;
		else&lt;br /&gt;
			local ns = &amp;quot;N&amp;quot;&lt;br /&gt;
			local ew = &amp;quot;E&amp;quot;&lt;br /&gt;
			if lat &amp;lt; 0 then&lt;br /&gt;
				ns = &amp;quot;S&amp;quot;&lt;br /&gt;
				lat = - lat&lt;br /&gt;
			end&lt;br /&gt;
			if long &amp;lt; 0 then&lt;br /&gt;
				ew = &amp;quot;W&amp;quot;&lt;br /&gt;
				long = - long&lt;br /&gt;
			end&lt;br /&gt;
			if form == &amp;quot;dec&amp;quot; then&lt;br /&gt;
				lat = decimalPrecision(lat, prec)&lt;br /&gt;
				long = decimalPrecision(long, prec)&lt;br /&gt;
				val = lat .. &amp;quot;°&amp;quot; .. ns .. &amp;quot; &amp;quot; .. long ..  &amp;quot;°&amp;quot; .. ew&lt;br /&gt;
			else&lt;br /&gt;
				local latdeg, latmin, latsec = decimalToDMS(lat, prec)&lt;br /&gt;
				local longdeg, longmin, longsec = decimalToDMS(long, prec)&lt;br /&gt;
&lt;br /&gt;
				if latsec == 0 and longsec == 0 then&lt;br /&gt;
					if latmin == 0 and longmin == 0 then&lt;br /&gt;
						val = latdeg .. &amp;quot;°&amp;quot; .. ns .. &amp;quot; &amp;quot; .. longdeg ..  &amp;quot;°&amp;quot; .. ew&lt;br /&gt;
					else&lt;br /&gt;
						val = latdeg .. &amp;quot;°&amp;quot; .. latmin .. &amp;quot;′&amp;quot; .. ns .. &amp;quot; &amp;quot;&lt;br /&gt;
						val = val .. longdeg .. &amp;quot;°&amp;quot;.. longmin .. &amp;quot;′&amp;quot; .. ew&lt;br /&gt;
					end&lt;br /&gt;
				else&lt;br /&gt;
					val = latdeg .. &amp;quot;°&amp;quot; .. latmin .. &amp;quot;′&amp;quot; .. latsec .. &amp;quot;″&amp;quot; .. ns .. &amp;quot; &amp;quot;&lt;br /&gt;
					val = val .. longdeg .. &amp;quot;°&amp;quot; .. longmin .. &amp;quot;′&amp;quot; .. longsec .. &amp;quot;″&amp;quot; .. ew&lt;br /&gt;
				end&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
		------------------------------------&lt;br /&gt;
	elseif dtype == &amp;quot;monolingualtext&amp;quot; then -- data type is Monolingual text:&lt;br /&gt;
		-- has mainsnak.datavalue.value as a table containing language/text pairs&lt;br /&gt;
		-- collect all the values in &#039;out&#039; and languages in &#039;mlt&#039; and process them later&lt;br /&gt;
		val = pre .. dv.text .. post&lt;br /&gt;
		mlt = dv.language&lt;br /&gt;
		------------------------------------&lt;br /&gt;
	else&lt;br /&gt;
		-- some other data type so write a specific handler&lt;br /&gt;
		val = &amp;quot;unknown data type: &amp;quot; .. dtype&lt;br /&gt;
	end -- of datatype/unknown value/sourced check&lt;br /&gt;
	return val, mlt&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- propertyvalueandquals takes a property object, the arguments passed from frame,&lt;br /&gt;
-- and a qualifier propertyID.&lt;br /&gt;
-- It returns a sequence (table) of values representing the values of that property&lt;br /&gt;
-- and qualifiers that match the qualifierID if supplied.&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- Dependencies: parseParam(); sourced(); labelOrId(); i18n.latestdatequalifier(); format_Date();&lt;br /&gt;
-- makeOrdinal(); roundto(); decimalPrecision(); decimalToDMS(); assembleoutput();&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
local function propertyvalueandquals(objproperty, args, qualID)&lt;br /&gt;
	-- needs this style of declaration because it&#039;s re-entrant&lt;br /&gt;
&lt;br /&gt;
	-- onlysourced is a boolean passed to return only values sourced to other than Wikipedia&lt;br /&gt;
	-- if nothing or an empty string is passed set it true&lt;br /&gt;
	local onlysrc = parseParam(args.onlysourced or args.osd, true)&lt;br /&gt;
&lt;br /&gt;
	-- linked is a a boolean that enables the link to a local page via sitelink&lt;br /&gt;
	-- if nothing or an empty string is passed set it true&lt;br /&gt;
	local linked = parseParam(args.linked, true)&lt;br /&gt;
&lt;br /&gt;
	-- prefix is a string that may be nil, empty (&amp;quot;&amp;quot;), or a string of characters&lt;br /&gt;
	-- this is prefixed to each value&lt;br /&gt;
	-- useful when when multiple values are returned&lt;br /&gt;
	-- any double-quotes &amp;quot; are stripped out, so that spaces may be passed&lt;br /&gt;
	local prefix = (args.prefix or &amp;quot;&amp;quot;):gsub(&#039;&amp;quot;&#039;, &#039;&#039;)&lt;br /&gt;
&lt;br /&gt;
	-- postfix is a string that may be nil, empty (&amp;quot;&amp;quot;), or a string of characters&lt;br /&gt;
	-- this is postfixed to each value&lt;br /&gt;
	-- useful when when multiple values are returned&lt;br /&gt;
	-- any double-quotes &amp;quot; are stripped out, so that spaces may be passed&lt;br /&gt;
	local postfix = (args.postfix or &amp;quot;&amp;quot;):gsub(&#039;&amp;quot;&#039;, &#039;&#039;)&lt;br /&gt;
&lt;br /&gt;
	-- linkprefix is a string that may be nil, empty (&amp;quot;&amp;quot;), or a string of characters&lt;br /&gt;
	-- this creates a link and is then prefixed to each value&lt;br /&gt;
	-- useful when when multiple values are returned and indirect links are needed&lt;br /&gt;
	-- any double-quotes &amp;quot; are stripped out, so that spaces may be passed&lt;br /&gt;
	local lprefix = (args.linkprefix or args.lp or &amp;quot;&amp;quot;):gsub(&#039;&amp;quot;&#039;, &#039;&#039;)&lt;br /&gt;
&lt;br /&gt;
	-- linkpostfix is a string that may be nil, empty (&amp;quot;&amp;quot;), or a string of characters&lt;br /&gt;
	-- this is postfixed to each value when linking is enabled with lprefix&lt;br /&gt;
	-- useful when when multiple values are returned&lt;br /&gt;
	-- any double-quotes &amp;quot; are stripped out, so that spaces may be passed&lt;br /&gt;
	local lpostfix = (args.linkpostfix or &amp;quot;&amp;quot;):gsub(&#039;&amp;quot;&#039;, &#039;&#039;)&lt;br /&gt;
&lt;br /&gt;
	-- wdlinks is a boolean passed to enable links to Wikidata when no article exists&lt;br /&gt;
	-- if nothing or an empty string is passed set it false&lt;br /&gt;
	local wdl = parseParam(args.wdlinks or args.wdl, false)&lt;br /&gt;
&lt;br /&gt;
	-- unitabbr is a boolean passed to enable unit abbreviations for common units&lt;br /&gt;
	-- if nothing or an empty string is passed set it false&lt;br /&gt;
	local uabbr = parseParam(args.unitabbr or args.uabbr, false)&lt;br /&gt;
&lt;br /&gt;
	-- qualsonly is a boolean passed to return just the qualifiers&lt;br /&gt;
	-- if nothing or an empty string is passed set it false&lt;br /&gt;
	local qualsonly = parseParam(args.qualsonly or args.qo, false)&lt;br /&gt;
&lt;br /&gt;
	-- maxvals is a string that may be nil, empty (&amp;quot;&amp;quot;), or a number&lt;br /&gt;
	-- this determines how many items may be returned when multiple values are available&lt;br /&gt;
	-- setting it = 1 is useful where the returned string is used within another call, e.g. image&lt;br /&gt;
	local maxvals = tonumber(args.maxvals) or 0&lt;br /&gt;
&lt;br /&gt;
	-- pd (plain date) is a string: yes/true/1 | no/false/0 | adj&lt;br /&gt;
	-- to disable/enable &amp;quot;sourcing cirumstances&amp;quot; or use adjectival form for the plain date&lt;br /&gt;
	local pd = args.plaindate or args.pd or &amp;quot;no&amp;quot;&lt;br /&gt;
&lt;br /&gt;
	local lang = args.lang&lt;br /&gt;
	-- all proper values of a Wikidata property will be the same type as the first&lt;br /&gt;
	-- qualifiers don&#039;t have a mainsnak, properties do&lt;br /&gt;
	local datatype = objproperty[1].datatype or objproperty[1].mainsnak.datatype&lt;br /&gt;
	-- out holds the values for this property&lt;br /&gt;
	-- mlt holds the language code if the datatype is monolingual text&lt;br /&gt;
	local out = {}&lt;br /&gt;
	local mlt = {}&lt;br /&gt;
	for k, v in pairs(objproperty) do&lt;br /&gt;
		if (onlysrc and not sourced(v)) or (qualsonly and qualID) then&lt;br /&gt;
			-- no value: it isn&#039;t sourced when onlysourced=true&lt;br /&gt;
			-- or only qualifiers are requested&lt;br /&gt;
		else&lt;br /&gt;
			out[#out+1], mlt[#out+1] = rendersnak(v, args, linked, lprefix, lpostfix, prefix, postfix, uabbr)&lt;br /&gt;
		end&lt;br /&gt;
&lt;br /&gt;
		-- See if qualifiers are to be returned:&lt;br /&gt;
		local snak = v.mainsnak or v&lt;br /&gt;
		if v.qualifiers and qualID and snak.snaktype==&amp;quot;value&amp;quot; then&lt;br /&gt;
			local qsep = (args.qsep or &amp;quot;&amp;quot;):gsub(&#039;&amp;quot;&#039;, &#039;&#039;)&lt;br /&gt;
			local qargs = {&lt;br /&gt;
				[&amp;quot;osd&amp;quot;]         = &amp;quot;false&amp;quot;,&lt;br /&gt;
				[&amp;quot;linked&amp;quot;]      = tostring(linked),&lt;br /&gt;
				[&amp;quot;prefix&amp;quot;]      = args.qprefix,&lt;br /&gt;
				[&amp;quot;postfix&amp;quot;]     = args.qpostfix,&lt;br /&gt;
				[&amp;quot;linkprefix&amp;quot;]  = args.qlinkprefix or args.qlp,&lt;br /&gt;
				[&amp;quot;linkpostfix&amp;quot;] = args.qlinkpostfix,&lt;br /&gt;
				[&amp;quot;wdl&amp;quot;]         = &amp;quot;false&amp;quot;,&lt;br /&gt;
				[&amp;quot;unitabbr&amp;quot;]    = tostring(uabbr),&lt;br /&gt;
				[&amp;quot;maxvals&amp;quot;]     = 0,&lt;br /&gt;
				[&amp;quot;sorted&amp;quot;]      = args.qsorted,&lt;br /&gt;
				[&amp;quot;noicon&amp;quot;]      = &amp;quot;true&amp;quot;,&lt;br /&gt;
				[&amp;quot;list&amp;quot;]        = args.qlist,&lt;br /&gt;
				[&amp;quot;sep&amp;quot;]         = qsep,&lt;br /&gt;
				[&amp;quot;langobj&amp;quot;]     = args.langobj,&lt;br /&gt;
				[&amp;quot;lang&amp;quot;]        = args.langobj.code,&lt;br /&gt;
			}&lt;br /&gt;
			local qlist = {}&lt;br /&gt;
			local t1, t2 = &amp;quot;&amp;quot;, &amp;quot;&amp;quot;&lt;br /&gt;
			-- see if we want all qualifiers&lt;br /&gt;
			if qualID == &amp;quot;ALL&amp;quot; then&lt;br /&gt;
				if v[&amp;quot;qualifiers-order&amp;quot;] then&lt;br /&gt;
					-- the values in the order table are the keys for the qualifiers table:&lt;br /&gt;
					for k1, v1 in ipairs(v[&amp;quot;qualifiers-order&amp;quot;]) do&lt;br /&gt;
						if v1 == &amp;quot;P1326&amp;quot; then&lt;br /&gt;
							local ts = v.qualifiers[v1][1].datavalue.value.time&lt;br /&gt;
							local dp = v.qualifiers[v1][1].datavalue.value.precision&lt;br /&gt;
							qlist[#qlist + 1] = dateFormat(ts, dp, args.df, args.bc, pd, &amp;quot;&amp;quot;, lang, &amp;quot;before&amp;quot;)&lt;br /&gt;
						else&lt;br /&gt;
							qlist[#qlist + 1] = assembleoutput(propertyvalueandquals(v.qualifiers[v1], qargs), qargs)&lt;br /&gt;
						end&lt;br /&gt;
					end&lt;br /&gt;
				else&lt;br /&gt;
					local ql = propertyvalueandquals(v1, qargs)&lt;br /&gt;
					for k1, v1 in ipairs(ql) do&lt;br /&gt;
						if k1 == &amp;quot;P1326&amp;quot; then&lt;br /&gt;
							local ts = v1[1].datavalue.value.time&lt;br /&gt;
							local dp = v1[1].datavalue.value.precision&lt;br /&gt;
							qlist[#qlist + 1] = dateFormat(ts, dp, args.df, args.bc, pd, &amp;quot;&amp;quot;, lang, &amp;quot;before&amp;quot;)&lt;br /&gt;
						else&lt;br /&gt;
							qlist[#qlist + 1] = v1&lt;br /&gt;
						end&lt;br /&gt;
					end&lt;br /&gt;
				end&lt;br /&gt;
			-- see if we want date/range&lt;br /&gt;
			elseif qualID == &amp;quot;DATES&amp;quot; then&lt;br /&gt;
				qargs.maxvals = 1&lt;br /&gt;
				for k1, v1 in pairs(v.qualifiers) do&lt;br /&gt;
					if k1 == &amp;quot;P580&amp;quot; then -- P580 is &amp;quot;start time&amp;quot;&lt;br /&gt;
						t1 = propertyvalueandquals(v1, qargs)[1] or &amp;quot;&amp;quot;&lt;br /&gt;
					elseif k1 == &amp;quot;P582&amp;quot; then -- P582 is &amp;quot;end time&amp;quot;&lt;br /&gt;
						t2 = propertyvalueandquals(v1, qargs)[1] or &amp;quot;&amp;quot;&lt;br /&gt;
					end&lt;br /&gt;
				end&lt;br /&gt;
			-- otherwise process qualID as a list of qualifiers&lt;br /&gt;
			else&lt;br /&gt;
				for q in mw.text.gsplit(qualID, &amp;quot;%p&amp;quot;) do -- split at punctuation and iterate&lt;br /&gt;
					q = mw.text.trim(q):upper() -- remove whitespace and capitalise&lt;br /&gt;
					if q == &amp;quot;P1326&amp;quot; then&lt;br /&gt;
						-- latest date, so supply &#039;before&#039; as well. Assume one date value.&lt;br /&gt;
						for k1, v1 in pairs(v.qualifiers) do&lt;br /&gt;
							if k1 == &amp;quot;P1326&amp;quot; then&lt;br /&gt;
								local ts = v1[1].datavalue.value.time&lt;br /&gt;
								local dp = v1[1].datavalue.value.precision&lt;br /&gt;
								qlist[#qlist + 1] = dateFormat(ts, dp, args.df, args.bc, pd, &amp;quot;&amp;quot;, lang, &amp;quot;before&amp;quot;)&lt;br /&gt;
							end&lt;br /&gt;
						end&lt;br /&gt;
					else&lt;br /&gt;
						for k1, v1 in pairs(v.qualifiers) do&lt;br /&gt;
							if k1 == q then&lt;br /&gt;
								local ql = propertyvalueandquals(v1, qargs)&lt;br /&gt;
								for k2, v2 in ipairs(ql) do&lt;br /&gt;
									qlist[#qlist + 1] = v2&lt;br /&gt;
								end&lt;br /&gt;
							end&lt;br /&gt;
						end&lt;br /&gt;
					end&lt;br /&gt;
				end -- of loop through list of qualifiers in qualID&lt;br /&gt;
			end -- of testing for what qualID is&lt;br /&gt;
			local t = t1 .. t2&lt;br /&gt;
			-- *** internationalise date separators later ***&lt;br /&gt;
			if t:find(&amp;quot;%s&amp;quot;) or t:find(&amp;quot;&amp;amp;nbsp;&amp;quot;) then dsep = &amp;quot;  &amp;amp;ndash; &amp;quot; else dsep = &amp;quot;&amp;amp;ndash;&amp;quot; end&lt;br /&gt;
			if #qlist &amp;gt; 0 then&lt;br /&gt;
				local qstr = assembleoutput(qlist, qargs)&lt;br /&gt;
				if qualsonly then&lt;br /&gt;
					out[#out+1] = qstr&lt;br /&gt;
				else&lt;br /&gt;
					out[#out] = out[#out] .. &amp;quot; (&amp;quot; .. qstr .. &amp;quot;)&amp;quot;&lt;br /&gt;
				end&lt;br /&gt;
			elseif t &amp;gt; &amp;quot;&amp;quot; then&lt;br /&gt;
				-- *** internationalise date separators later ***&lt;br /&gt;
				local dsep = &amp;quot;&amp;amp;ndash;&amp;quot;&lt;br /&gt;
				if t:find(&amp;quot;%s&amp;quot;) or t:find(&amp;quot;&amp;amp;nbsp;&amp;quot;) then dsep = &amp;quot;  &amp;amp;ndash; &amp;quot; end&lt;br /&gt;
				if qualsonly then&lt;br /&gt;
					out[#out+1] = t1 .. dsep .. t2&lt;br /&gt;
				else&lt;br /&gt;
					out[#out] = out[#out] .. &amp;quot; (&amp;quot; .. t1 .. dsep .. t2 .. &amp;quot;)&amp;quot;&lt;br /&gt;
				end&lt;br /&gt;
			end&lt;br /&gt;
		end -- of test for qualifiers wanted&lt;br /&gt;
&lt;br /&gt;
		if maxvals &amp;gt; 0 and #out &amp;gt;= maxvals then break end&lt;br /&gt;
	end -- of for each value loop&lt;br /&gt;
&lt;br /&gt;
	-- we need to pick one value to return if the datatype was &amp;quot;monolingualtext&amp;quot;&lt;br /&gt;
	-- if there&#039;s only one value, use that&lt;br /&gt;
	-- otherwise look through the fallback languages for a match&lt;br /&gt;
	if datatype == &amp;quot;monolingualtext&amp;quot; and #out &amp;gt;1 then&lt;br /&gt;
		local langcode = args.langobj.code&lt;br /&gt;
		langcode = mw.text.split( langcode, &#039;-&#039;, true )[1]&lt;br /&gt;
		local fbtbl = mw.language.getFallbacksFor( langcode )&lt;br /&gt;
		table.insert( fbtbl, 1, langcode )&lt;br /&gt;
		bestval = &amp;quot;&amp;quot;&lt;br /&gt;
		found = false&lt;br /&gt;
		for idx1, lang1 in ipairs(fbtbl) do&lt;br /&gt;
			for idx2, lang2 in ipairs(mlt) do&lt;br /&gt;
				if (lang1 == lang2) and not found then&lt;br /&gt;
					bestval = out[idx2]&lt;br /&gt;
					found = true&lt;br /&gt;
					break&lt;br /&gt;
				end&lt;br /&gt;
			end -- loop through values of property&lt;br /&gt;
		end -- loop through fallback languages&lt;br /&gt;
		if found then&lt;br /&gt;
			-- replace output table with a table containing the best value&lt;br /&gt;
			out = { bestval }&lt;br /&gt;
		else&lt;br /&gt;
			-- more than one value and none of them on the list of fallback languages&lt;br /&gt;
			-- sod it, just give them the first one&lt;br /&gt;
			out = { out[1] }&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	return out&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- Common code for p.getValueByQual and p.getValueByLang&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- Dependencies: parseParam; setRanks; parseInput; sourced; assembleoutput;&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
local _getvaluebyqual = function(frame, qualID, checkvalue)&lt;br /&gt;
&lt;br /&gt;
	-- The property ID that will have a qualifier is the first unnamed parameter&lt;br /&gt;
	local propertyID = mw.text.trim(frame.args[1] or &amp;quot;&amp;quot;)&lt;br /&gt;
	if propertyID == &amp;quot;&amp;quot; then return &amp;quot;no property supplied&amp;quot; end&lt;br /&gt;
&lt;br /&gt;
	if qualID == &amp;quot;&amp;quot; then return &amp;quot;no qualifier supplied&amp;quot; end&lt;br /&gt;
&lt;br /&gt;
	-- onlysourced is a boolean passed to return property values&lt;br /&gt;
	-- only when property values are sourced to something other than Wikipedia&lt;br /&gt;
	-- if nothing or an empty string is passed set it true&lt;br /&gt;
	-- if &amp;quot;false&amp;quot; or &amp;quot;no&amp;quot; or 0 is passed set it false&lt;br /&gt;
	local onlysrc = parseParam(frame.args.onlysourced or frame.args.osd, true)&lt;br /&gt;
&lt;br /&gt;
	-- set the requested ranks flags&lt;br /&gt;
	frame.args.reqranks = setRanks(frame.args.rank)&lt;br /&gt;
&lt;br /&gt;
	-- set a language object and code in the frame.args table&lt;br /&gt;
	frame.args.langobj = findLang(frame.args.lang)&lt;br /&gt;
	frame.args.lang = frame.args.langobj.code&lt;br /&gt;
&lt;br /&gt;
	-- check for locally supplied parameter in second unnamed parameter&lt;br /&gt;
	-- success means no local parameter and the property exists&lt;br /&gt;
	local qid, props = parseInput(frame, frame.args[2], propertyID)&lt;br /&gt;
&lt;br /&gt;
	if qid then&lt;br /&gt;
		local out = {}&lt;br /&gt;
		-- Scan through the values of the property&lt;br /&gt;
		-- we want something like property is &amp;quot;pronunciation audio (P443)&amp;quot; in propertyID&lt;br /&gt;
		-- with a qualifier like &amp;quot;language of work or name (P407)&amp;quot; in qualID&lt;br /&gt;
		-- whose value has the required ID, like &amp;quot;British English (Q7979)&amp;quot;, in qval&lt;br /&gt;
		for k1, v1 in pairs(props) do&lt;br /&gt;
			if v1.mainsnak.snaktype == &amp;quot;value&amp;quot; and v1.mainsnak.datavalue.type == &amp;quot;string&amp;quot; then&lt;br /&gt;
				-- We&#039;ll only deal with returning strings for now&lt;br /&gt;
				-- so check if it has the right qualifier&lt;br /&gt;
				local v1q = v1.qualifiers&lt;br /&gt;
				if v1q and v1q[qualID] then&lt;br /&gt;
					if onlysrc == false or sourced(v1) then&lt;br /&gt;
						-- if we&#039;ve got this far, we have a (sourced) claim with qualifiers&lt;br /&gt;
						-- so see if matches the required value&lt;br /&gt;
						-- We&#039;ll only deal with wikibase-items for now&lt;br /&gt;
						if v1q[qualID][1].datatype == &amp;quot;wikibase-item&amp;quot; then&lt;br /&gt;
							if checkvalue(v1q[qualID][1].datavalue.value.id) then&lt;br /&gt;
								out[#out + 1] = v1.mainsnak.datavalue.value&lt;br /&gt;
							end&lt;br /&gt;
						end&lt;br /&gt;
					end -- of check for sourced&lt;br /&gt;
				end -- of check for matching required value and has qualifiers&lt;br /&gt;
			else&lt;br /&gt;
				return &amp;quot;not string&amp;quot;&lt;br /&gt;
			end -- of check for string&lt;br /&gt;
		end -- of loop through values of propertyID&lt;br /&gt;
		return assembleoutput(out, frame.args, qid, propertyID)&lt;br /&gt;
	else&lt;br /&gt;
		return props -- either local parameter or nothing&lt;br /&gt;
	end -- of test for success&lt;br /&gt;
	return nil&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- _location takes Q-id and follows P131 (located in the administrative territorial entity)&lt;br /&gt;
-- or P276 (location) or P706 (located on terrain feature)&lt;br /&gt;
-- from the initial item to higher level territories/locations until it reaches the highest.&lt;br /&gt;
-- An optional boolean, &#039;first&#039;, determines whether the first item is returned (default: false).&lt;br /&gt;
-- An optional boolean &#039;skip&#039; toggles the display to skip to the last item (default: false).&lt;br /&gt;
-- It returns a table containing the locations - linked where possible, except for the highest.&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- Dependencies: findLang(); labelOrId(); linkedItem&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
local _location = function(qid, first, skip)&lt;br /&gt;
	first = parseParam(first, false)&lt;br /&gt;
	skip = parseParam(skip, false)&lt;br /&gt;
	local out = {}&lt;br /&gt;
	local langcode = findLang():getCode()&lt;br /&gt;
	local finished = false&lt;br /&gt;
	local count = 0&lt;br /&gt;
	repeat&lt;br /&gt;
		local prop = mw.wikibase.getBestStatements(qid, &amp;quot;P131&amp;quot;)[1] or mw.wikibase.getBestStatements(qid, &amp;quot;P276&amp;quot;)[1] or mw.wikibase.getBestStatements(qid, &amp;quot;P706&amp;quot;)[1]&lt;br /&gt;
		-- check if it&#039;s an instance of (P31) a country (Q6256) and terminate the chain if it is&lt;br /&gt;
		local inst = mw.wikibase.getAllStatements(qid, &amp;quot;P31&amp;quot;)&lt;br /&gt;
		if #inst &amp;gt; 0 then&lt;br /&gt;
			for k, v in ipairs(inst) do&lt;br /&gt;
				local instid = v.mainsnak.datavalue.value.id&lt;br /&gt;
				-- stop if it&#039;s a country (or a country within the United Kingdom if skip is true)&lt;br /&gt;
				if instid == &amp;quot;Q6256&amp;quot; or (skip and instid == &amp;quot;Q3336843&amp;quot;) then&lt;br /&gt;
					prop = nil -- this will ensure this is treated as top-level location&lt;br /&gt;
					break&lt;br /&gt;
				end&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
		if prop and prop.mainsnak.datavalue then&lt;br /&gt;
			if not skip or count == 0 then&lt;br /&gt;
				out[#out+1] = linkedItem(qid, &amp;quot;:&amp;quot;, &amp;quot;&amp;quot;, &amp;quot;&amp;quot;, &amp;quot;&amp;quot;) -- get a linked value if we can&lt;br /&gt;
			end&lt;br /&gt;
			qid = prop.mainsnak.datavalue.value.id&lt;br /&gt;
		else&lt;br /&gt;
			-- This is top-level location, so get short name  except when this is the first item&lt;br /&gt;
			-- Use full label if there&#039;s no short name or this is the first item&lt;br /&gt;
			props = mw.wikibase.getAllStatements(qid, &amp;quot;P1813&amp;quot;)&lt;br /&gt;
			-- if there&#039;s a short name and this isn&#039;t the only item&lt;br /&gt;
			if props[1] and (#out &amp;gt; 0)then&lt;br /&gt;
				local shortname&lt;br /&gt;
				-- short name is monolingual text, so look for match to the local language&lt;br /&gt;
				-- choose the shortest &#039;short name&#039; in that language&lt;br /&gt;
				for k, v in pairs(props) do&lt;br /&gt;
					if v.mainsnak.datavalue.value.language == langcode then&lt;br /&gt;
						local name = v.mainsnak.datavalue.value.text&lt;br /&gt;
						if (not shortname) or (#name &amp;lt; #shortname) then&lt;br /&gt;
							shortname = name&lt;br /&gt;
						end&lt;br /&gt;
					end&lt;br /&gt;
				end&lt;br /&gt;
				-- add the shortname if one is found, fallback to the label&lt;br /&gt;
				-- but skip it if it&#039;s &amp;quot;USA&amp;quot;&lt;br /&gt;
				if shortname ~= &amp;quot;USA&amp;quot; then&lt;br /&gt;
					out[#out+1] = shortname or labelOrId(qid)&lt;br /&gt;
				else&lt;br /&gt;
					if skip then out[#out+1] = &amp;quot;US&amp;quot; end&lt;br /&gt;
				end&lt;br /&gt;
			else&lt;br /&gt;
				-- no shortname, so just add the label&lt;br /&gt;
				local loc = labelOrId(qid)&lt;br /&gt;
				-- exceptions go here:&lt;br /&gt;
				if loc == &amp;quot;United States of America&amp;quot; then&lt;br /&gt;
					out[#out+1] = &amp;quot;United States&amp;quot;&lt;br /&gt;
				else&lt;br /&gt;
					out[#out+1] = loc&lt;br /&gt;
				end&lt;br /&gt;
			end&lt;br /&gt;
			finished = true&lt;br /&gt;
		end&lt;br /&gt;
		count = count + 1&lt;br /&gt;
	until finished or count &amp;gt;= 10 -- limit to 10 levels to avoid infinite loops&lt;br /&gt;
	if not first then table.remove(out, 1) end&lt;br /&gt;
	return out&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- Public functions&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- getValue is used to get the value(s) of a property&lt;br /&gt;
-- The property ID is passed as the first unnamed parameter and is required.&lt;br /&gt;
-- A locally supplied parameter may optionaly be supplied as the second unnamed parameter.&lt;br /&gt;
-- The function will now also return qualifiers if parameter qual is supplied&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- Dependencies: setRanks; parseInput; propertyvalueandquals; assembleoutput; parseParam; sourced; &lt;br /&gt;
-- labelOrId; i18n.latestdatequalifier; format_Date; makeOrdinal; roundto; decimalPrecision; decimalToDMS;&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
p.getValue = function(frame)&lt;br /&gt;
	if not frame.args[1] then&lt;br /&gt;
		frame.args = frame:getParent().args&lt;br /&gt;
		if not frame.args[1] then return i18n.errors[&amp;quot;No property supplied&amp;quot;] end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- parameter sets for commonly used groups of parameters&lt;br /&gt;
	local paraset = tonumber(frame.args.ps or frame.args.parameterset or 0)&lt;br /&gt;
	if paraset == 1 then&lt;br /&gt;
		frame.args.rank = &amp;quot;best&amp;quot;&lt;br /&gt;
		frame.args.fetchwikidata = &amp;quot;ALL&amp;quot;&lt;br /&gt;
		frame.args.onlysourced = &amp;quot;no&amp;quot;&lt;br /&gt;
		frame.args.noicon = &amp;quot;true&amp;quot;&lt;br /&gt;
	elseif paraset == 2 then&lt;br /&gt;
		-- second set goes here&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	local propertyID = mw.text.trim(frame.args[1] or &amp;quot;&amp;quot;)&lt;br /&gt;
&lt;br /&gt;
	frame.args.reqranks = setRanks(frame.args.rank)&lt;br /&gt;
&lt;br /&gt;
	local entityid, props = parseInput(frame, frame.args[2], propertyID)&lt;br /&gt;
&lt;br /&gt;
	if not entityid then&lt;br /&gt;
		return props -- either the input parameter or nothing&lt;br /&gt;
	end&lt;br /&gt;
	-- qual is a string containing the property ID of the qualifier(s) to be returned&lt;br /&gt;
	-- if qual == &amp;quot;ALL&amp;quot; then all qualifiers returned&lt;br /&gt;
	-- if qual == &amp;quot;DATES&amp;quot; then qualifiers P580 (start time) and P582 (end time) returned&lt;br /&gt;
	-- if nothing or an empty string is passed set it nil -&amp;gt; no qualifiers returned&lt;br /&gt;
	local qualID = mw.text.trim(frame.args.qual or &amp;quot;&amp;quot;):upper()&lt;br /&gt;
	if qualID == &amp;quot;&amp;quot; then qualID = nil end&lt;br /&gt;
&lt;br /&gt;
	-- set a language object and code in the frame.args table&lt;br /&gt;
	frame.args.langobj = findLang(frame.args.lang)&lt;br /&gt;
	frame.args.lang = frame.args.langobj.code&lt;br /&gt;
&lt;br /&gt;
	-- table &#039;out&#039; stores the return value(s):&lt;br /&gt;
	local out = propertyvalueandquals(props, frame.args, qualID)&lt;br /&gt;
&lt;br /&gt;
	-- format the table of values and return it as a string:&lt;br /&gt;
	return assembleoutput(out, frame.args, entityid, propertyID)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- getPreferredValue is used to get a value,&lt;br /&gt;
-- (or a comma separated list of them if multiple values exist).&lt;br /&gt;
-- If preferred ranks are set, it will return those values, otherwise values with normal ranks&lt;br /&gt;
-- now redundant to getValue with |rank=best&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- Dependencies: p.getValue; setRanks; parseInput; propertyvalueandquals; assembleoutput;&lt;br /&gt;
-- parseParam; sourced; labelOrId; i18n.latestdatequalifier; format_Date;&lt;br /&gt;
-- makeOrdinal; roundto; decimalPrecision; decimalToDMS;&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
p.getPreferredValue = function(frame)&lt;br /&gt;
	frame.args.rank = &amp;quot;best&amp;quot;&lt;br /&gt;
	return p.getValue(frame)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- getCoords is used to get coordinates for display in an infobox&lt;br /&gt;
-- whitelist and blacklist are implemented&lt;br /&gt;
-- optional &#039;display&#039; parameter is allowed, defaults to &amp;quot;inline, title&amp;quot;&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- Dependencies: setRanks(); parseInput(); decimalPrecision();&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
p.getCoords = function(frame)&lt;br /&gt;
	local propertyID = &amp;quot;P625&amp;quot;&lt;br /&gt;
&lt;br /&gt;
	-- if there is a &#039;display&#039; parameter supplied, use it&lt;br /&gt;
	-- otherwise default to &amp;quot;inline, title&amp;quot;&lt;br /&gt;
	local disp = frame.args.display or &amp;quot;&amp;quot;&lt;br /&gt;
	if disp == &amp;quot;&amp;quot; then&lt;br /&gt;
		disp = &amp;quot;inline, title&amp;quot;&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- there may be a format parameter to switch from deg/min/sec to decimal degrees&lt;br /&gt;
	-- default is deg/min/sec&lt;br /&gt;
	-- decimal degrees needs |format = dec&lt;br /&gt;
	local form = (frame.args.format or &amp;quot;&amp;quot;):lower():sub(1,3)&lt;br /&gt;
	if form ~= &amp;quot;dec&amp;quot; then&lt;br /&gt;
		form = &amp;quot;dms&amp;quot;&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- just deal with best values&lt;br /&gt;
	frame.args.reqranks = setRanks(&amp;quot;best&amp;quot;)&lt;br /&gt;
&lt;br /&gt;
	local qid, props = parseInput(frame, frame.args[1], propertyID)&lt;br /&gt;
	if not qid then&lt;br /&gt;
		return props -- either local parameter or nothing&lt;br /&gt;
	else&lt;br /&gt;
		dv = props[1].mainsnak.datavalue.value&lt;br /&gt;
		local lat, long, prec = dv.latitude, dv.longitude, dv.precision&lt;br /&gt;
		lat = decimalPrecision(lat, prec)&lt;br /&gt;
		long = decimalPrecision(long, prec)&lt;br /&gt;
		local lat_long = { lat, long }&lt;br /&gt;
		lat_long[&amp;quot;display&amp;quot;] = disp&lt;br /&gt;
		lat_long[&amp;quot;format&amp;quot;] = form&lt;br /&gt;
		-- invoke template Coord with the values stored in the table&lt;br /&gt;
		return frame:expandTemplate{title = &#039;coord&#039;, args = lat_long}&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- getQualifierValue is used to get a formatted value of a qualifier&lt;br /&gt;
--&lt;br /&gt;
-- The call needs:	a property (the unnamed parameter or 1=)&lt;br /&gt;
-- 					a target value for that property (pval=)&lt;br /&gt;
--					a qualifier for that target value (qual=)&lt;br /&gt;
-- The usual whitelisting and blacklisting of the property is implemented&lt;br /&gt;
-- The boolean onlysourced= parameter can be set to return nothing&lt;br /&gt;
-- when the property is unsourced (or only sourced to Wikipedia)&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- Dependencies: parseParam(); setRanks(); parseInput(); sourced();&lt;br /&gt;
-- propertyvalueandquals(); assembleoutput();&lt;br /&gt;
-- labelOrId(); i18n.latestdatequalifier(); format_Date();&lt;br /&gt;
-- findLang(); makeOrdinal(); roundto(); decimalPrecision(); decimalToDMS();&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
p.getQualifierValue = function(frame)&lt;br /&gt;
&lt;br /&gt;
	-- The property ID that will have a qualifier is the first unnamed parameter&lt;br /&gt;
	local propertyID = mw.text.trim(frame.args[1] or &amp;quot;&amp;quot;)&lt;br /&gt;
&lt;br /&gt;
	-- The value of the property we want to match whose qualifier value is to be returned&lt;br /&gt;
	-- is passed in named parameter |pval=&lt;br /&gt;
	local propvalue = frame.args.pval&lt;br /&gt;
&lt;br /&gt;
	-- The property ID of the qualifier&lt;br /&gt;
	-- whose value is to be returned is passed in named parameter |qual=&lt;br /&gt;
	local qualifierID = frame.args.qual&lt;br /&gt;
&lt;br /&gt;
	-- onlysourced is a boolean passed to return qualifiers&lt;br /&gt;
	-- only when property values are sourced to something other than Wikipedia&lt;br /&gt;
	-- if nothing or an empty string is passed set it true&lt;br /&gt;
	-- if &amp;quot;false&amp;quot; or &amp;quot;no&amp;quot; or 0 is passed set it false&lt;br /&gt;
	local onlysrc = parseParam(frame.args.onlysourced or frame.args.osd, true)&lt;br /&gt;
&lt;br /&gt;
	-- set a language object in the frame.args table&lt;br /&gt;
	frame.args.langobj = findLang(frame.args.lang)&lt;br /&gt;
&lt;br /&gt;
	-- set the requested ranks flags&lt;br /&gt;
	frame.args.reqranks = setRanks(frame.args.rank)&lt;br /&gt;
&lt;br /&gt;
	-- check for locally supplied parameter in second unnamed parameter&lt;br /&gt;
	-- success means no local parameter and the property exists&lt;br /&gt;
	local qid, props = parseInput(frame, frame.args[2], propertyID)&lt;br /&gt;
	if qid then&lt;br /&gt;
		local out = {}&lt;br /&gt;
		-- Scan through the values of the property&lt;br /&gt;
		-- we want something like property is P793, significant event (in propertyID)&lt;br /&gt;
		-- whose value is something like Q385378, construction (in propvalue)&lt;br /&gt;
		-- then we can return the value(s) of a qualifier such as P580, start time (in qualifierID)&lt;br /&gt;
		for k1, v1 in pairs(props) do&lt;br /&gt;
			if v1.mainsnak.snaktype == &amp;quot;value&amp;quot; and v1.mainsnak.datavalue.type == &amp;quot;wikibase-entityid&amp;quot; then&lt;br /&gt;
				-- It&#039;s a wiki-linked value, so check if it&#039;s the target (in propvalue)&lt;br /&gt;
				-- and if it has qualifiers&lt;br /&gt;
				if v1.mainsnak.datavalue.value.id == propvalue and v1.qualifiers then&lt;br /&gt;
					if onlysrc == false or sourced(v1) then&lt;br /&gt;
						-- if we&#039;ve got this far, we have a (sourced) claim with qualifiers&lt;br /&gt;
						-- which matches the target, so find the value(s) of the qualifier we want&lt;br /&gt;
						local quals = v1.qualifiers[qualifierID]&lt;br /&gt;
						if quals then&lt;br /&gt;
							-- can&#039;t reference qualifer, so set onlysourced = &amp;quot;no&amp;quot; (not boolean)&lt;br /&gt;
							local qargs = frame.args&lt;br /&gt;
							qargs.onlysourced = &amp;quot;no&amp;quot;&lt;br /&gt;
							local vals = propertyvalueandquals(quals, qargs, qid)&lt;br /&gt;
							for k, v in pairs(vals) do&lt;br /&gt;
								out[#out + 1] = v&lt;br /&gt;
							end&lt;br /&gt;
						end&lt;br /&gt;
					end -- of check for sourced&lt;br /&gt;
				end -- of check for matching required value and has qualifiers&lt;br /&gt;
			end -- of check for wikibase entity&lt;br /&gt;
		end -- of loop through values of propertyID&lt;br /&gt;
		return assembleoutput(out, frame.args, qid, propertyID)&lt;br /&gt;
	else&lt;br /&gt;
		return props -- either local parameter or nothing&lt;br /&gt;
	end -- of test for success&lt;br /&gt;
	return nil&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- getValueByQual gets the value of a property which has a qualifier with a given entity value&lt;br /&gt;
-- The call needs:&lt;br /&gt;
--					a property ID (the unnamed parameter or 1=Pxxx)&lt;br /&gt;
--					the ID of a qualifier for that property (qualID=Pyyy)&lt;br /&gt;
--					the Wikibase-entity ID of a value for that qualifier (qvalue=Qzzz)&lt;br /&gt;
-- The usual whitelisting, blacklisting, onlysourced, etc. are implemented&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- Dependencies: _getvaluebyqual; parseParam; setRanks; parseInput; sourced;&lt;br /&gt;
-- assembleoutput;&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
p.getValueByQual = function(frame)&lt;br /&gt;
	local qualID = frame.args.qualID&lt;br /&gt;
	-- The Q-id of the value for the qualifier we want to match is in named parameter |qvalue=&lt;br /&gt;
	local qval = frame.args.qvalue or &amp;quot;&amp;quot;&lt;br /&gt;
	if qval == &amp;quot;&amp;quot; then return &amp;quot;no qualifier value supplied&amp;quot; end&lt;br /&gt;
	local function checkQID(id)&lt;br /&gt;
		return id == qval&lt;br /&gt;
	end&lt;br /&gt;
	return _getvaluebyqual(frame, qualID, checkQID)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- getValueByLang gets the value of a property which has a qualifier P407&lt;br /&gt;
-- (&amp;quot;language of work or name&amp;quot;) whose value has the given language code&lt;br /&gt;
-- The call needs:&lt;br /&gt;
--					a property ID (the unnamed parameter or 1=Pxxx)&lt;br /&gt;
--					the MediaWiki language code to match the language (lang=xx[-yy])&lt;br /&gt;
--					(if no code is supplied, it uses the default language)&lt;br /&gt;
-- The usual whitelisting, blacklisting, onlysourced, etc. are implemented&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- Dependencies: _getvaluebyqual; parseParam; setRanks; parseInput; sourced; assembleoutput;&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
p.getValueByLang = function(frame)&lt;br /&gt;
&lt;br /&gt;
	-- The language code for the qualifier we want to match is in named parameter |lang=&lt;br /&gt;
	local langcode = frame.args.lang or &amp;quot;&amp;quot;&lt;br /&gt;
	if langcode == &amp;quot;&amp;quot; then&lt;br /&gt;
		langcode = frame:callParserFunction{ name = &amp;quot;int&amp;quot;, args = &amp;quot;lang&amp;quot; }&lt;br /&gt;
	end&lt;br /&gt;
	function checkLanguage(id)&lt;br /&gt;
		-- id should represent a language like &amp;quot;British English (Q7979)&amp;quot;&lt;br /&gt;
		-- it should have string property &amp;quot;Wikimedia language code (P424)&amp;quot;&lt;br /&gt;
		-- qlcode will be a table:&lt;br /&gt;
		local qlcode = mw.wikibase.getBestStatements(id, &amp;quot;P424&amp;quot;)&lt;br /&gt;
		if (#qlcode &amp;gt; 0) and (qlcode[1].mainsnak.datavalue.value == langcode) then&lt;br /&gt;
			return true&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	return _getvaluebyqual(frame, &amp;quot;P407&amp;quot;, checkLanguage)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- getValueByRefSource gets the value of a property which has a reference &amp;quot;stated in&amp;quot; (P248)&lt;br /&gt;
-- whose value has the given entity code.&lt;br /&gt;
-- The call needs:&lt;br /&gt;
--					a property ID (the unnamed parameter or 1=Pxxx)&lt;br /&gt;
--					the entity ID of a value to match where the reference is stated in (match=Qzzz)&lt;br /&gt;
-- The usual whitelisting, blacklisting, onlysourced, etc. are implemented&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- Dependencies: parseParam; setRanks; parseInput; sourced; propertyvalueandquals assembleoutput;&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
p.getValueByRefSource = function(frame)&lt;br /&gt;
	-- The property ID that we want to check is the first unnamed parameter&lt;br /&gt;
	local propertyID = mw.text.trim(frame.args[1] or &amp;quot;&amp;quot;):upper()&lt;br /&gt;
	if propertyID == &amp;quot;&amp;quot; then return &amp;quot;no property supplied&amp;quot; end&lt;br /&gt;
&lt;br /&gt;
	-- The Q-id of the value we want to match is in named parameter |qvalue=&lt;br /&gt;
	local qval = (frame.args.match or &amp;quot;&amp;quot;):upper()&lt;br /&gt;
	if qval == &amp;quot;&amp;quot; then qval = &amp;quot;Q21540096&amp;quot; end&lt;br /&gt;
&lt;br /&gt;
	local unit = (frame.args.unit or &amp;quot;&amp;quot;):upper()&lt;br /&gt;
	if unit == &amp;quot;&amp;quot; then unit = &amp;quot;Q4917&amp;quot; end&lt;br /&gt;
&lt;br /&gt;
	local onlysrc = parseParam(frame.args.onlysourced or frame.args.osd, true)&lt;br /&gt;
&lt;br /&gt;
	-- set the requested ranks flags&lt;br /&gt;
	frame.args.reqranks = setRanks(frame.args.rank)&lt;br /&gt;
&lt;br /&gt;
	-- set a language object and code in the frame.args table&lt;br /&gt;
	frame.args.langobj = findLang(frame.args.lang)&lt;br /&gt;
	frame.args.lang = frame.args.langobj.code&lt;br /&gt;
&lt;br /&gt;
	local linked = parseParam(frame.args.linked, true)&lt;br /&gt;
&lt;br /&gt;
	local uabbr = parseParam(frame.args.uabbr or frame.args.unitabbr, false)&lt;br /&gt;
&lt;br /&gt;
	-- qid not nil means no local parameter and the property exists&lt;br /&gt;
	local qid, props = parseInput(frame, frame.args[2], propertyID)&lt;br /&gt;
&lt;br /&gt;
	if qid then&lt;br /&gt;
		local out = {}&lt;br /&gt;
		local mlt= {}&lt;br /&gt;
		for k1, v1 in pairs(props) do&lt;br /&gt;
			if onlysrc == false or sourced(v1) then&lt;br /&gt;
				if v1.references then&lt;br /&gt;
					for k2, v2 in pairs(v1.references) do&lt;br /&gt;
						if v2.snaks.P248 then&lt;br /&gt;
							for k3, v3 in pairs(v2.snaks.P248) do&lt;br /&gt;
								if v3.datavalue.value.id == qval then&lt;br /&gt;
									out[#out+1], mlt[#out+1] = rendersnak(v1, frame.args, linked, &amp;quot;&amp;quot;, &amp;quot;&amp;quot;, &amp;quot;&amp;quot;, &amp;quot;&amp;quot;, uabbr, unit)&lt;br /&gt;
									if not mlt[#out] then&lt;br /&gt;
										-- we only need one match per property value&lt;br /&gt;
										-- unless datatype was monolingual text&lt;br /&gt;
										break&lt;br /&gt;
									end&lt;br /&gt;
								end -- of test for match&lt;br /&gt;
							end -- of loop through values &amp;quot;stated in&amp;quot;&lt;br /&gt;
						end -- of test that &amp;quot;stated in&amp;quot; exists&lt;br /&gt;
					end -- of loop through references&lt;br /&gt;
				end -- of test that references exist&lt;br /&gt;
			end -- of test for sourced&lt;br /&gt;
		end -- of loop through values of propertyID&lt;br /&gt;
		if #mlt &amp;gt; 0 then&lt;br /&gt;
			local langcode = frame.args.lang&lt;br /&gt;
			langcode = mw.text.split( langcode, &#039;-&#039;, true )[1]&lt;br /&gt;
			local fbtbl = mw.language.getFallbacksFor( langcode )&lt;br /&gt;
			table.insert( fbtbl, 1, langcode )&lt;br /&gt;
			bestval = &amp;quot;&amp;quot;&lt;br /&gt;
			found = false&lt;br /&gt;
			for idx1, lang1 in ipairs(fbtbl) do&lt;br /&gt;
				for idx2, lang2 in ipairs(mlt) do&lt;br /&gt;
					if (lang1 == lang2) and not found then&lt;br /&gt;
						bestval = out[idx2]&lt;br /&gt;
						found = true&lt;br /&gt;
						break&lt;br /&gt;
					end&lt;br /&gt;
				end -- loop through values of property&lt;br /&gt;
			end -- loop through fallback languages&lt;br /&gt;
			if found then&lt;br /&gt;
				-- replace output table with a table containing the best value&lt;br /&gt;
				out = { bestval }&lt;br /&gt;
			else&lt;br /&gt;
				-- more than one value and none of them on the list of fallback languages&lt;br /&gt;
				-- sod it, just give them the first one&lt;br /&gt;
				out = { out[1] }&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
		return assembleoutput(out, frame.args, qid, propertyID)&lt;br /&gt;
	else&lt;br /&gt;
		return props -- no property or local parameter supplied&lt;br /&gt;
	end -- of test for success&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- getCommonsLink takes an optional qid of a Wikidata entity passed as |qid=&lt;br /&gt;
-- It returns one of the following in order of preference:&lt;br /&gt;
-- the Commons sitelink of the linked Wikidata item;&lt;br /&gt;
-- the Commons sitelink of the topic&#039;s main category of the linked Wikidata item;&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- Dependencies: _getCommonslink(); _getSitelink()&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
p.getCommonsLink = function(frame)&lt;br /&gt;
	return _getCommonslink(frame.args.qid, frame.args.onlycat or frame.args.onlycategories)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- getSitelink takes the qid of a Wikidata entity passed as |qid=&lt;br /&gt;
-- It takes an optional parameter |wiki= to determine which wiki is to be checked for a sitelink&lt;br /&gt;
-- If the parameter is blank, then it uses the local wiki.&lt;br /&gt;
-- If there is a sitelink to an article available, it returns the plain text link to the article&lt;br /&gt;
-- If there is no sitelink, it returns nil.&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- Dependencies: none&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
p.getSiteLink = function(frame)&lt;br /&gt;
	return _getSitelink(frame.args.qid, frame.args.wiki or mw.text.trim(frame.args[1] or &amp;quot;&amp;quot;))&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- getLink has the qid of a Wikidata entity passed as the first unnamed parameter or as |qid=&lt;br /&gt;
-- If there is a sitelink to an article on the local Wiki, it returns a link to the article&lt;br /&gt;
-- with the Wikidata label as the displayed text.&lt;br /&gt;
-- If there is no sitelink, it returns the label as plain text.&lt;br /&gt;
-- If there is no label in the local language, it displays the qid instead.&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- Dependencies: none&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
p.getLink = function(frame)&lt;br /&gt;
	local itemID = mw.text.trim(frame.args[1] or frame.args.qid or &amp;quot;&amp;quot;)&lt;br /&gt;
	if itemID == &amp;quot;&amp;quot; then return end&lt;br /&gt;
	local sitelink = mw.wikibase.sitelink(itemID)&lt;br /&gt;
	local label = labelOrId(itemID)&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 label&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- getLabel has the qid of a Wikidata entity passed as the first unnamed parameter or as |qid=&lt;br /&gt;
-- It returns the Wikidata label for the local language as plain text.&lt;br /&gt;
-- If there is no label in the local language, it displays the qid instead.&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- Dependencies: none&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
p.getLabel = function(frame)&lt;br /&gt;
	local itemID = mw.text.trim(frame.args[1] or frame.args.qid or &amp;quot;&amp;quot;)&lt;br /&gt;
	if itemID == &amp;quot;&amp;quot; then return end&lt;br /&gt;
	local label = labelOrId(itemID)&lt;br /&gt;
	return label&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- getAT has the qid of a Wikidata entity passed as the first unnamed parameter or as |qid=&lt;br /&gt;
-- If there is a sitelink to an article on the local Wiki, it returns the sitelink as plain text.&lt;br /&gt;
-- If there is no sitelink, it returns nothing.&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- Dependencies: none&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
p.getAT = function(frame)&lt;br /&gt;
	local itemID = mw.text.trim(frame.args[1] or frame.args.qid or &amp;quot;&amp;quot;)&lt;br /&gt;
	if itemID == &amp;quot;&amp;quot; then return end&lt;br /&gt;
	return mw.wikibase.sitelink(itemID)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- getDescription has the qid of a Wikidata entity passed as |qid=&lt;br /&gt;
-- (it defaults to the associated qid of the current article if omitted)&lt;br /&gt;
-- and a local parameter passed as the first unnamed parameter.&lt;br /&gt;
-- Any local parameter passed (other than &amp;quot;Wikidata&amp;quot; or &amp;quot;none&amp;quot;) becomes the return value.&lt;br /&gt;
-- It returns the article description for the Wikidata entity if the local parameter is &amp;quot;Wikidata&amp;quot;.&lt;br /&gt;
-- Nothing is returned if the description doesn&#039;t exist or &amp;quot;none&amp;quot; is passed as the local parameter.&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- Dependencies: none&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
p.getDescription = function(frame)&lt;br /&gt;
	local desc = mw.text.trim(frame.args[1] or &amp;quot;&amp;quot;)&lt;br /&gt;
	local itemID = mw.text.trim(frame.args.qid or &amp;quot;&amp;quot;)&lt;br /&gt;
	if itemID == &amp;quot;&amp;quot; then itemID = nil end&lt;br /&gt;
	if desc:lower() == &#039;wikidata&#039; then&lt;br /&gt;
		return mw.wikibase.description(itemID)&lt;br /&gt;
	elseif desc:lower() == &#039;none&#039; then&lt;br /&gt;
		return nil&lt;br /&gt;
	else&lt;br /&gt;
		return desc&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- pageId returns the page id (entity ID, Qnnn) of the current page&lt;br /&gt;
-- returns nothing if the page is not connected to Wikidata&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- Dependencies: none&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
p.pageId = function(frame)&lt;br /&gt;
	return mw.wikibase.getEntityIdForCurrentPage()&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- formatDate is a wrapper to export the private function format_Date&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- Dependencies: format_Date();&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
p.formatDate = function(frame)&lt;br /&gt;
	return format_Date(frame.args[1], frame.args.df, frame.args.bc)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- location is a wrapper to export the private function _location&lt;br /&gt;
-- it takes the entity-id as qid or the first unnamed parameter&lt;br /&gt;
-- optional boolean parameter first toggles the display of the first item&lt;br /&gt;
-- optional boolean parameter skip toggles the display to skip to the last item&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- Dependencies: _location();&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
p.location = function(frame)&lt;br /&gt;
	local qid = mw.text.trim(frame.args.qid or frame.args[1] or &amp;quot;&amp;quot;):upper()&lt;br /&gt;
	if qid == &amp;quot;&amp;quot; then return &amp;quot;No id supplied&amp;quot; end&lt;br /&gt;
	local first = mw.text.trim(frame.args.first or &amp;quot;&amp;quot;)&lt;br /&gt;
	local skip = mw.text.trim(frame.args.skip or &amp;quot;&amp;quot;)&lt;br /&gt;
	return table.concat( _location(qid, first, skip), &amp;quot;, &amp;quot; )&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- checkBlacklist implements a test to check whether a named field is allowed&lt;br /&gt;
-- returns true if the field is not blacklisted (i.e. allowed)&lt;br /&gt;
-- returns false if the field is blacklisted (i.e. disallowed)&lt;br /&gt;
-- {{#if:{{#invoke:WikidataIB |checkBlacklist |name=Joe |suppressfields=Dave; Joe; Fred}} | not blacklisted | blacklisted}}&lt;br /&gt;
-- displays &amp;quot;blacklisted&amp;quot;&lt;br /&gt;
-- {{#if:{{#invoke:WikidataIB |checkBlacklist |name=Jim |suppressfields=Dave; Joe; Fred}} | not blacklisted | blacklisted}}&lt;br /&gt;
-- displays &amp;quot;not blacklisted&amp;quot;&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- Dependencies: none&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
p.checkBlacklist = function(frame)&lt;br /&gt;
	local blacklist = frame.args.suppressfields or frame.args.spf or &amp;quot;&amp;quot;&lt;br /&gt;
	local fieldname = frame.args.name or &amp;quot;&amp;quot;&lt;br /&gt;
	if blacklist ~= &amp;quot;&amp;quot; and fieldname ~= &amp;quot;&amp;quot; then&lt;br /&gt;
		if blacklist:find(fieldname) then&lt;br /&gt;
			return false&lt;br /&gt;
		else&lt;br /&gt;
			return true&lt;br /&gt;
		end&lt;br /&gt;
	else&lt;br /&gt;
		-- one of the fields is missing: let&#039;s call that &amp;quot;not on the list&amp;quot;&lt;br /&gt;
		return true&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- emptyor returns nil if its first unnamed argument is just punctuation, whitespace or html tags&lt;br /&gt;
-- otherwise it returns the argument unchanged (including leading/trailing space).&lt;br /&gt;
-- If the argument may contain &amp;quot;=&amp;quot;, then it must be called explicitly:&lt;br /&gt;
-- |1=arg&lt;br /&gt;
-- (In that case, leading and trailing spaces are trimmed)&lt;br /&gt;
-- It finds use in infoboxes where it can replace tests like:&lt;br /&gt;
-- {{#if: {{#invoke:WikidatIB |getvalue |P99 |fwd=ALL}} | &amp;lt;span class=&amp;quot;xxx&amp;quot;&amp;gt;{{#invoke:WikidatIB |getvalue |P99 |fwd=ALL}}&amp;lt;/span&amp;gt; | }}&lt;br /&gt;
-- with a form that uses just a single call to Wikidata:&lt;br /&gt;
-- {{#invoke |WikidataIB |emptyor |1= &amp;lt;span class=&amp;quot;xxx&amp;quot;&amp;gt;{{#invoke:WikidataIB |getvalue |P99 |fwd=ALL}}&amp;lt;/span&amp;gt; }}&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- Dependencies: none&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
p.emptyor = function(frame)&lt;br /&gt;
	local s = frame.args[1] or &amp;quot;&amp;quot;&lt;br /&gt;
	if s == &amp;quot;&amp;quot; then return nil end&lt;br /&gt;
	local sx = s:gsub(&amp;quot;%s&amp;quot;, &amp;quot;&amp;quot;):gsub(&amp;quot;&amp;lt;[^&amp;gt;]*&amp;gt;&amp;quot;, &amp;quot;&amp;quot;):gsub(&amp;quot;%p&amp;quot;, &amp;quot;&amp;quot;)&lt;br /&gt;
	if sx == &amp;quot;&amp;quot; then&lt;br /&gt;
		return nil&lt;br /&gt;
	else&lt;br /&gt;
		return s&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- labelorid is a public function to expose the output of labelOrId()&lt;br /&gt;
-- Pass the Q-number as |qid= or as an unnamed parameter.&lt;br /&gt;
-- It returns the Wikidata label for that entity or the qid if no label exists.&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- Dependencies: labelOrId&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
p.labelorid = function(frame)&lt;br /&gt;
	local label = labelOrId( frame.args.qid or frame.args[1] )&lt;br /&gt;
	return label&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- getLang returns the MediaWiki language code of the current content.&lt;br /&gt;
-- If optional parameter |style=full, it returns the language name.&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- Dependencies: none&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
p.getLang = function(frame)&lt;br /&gt;
	local style = (frame.args.style or &amp;quot;&amp;quot;):lower()&lt;br /&gt;
	local langcode = mw.language.getContentLanguage().code&lt;br /&gt;
	if style == &amp;quot;full&amp;quot; then&lt;br /&gt;
		return mw.language.fetchLanguageName( langcode )&lt;br /&gt;
	end&lt;br /&gt;
	return langcode&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- findLanguage exports the local findLang() function&lt;br /&gt;
-- It takes an optional language code and returns, in order of preference:&lt;br /&gt;
-- the code if a known language;&lt;br /&gt;
-- the user&#039;s language, if set;&lt;br /&gt;
-- the server&#039;s content language.&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- Dependencies: findLang&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
p.findLanguage = function(frame)&lt;br /&gt;
	return findLang(frame.args.lang or frame.args[1]).code&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- getQid returns the qid, if supplied&lt;br /&gt;
-- failing that, the Wikidata entity ID of the &amp;quot;category&#039;s main topic (P301)&amp;quot;, if it exists&lt;br /&gt;
-- failing that, the Wikidata entity ID asociated with the curent page, if it exists&lt;br /&gt;
-- otherwise, nothing&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- Dependencies: none&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
p.getQid = function(frame)&lt;br /&gt;
	local qid = (frame.args.qid or &amp;quot;&amp;quot;):upper()&lt;br /&gt;
	-- check if a qid was passed; if so, return it:&lt;br /&gt;
	if qid ~= &amp;quot;&amp;quot; then return qid end&lt;br /&gt;
	-- check if there&#039;s a &amp;quot;category&#039;s main topic (P301)&amp;quot;:&lt;br /&gt;
	qid = mw.wikibase.getEntityIdForCurrentPage()&lt;br /&gt;
	if qid then&lt;br /&gt;
		local prop301 = mw.wikibase.getBestStatements(qid, &amp;quot;P301&amp;quot;)&lt;br /&gt;
		if prop301[1] then&lt;br /&gt;
			local mctid = prop301[1].mainsnak.datavalue.value.id&lt;br /&gt;
			if mctid then return mctid end&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	-- otherwise return the page qid (if any)&lt;br /&gt;
	return qid&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- followQid takes two optional parameters: qid and props&lt;br /&gt;
-- If qid is not given, it uses the qid for the connected page&lt;br /&gt;
-- or returns nil if there isn&#039;t one.&lt;br /&gt;
-- props is a list of properties, separated by punctuation.&lt;br /&gt;
-- If props is given, the Wikidata item for the qid is examined for each property in turn.&lt;br /&gt;
-- If that property contains a value that is another Wikibase-item, that item&#039;s qid is returned,&lt;br /&gt;
-- and the search terminates.&lt;br /&gt;
-- If props is not given, the qid is returned.&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- Dependencies: none&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
p.followQid = function(frame)&lt;br /&gt;
	local qid = (frame.args.qid or &amp;quot;&amp;quot;):upper()&lt;br /&gt;
	if qid == &amp;quot;&amp;quot; then&lt;br /&gt;
		qid = mw.wikibase.getEntityIdForCurrentPage()&lt;br /&gt;
	end&lt;br /&gt;
	if not qid then return nil end&lt;br /&gt;
&lt;br /&gt;
	local props = (frame.args.props or &amp;quot;&amp;quot;):upper()&lt;br /&gt;
	if props ~= &amp;quot;&amp;quot; then&lt;br /&gt;
		for p in mw.text.gsplit(props, &amp;quot;%p&amp;quot;) do -- split at punctuation and iterate&lt;br /&gt;
			p = mw.text.trim(p)&lt;br /&gt;
			for i, v in ipairs( mw.wikibase.getBestStatements(qid, p) ) do&lt;br /&gt;
				local linkedid = v.mainsnak.datavalue and v.mainsnak.datavalue.value.id&lt;br /&gt;
				if linkedid then&lt;br /&gt;
					return linkedid&lt;br /&gt;
				end&lt;br /&gt;
			end -- loop through values of property to follow&lt;br /&gt;
		end -- loop through list of properties to follow&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	return qid&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- siteID returns the root of the globalSiteID&lt;br /&gt;
-- e.g. &amp;quot;en&amp;quot; for &amp;quot;enwiki&amp;quot;, &amp;quot;enwikisource&amp;quot;, etc.&lt;br /&gt;
-- treats &amp;quot;en-gb&amp;quot; as &amp;quot;en&amp;quot;, etc.&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- Dependencies: none&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
p.siteID = function(frame)&lt;br /&gt;
	local txtlang = frame:preprocess( &amp;quot;{{int:lang}}&amp;quot; ) or &amp;quot;&amp;quot;&lt;br /&gt;
	-- This deals with specific exceptions: be-tarask -&amp;gt; be-x-old&lt;br /&gt;
	if txtlang == &amp;quot;be-tarask&amp;quot; then&lt;br /&gt;
		return &amp;quot;be_x_old&amp;quot;&lt;br /&gt;
	end&lt;br /&gt;
	local pos = txtlang:find(&amp;quot;-&amp;quot;)&lt;br /&gt;
	local ret = &amp;quot;&amp;quot;&lt;br /&gt;
	if pos then&lt;br /&gt;
		ret = txtlang:sub(1, pos-1)&lt;br /&gt;
	else&lt;br /&gt;
		ret = txtlang&lt;br /&gt;
	end&lt;br /&gt;
	return ret&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- projID returns the code used to link to the reader&#039;s language&#039;s project&lt;br /&gt;
-- e.g &amp;quot;en&amp;quot; for [[:en:WikidataIB]]&lt;br /&gt;
-- treats &amp;quot;en-gb&amp;quot; as &amp;quot;en&amp;quot;, etc.&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- Dependencies: none&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
p.projID = function(frame)&lt;br /&gt;
	local txtlang = frame:preprocess( &amp;quot;{{int:lang}}&amp;quot; ) or &amp;quot;&amp;quot;&lt;br /&gt;
	-- This deals with specific exceptions: be-tarask -&amp;gt; be-x-old&lt;br /&gt;
	if txtlang == &amp;quot;be-tarask&amp;quot; then&lt;br /&gt;
		return &amp;quot;be-x-old&amp;quot;&lt;br /&gt;
	end&lt;br /&gt;
	local pos = txtlang:find(&amp;quot;-&amp;quot;)&lt;br /&gt;
	local ret = &amp;quot;&amp;quot;&lt;br /&gt;
	if pos then&lt;br /&gt;
		ret = txtlang:sub(1, pos-1)&lt;br /&gt;
	else&lt;br /&gt;
		ret = txtlang&lt;br /&gt;
	end&lt;br /&gt;
	return ret&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- formatNumber formats a number according to the the supplied language code (&amp;quot;|lang=&amp;quot;)&lt;br /&gt;
-- or the default language if not supplied.&lt;br /&gt;
-- The number is the first unnamed parameter or &amp;quot;|num=&amp;quot;&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- Dependencies: findLang()&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
p.formatNumber = function(frame)&lt;br /&gt;
	local lang&lt;br /&gt;
	local num = tonumber(frame.args[1] or frame.args.num) or 0&lt;br /&gt;
	lang = findLang(frame.args.lang)&lt;br /&gt;
	return lang:formatNum( num )&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- examine dumps the property (the unnamed parameter or pid)&lt;br /&gt;
-- from the item given by the parameter &#039;qid&#039; (or the other unnamed parameter)&lt;br /&gt;
-- or from the item corresponding to the current page if qid is not supplied.&lt;br /&gt;
-- e.g. {{#invoke:WikidataIB |examine |pid=P26 |qid=Q42}}&lt;br /&gt;
-- or {{#invoke:WikidataIB |examine |P26 |Q42}} or any combination of these&lt;br /&gt;
-- or {{#invoke:WikidataIB |examine |P26}} for the current page.&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- Dependencies: none&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
p.examine = function( frame )&lt;br /&gt;
	local args&lt;br /&gt;
	if frame.args[1] or frame.args.pid or frame.args.qid then&lt;br /&gt;
		args = frame.args&lt;br /&gt;
	else&lt;br /&gt;
		args = frame:getParent().args&lt;br /&gt;
	end&lt;br /&gt;
	local par = {}&lt;br /&gt;
	local pid = (args.pid or &amp;quot;&amp;quot;):upper()&lt;br /&gt;
	local qid = (args.qid or &amp;quot;&amp;quot;):upper()&lt;br /&gt;
	par[1] = mw.text.trim( args[1] or &amp;quot;&amp;quot; ):upper()&lt;br /&gt;
	par[2] = mw.text.trim( args[2] or &amp;quot;&amp;quot; ):upper()&lt;br /&gt;
	table.sort(par)&lt;br /&gt;
	if par[2]:sub(1,1) == &amp;quot;P&amp;quot; then par[1], par[2] = par[2], par[1] end&lt;br /&gt;
	if pid == &amp;quot;&amp;quot; then pid = par[1] end&lt;br /&gt;
	if qid == &amp;quot;&amp;quot; then qid = par[2] end&lt;br /&gt;
	if pid:sub(1,1) ~= &amp;quot;P&amp;quot; then return &amp;quot;No property supplied&amp;quot; end&lt;br /&gt;
	if qid:sub(1,1) ~= &amp;quot;Q&amp;quot; then qid = mw.wikibase.getEntityIdForCurrentPage() end&lt;br /&gt;
	if not qid then return &amp;quot;No item for this page&amp;quot; end&lt;br /&gt;
	return mw.dumpObject( mw.wikibase.getAllStatements( qid, pid ) )&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- checkvalue looks for &#039;val&#039; as a wikibase-item value of a property (the unnamed parameter or pid)&lt;br /&gt;
-- from the item given by the parameter &#039;qid&#039;&lt;br /&gt;
-- or from the Wikidata item associated with the current page if qid is not supplied.&lt;br /&gt;
-- If property is not supplied, then P31 (instance of) is assumed.&lt;br /&gt;
-- It returns val if found or nothing if not found.&lt;br /&gt;
-- e.g. {{#invoke:WikidataIB |checkvalue |val=Q5 |pid=P31 |qid=Q42}}&lt;br /&gt;
-- or {{#invoke:WikidataIB |checkvalue |val=Q5 |P31 |qid=Q42}}&lt;br /&gt;
-- or {{#invoke:WikidataIB |checkvalue |val=Q5 |qid=Q42}}&lt;br /&gt;
-- or {{#invoke:WikidataIB |checkvalue |val=Q5 |P31}} for the current page.&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- Dependencies: none&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
p.checkvalue = function( frame )&lt;br /&gt;
	local args&lt;br /&gt;
	if frame.args.val then&lt;br /&gt;
		args = frame.args&lt;br /&gt;
	else&lt;br /&gt;
		args = frame:getParent().args&lt;br /&gt;
	end&lt;br /&gt;
	local val = args.val&lt;br /&gt;
	if not val then return nil end&lt;br /&gt;
	local pid = mw.text.trim(args.pid or args[1] or &amp;quot;P31&amp;quot;):upper()&lt;br /&gt;
	local qid = (args.qid or &amp;quot;&amp;quot;):upper()&lt;br /&gt;
	if pid:sub(1,1) ~= &amp;quot;P&amp;quot; then return nil end&lt;br /&gt;
	if qid:sub(1,1) ~= &amp;quot;Q&amp;quot; then qid = mw.wikibase.getEntityIdForCurrentPage() end&lt;br /&gt;
	if not qid then return nil end&lt;br /&gt;
	local stats = mw.wikibase.getAllStatements( qid, pid )&lt;br /&gt;
	if not stats[1] then return nil end&lt;br /&gt;
	if stats[1].mainsnak.datatype == &amp;quot;wikibase-item&amp;quot; then&lt;br /&gt;
		for k, v in pairs( stats ) do&lt;br /&gt;
			if v.mainsnak.snaktype == &amp;quot;value&amp;quot; and v.mainsnak.datavalue.value.id == val then&lt;br /&gt;
				return val&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	return nil&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- url2 takes a parameter url= that is a proper url and formats it for use in an infobox.&lt;br /&gt;
-- If no parameter is supplied, it returns nothing.&lt;br /&gt;
-- This is the equivalent of Template:URL&lt;br /&gt;
-- but it keeps the &amp;quot;edit at Wikidata&amp;quot; pen icon out of the microformat.&lt;br /&gt;
-- Usually it will take its url parameter directly from a Wikidata call:&lt;br /&gt;
-- e.g. {{#invoke:WikidataIB |url2 |url={{wdib |P856 |qid=Q23317 |fwd=ALL |osd=no}}&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- Dependencies: none&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
p.url2 = function(frame)&lt;br /&gt;
	local txt = frame.args.url or &amp;quot;&amp;quot;&lt;br /&gt;
	if txt == &amp;quot;&amp;quot; then return nil end&lt;br /&gt;
	local url, icon = txt:match(&amp;quot;(.+)&amp;amp;nbsp;(.+)&amp;quot;)&lt;br /&gt;
	url = url or txt&lt;br /&gt;
	icon = icon or &amp;quot;&amp;quot;&lt;br /&gt;
	local prot, addr = url:match(&amp;quot;(http[s]*://)(.+)&amp;quot;)&lt;br /&gt;
	prot = prot or url&lt;br /&gt;
	addr = addr or &amp;quot;&amp;quot;&lt;br /&gt;
	local disp, n = addr:gsub(&amp;quot;%.&amp;quot;, &amp;quot;&amp;lt;wbr/&amp;gt;%.&amp;quot;)&lt;br /&gt;
	return &#039;&amp;lt;span class=&amp;quot;url&amp;quot;&amp;gt;[&#039; .. prot .. addr .. &amp;quot; &amp;quot; .. disp .. &amp;quot;]&amp;lt;/span&amp;gt;&amp;amp;nbsp;&amp;quot; .. icon&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- getWebsite fetches the Official website (P856) and formats it for use in an infobox.&lt;br /&gt;
-- This is similar to Template:Official website but with a url displayed,&lt;br /&gt;
-- and it adds the &amp;quot;edit at Wikidata&amp;quot; pen icon beyond the microformat if enabled.&lt;br /&gt;
-- A local value will override the Wikidata value. &amp;quot;NONE&amp;quot; returns nothing.&lt;br /&gt;
-- e.g. {{#invoke:WikidataIB |getWebsite |qid= |noicon= |lang= |url= }}&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- Dependencies: findLang(); parseParam();&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
p.getWebsite = function(frame)&lt;br /&gt;
	local url = frame.args.url or &amp;quot;&amp;quot;&lt;br /&gt;
	if url:upper() == &amp;quot;NONE&amp;quot; then return nil end&lt;br /&gt;
&lt;br /&gt;
	local qid = frame.args.qid or &amp;quot;&amp;quot;&lt;br /&gt;
	if qid == &amp;quot;&amp;quot; then qid = mw.wikibase.getEntityIdForCurrentPage() end&lt;br /&gt;
	if not qid then return nil end&lt;br /&gt;
&lt;br /&gt;
	local urls = {}&lt;br /&gt;
	local quals = {}&lt;br /&gt;
	if url == &amp;quot;&amp;quot; then&lt;br /&gt;
		local props = mw.wikibase.getBestStatements(qid, &amp;quot;P856&amp;quot;)&lt;br /&gt;
		for k, v in pairs(props) do&lt;br /&gt;
			if v.mainsnak.snaktype == &amp;quot;value&amp;quot; then&lt;br /&gt;
				urls[#urls+1] = v.mainsnak.datavalue.value&lt;br /&gt;
				if v.qualifiers and v.qualifiers[&amp;quot;P1065&amp;quot;] then&lt;br /&gt;
					 -- just take the first archive url (P1065)&lt;br /&gt;
					local au = v.qualifiers[&amp;quot;P1065&amp;quot;][1]&lt;br /&gt;
					if au.snaktype == &amp;quot;value&amp;quot; then&lt;br /&gt;
						quals[#urls] = au.datavalue.value&lt;br /&gt;
					end -- test for archive url having a value&lt;br /&gt;
				end -- test for qualifers&lt;br /&gt;
			end -- test for website having a value&lt;br /&gt;
		end -- loop through website(s)&lt;br /&gt;
	else&lt;br /&gt;
		urls[1] = url&lt;br /&gt;
	end&lt;br /&gt;
	if #urls == 0 then return nil end&lt;br /&gt;
&lt;br /&gt;
	local out = {}&lt;br /&gt;
	for i, u in ipairs(urls) do&lt;br /&gt;
		local link = quals[i] or u&lt;br /&gt;
		local prot, addr = u:match(&amp;quot;(http[s]*://)(.+)&amp;quot;)&lt;br /&gt;
		addr = addr or u&lt;br /&gt;
		local disp, n = addr:gsub(&amp;quot;%.&amp;quot;, &amp;quot;&amp;lt;wbr/&amp;gt;%.&amp;quot;)&lt;br /&gt;
		out[#out+1] = &#039;&amp;lt;span class=&amp;quot;url&amp;quot;&amp;gt;[&#039; .. link .. &amp;quot; &amp;quot; .. disp .. &amp;quot;]&amp;lt;/span&amp;gt;&amp;quot;&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	local langcode = findLang(frame.args.lang).code&lt;br /&gt;
	local noicon = parseParam(frame.args.noicon, false)&lt;br /&gt;
	if url == &amp;quot;&amp;quot; and not noicon then&lt;br /&gt;
		out[#out] = out[#out] .. createicon(langcode, qid, &amp;quot;P856&amp;quot;)&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	local ret = &amp;quot;&amp;quot;&lt;br /&gt;
	if #out &amp;gt; 1 then&lt;br /&gt;
		ret = mw.getCurrentFrame():expandTemplate{title = &amp;quot;ubl&amp;quot;, args = out}&lt;br /&gt;
	else&lt;br /&gt;
		ret = out[1]&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	return ret&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- getAllLabels fetches the set of labels and formats it for display as wikitext.&lt;br /&gt;
-- It takes a parameter &#039;qid&#039; for arbitrary access, otherwise it uses the current page.&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- Dependencies: none&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
p.getAllLabels = function(frame)&lt;br /&gt;
	local args = frame.args or frame:getParent().args or {}&lt;br /&gt;
&lt;br /&gt;
	local qid = args.qid&lt;br /&gt;
	if qid == &amp;quot;&amp;quot; then qid = nil end&lt;br /&gt;
&lt;br /&gt;
	local entity = mw.wikibase.getEntity(qid)&lt;br /&gt;
	if not entity then return i18n[&amp;quot;entity-not-found&amp;quot;] end&lt;br /&gt;
&lt;br /&gt;
	local labels = entity.labels&lt;br /&gt;
	if not labels then return i18n[&amp;quot;labels-not-found&amp;quot;] end&lt;br /&gt;
&lt;br /&gt;
	out = {}&lt;br /&gt;
	for k, v in pairs(labels) do&lt;br /&gt;
		out[#out+1] = v.value .. &amp;quot; (&amp;quot; .. v.language .. &amp;quot;)&amp;quot;&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	return table.concat(out, &amp;quot;; &amp;quot;)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- getAllDescriptions fetches the set of descriptions and formats it for display as wikitext.&lt;br /&gt;
-- It takes a parameter &#039;qid&#039; for arbitrary access, otherwise it uses the current page.&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- Dependencies: none&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
p.getAllDescriptions = function(frame)&lt;br /&gt;
	local args = frame.args or frame:getParent().args or {}&lt;br /&gt;
&lt;br /&gt;
	local qid = args.qid&lt;br /&gt;
	if qid == &amp;quot;&amp;quot; then qid = nil end&lt;br /&gt;
&lt;br /&gt;
	local entity = mw.wikibase.getEntity(qid)&lt;br /&gt;
	if not entity then return i18n[&amp;quot;entity-not-found&amp;quot;] end&lt;br /&gt;
&lt;br /&gt;
	local descriptions = entity.descriptions&lt;br /&gt;
	if not descriptions then return i18n[&amp;quot;descriptions-not-found&amp;quot;] end&lt;br /&gt;
&lt;br /&gt;
	out = {}&lt;br /&gt;
	for k, v in pairs(descriptions) do&lt;br /&gt;
		out[#out+1] = v.value .. &amp;quot; (&amp;quot; .. v.language .. &amp;quot;)&amp;quot;&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	return table.concat(out, &amp;quot;; &amp;quot;)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- getAllAliases fetches the set of descriptions and formats it for display as wikitext.&lt;br /&gt;
-- It takes a parameter &#039;qid&#039; for arbitrary access, otherwise it uses the current page.&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- Dependencies: none&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
p.getAllAliases = function(frame)&lt;br /&gt;
	local args = frame.args or frame:getParent().args or {}&lt;br /&gt;
&lt;br /&gt;
	local qid = args.qid&lt;br /&gt;
	if qid == &amp;quot;&amp;quot; then qid = nil end&lt;br /&gt;
&lt;br /&gt;
	local entity = mw.wikibase.getEntity(qid)&lt;br /&gt;
	if not entity then return i18n[&amp;quot;entity-not-found&amp;quot;] end&lt;br /&gt;
&lt;br /&gt;
	local aliases = entity.aliases&lt;br /&gt;
	if not aliases then return i18n[&amp;quot;aliases-not-found&amp;quot;] end&lt;br /&gt;
&lt;br /&gt;
	out = {}&lt;br /&gt;
	for k1, v1 in pairs(aliases) do&lt;br /&gt;
		local lang = v1[1].language&lt;br /&gt;
		local val = {}&lt;br /&gt;
		for k1, v2 in ipairs(v1) do&lt;br /&gt;
			val[#val+1] = v2.value&lt;br /&gt;
		end&lt;br /&gt;
		out[#out+1] = table.concat(val, &amp;quot;, &amp;quot;) .. &amp;quot; (&amp;quot; .. lang .. &amp;quot;)&amp;quot;&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	return table.concat(out, &amp;quot;; &amp;quot;)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
return p&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- List of exported functions&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
-- getValue&lt;br /&gt;
-- getPreferredValue&lt;br /&gt;
-- getCoords&lt;br /&gt;
-- getQualifierValue&lt;br /&gt;
-- getValueByQual&lt;br /&gt;
-- getValueByLang&lt;br /&gt;
-- getLink&lt;br /&gt;
-- getLabel&lt;br /&gt;
-- getAT&lt;br /&gt;
-- getDescription&lt;br /&gt;
-- pageId&lt;br /&gt;
-- formatDate&lt;br /&gt;
-- location&lt;br /&gt;
-- checkBlacklist&lt;br /&gt;
-- emptyor&lt;br /&gt;
-- labelorid&lt;br /&gt;
-- getLang&lt;br /&gt;
-- findLanguage&lt;br /&gt;
-- getQID&lt;br /&gt;
-- followQid&lt;br /&gt;
-- siteID&lt;br /&gt;
-- projID&lt;br /&gt;
-- formatNumber&lt;br /&gt;
-- examine&lt;br /&gt;
-- checkvalue&lt;br /&gt;
-- url2&lt;br /&gt;
-- getWebsite&lt;br /&gt;
-------------------------------------------------------------------------------&lt;/div&gt;</summary>
		<author><name>Aron.hives@edubase.net</name></author>
	</entry>
	<entry>
		<id>https://edubase.wiki/index.php?title=Module:WikidataIB/doc&amp;diff=27360</id>
		<title>Module:WikidataIB/doc</title>
		<link rel="alternate" type="text/html" href="https://edubase.wiki/index.php?title=Module:WikidataIB/doc&amp;diff=27360"/>
		<updated>2018-11-12T22:47:35Z</updated>

		<summary type="html">&lt;p&gt;Aron.hives@edubase.net: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;{{Module rating |release}}&lt;br /&gt;
&lt;br /&gt;
This module is designed specifically to implement a mechanism which moves control of whether Wikidata values are used in an infobox from the template coder at the infobox design level to the editor at the article level. It is only intended to be used inside an infobox.&lt;br /&gt;
&lt;br /&gt;
One of the three sandboxes should be used for testing anything other than trivial amendments.&lt;br /&gt;
&lt;br /&gt;
Test cases for the main module and two of the sandboxes are available.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable plainrowheaders&lt;br /&gt;
|+ Modules and test cases&lt;br /&gt;
|-&lt;br /&gt;
! &lt;br /&gt;
! scope=&amp;quot;col&amp;quot; | Module&lt;br /&gt;
! scope=&amp;quot;col&amp;quot; | Test cases&lt;br /&gt;
|-&lt;br /&gt;
! scope=&amp;quot;row&amp;quot; | Main&lt;br /&gt;
| [[Module:WikidataIB]]&lt;br /&gt;
| [[Module talk:WikidataIB/testing]]&lt;br /&gt;
|-&lt;br /&gt;
! scope=&amp;quot;row&amp;quot; | sandbox&lt;br /&gt;
| [[Module:WikidataIB/sandbox]]&lt;br /&gt;
| [[Module talk:WikidataIB/sandbox/testing]]&lt;br /&gt;
|-&lt;br /&gt;
! scope=&amp;quot;row&amp;quot; | sandbox1&lt;br /&gt;
| [[Module:WikidataIB/sandbox1]]&lt;br /&gt;
| [[Module talk:WikidataIB/sandbox1/testing]]&lt;br /&gt;
|-&lt;br /&gt;
! scope=&amp;quot;row&amp;quot; | sandbox2&lt;br /&gt;
| [[Module:WikidataIB/sandbox2]]&lt;br /&gt;
| &lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== Overview ==&lt;br /&gt;
The module provides these calls specifically for use in infoboxes at present:&lt;br /&gt;
# &amp;lt;code&amp;gt;getValue&amp;lt;/code&amp;gt;&lt;br /&gt;
#: &amp;lt;s&amp;gt;&amp;lt;code&amp;gt;getPreferredValue&amp;lt;/code&amp;gt;&amp;lt;/s&amp;gt; - obsoleted: use &amp;lt;code&amp;gt;getValue|rank=best&amp;lt;/code&amp;gt; instead.&lt;br /&gt;
# &amp;lt;code&amp;gt;getCoords&amp;lt;/code&amp;gt;&lt;br /&gt;
# &amp;lt;code&amp;gt;getQualifierValue&amp;lt;/code&amp;gt;&lt;br /&gt;
# &amp;lt;code&amp;gt;getValueByQual&amp;lt;/code&amp;gt;&lt;br /&gt;
# &amp;lt;code&amp;gt;getValueByLang&amp;lt;/code&amp;gt;&lt;br /&gt;
The obsolete call getSourcedValue has now been removed as it is redundant to getValue which can do the same job using the {{para|onlysourced|true}} parameter (which is set by default).&lt;br /&gt;
&lt;br /&gt;
There are also these utility calls:&lt;br /&gt;
# &amp;lt;code&amp;gt;getLink&amp;lt;/code&amp;gt;&lt;br /&gt;
# &amp;lt;code&amp;gt;getLabel&amp;lt;/code&amp;gt;&lt;br /&gt;
# &amp;lt;code&amp;gt;getAT&amp;lt;/code&amp;gt;&lt;br /&gt;
# &amp;lt;code&amp;gt;getDescription&amp;lt;/code&amp;gt;&lt;br /&gt;
# &amp;lt;code&amp;gt;pageId&amp;lt;/code&amp;gt;&lt;br /&gt;
# &amp;lt;code&amp;gt;formatDate&amp;lt;/code&amp;gt;&lt;br /&gt;
# &amp;lt;code&amp;gt;checkBlacklist&amp;lt;/code&amp;gt;&lt;br /&gt;
# &amp;lt;code&amp;gt;emptyor&amp;lt;/code&amp;gt;&lt;br /&gt;
# &amp;lt;code&amp;gt;labelorid&amp;lt;/code&amp;gt;&lt;br /&gt;
# &amp;lt;code&amp;gt;getLang&amp;lt;/code&amp;gt;&lt;br /&gt;
# &amp;lt;code&amp;gt;getQid&amp;lt;/code&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Example form of each call:&lt;br /&gt;
 &amp;lt;nowiki&amp;gt;{{#invoke:WikidataIB |getValue |&amp;lt;PropertyID&amp;gt; |name=&amp;lt;fieldname&amp;gt; |suppressfields=&amp;lt;list of fields which will never display&amp;gt; |fetchwikidata=&amp;lt;list of fields to fetch values from Wikidata&amp;gt; |onlysourced=&amp;lt;yes/no&amp;gt; |noicon=&amp;lt;yes/no&amp;gt; |df=&amp;lt;dmy/mdy/y&amp;gt; |bc=&amp;lt;BC/BCE&amp;gt; |qual=&amp;lt;ALL/DATES/P999&amp;gt; |list=&amp;lt;ubl/hlist/prose&amp;gt; |linked=&amp;lt;yes/no&amp;gt; |&amp;lt;local parameter&amp;gt;}}&amp;lt;/nowiki&amp;gt;&lt;br /&gt;
&lt;br /&gt;
 &amp;lt;nowiki&amp;gt;{{#invoke:WikidataIB |getCoords |name=&amp;lt;fieldname&amp;gt; |suppressfields=&amp;lt;list of fields which will never display&amp;gt; |fetchwikidata=&amp;lt;list of fields to fetch values from Wikidata&amp;gt; |&amp;lt;local parameter&amp;gt;}}&amp;lt;/nowiki&amp;gt;&lt;br /&gt;
&lt;br /&gt;
 &amp;lt;nowiki&amp;gt;{{#invoke:WikidataIB |getQualifierValue |&amp;lt;PropertyID&amp;gt; |pval=&amp;lt;ID of target value for the property&amp;gt; |qual=&amp;lt;qualifier ID for that target value&amp;gt; |name=&amp;lt;fieldname&amp;gt; |suppressfields=&amp;lt;list of fields which will never display&amp;gt; |fetchwikidata=&amp;lt;list of fields to fetch values from Wikidata&amp;gt; |onlysourced=&amp;lt;yes/no&amp;gt;}}&amp;lt;/nowiki&amp;gt;&lt;br /&gt;
&lt;br /&gt;
 &amp;lt;nowiki&amp;gt;{{#invoke:WikidataIB |getValueByQual |&amp;lt;PropertyID&amp;gt; |qualID=&amp;lt;qualifier property ID to match&amp;gt; |qvalue=&amp;lt;QID of target value for the qualifier property&amp;gt; |name=&amp;lt;fieldname&amp;gt; |suppressfields=&amp;lt;list of fields which will never display&amp;gt; |fetchwikidata=&amp;lt;list of fields to fetch values from Wikidata&amp;gt; |onlysourced=&amp;lt;yes/no&amp;gt;}}&amp;lt;/nowiki&amp;gt;&lt;br /&gt;
&lt;br /&gt;
 &amp;lt;nowiki&amp;gt;{{#invoke:WikidataIB |getValueByLang |&amp;lt;PropertyID&amp;gt; |lang=&amp;lt;language code to match&amp;gt; |name=&amp;lt;fieldname&amp;gt; |suppressfields=&amp;lt;list of fields which will never display&amp;gt; |fetchwikidata=&amp;lt;list of fields to fetch values from Wikidata&amp;gt; |onlysourced=&amp;lt;yes/no&amp;gt;}}&amp;lt;/nowiki&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== Function getValue ==&lt;br /&gt;
=== Parameters to getValue ===&lt;br /&gt;
{| class =&amp;quot;wikitable&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! scope=&amp;quot;col&amp;quot; | Name&lt;br /&gt;
! scope=&amp;quot;col&amp;quot; | Alias&lt;br /&gt;
! scope=&amp;quot;col&amp;quot; | Function&lt;br /&gt;
! scope=&amp;quot;col&amp;quot; | Default&lt;br /&gt;
|-&lt;br /&gt;
| (first unnamed)&lt;br /&gt;
| 1&lt;br /&gt;
| The property-ID whose values are returned. Required.&lt;br /&gt;
| &lt;br /&gt;
|-&lt;br /&gt;
|-&lt;br /&gt;
| (second unnamed)&lt;br /&gt;
| 2&lt;br /&gt;
| A locally supplied value that, if it is not empty, will be returned in preference to the value on Wikidata.&lt;br /&gt;
| empty&lt;br /&gt;
|-&lt;br /&gt;
| qid&lt;br /&gt;
| &lt;br /&gt;
| The Q-number (entity-ID) of the entity that the property belongs to. If not supplied or empty, defaults to the associated Wikidata entry of the current page – uses [[:mw:Extension:Wikibase Client/Lua #mw.wikibase.getEntityIdForCurrentPage|mw.wikibase.getEntityIdForCurrentPage()]].&lt;br /&gt;
| Item id for current page&lt;br /&gt;
|-&lt;br /&gt;
| rank&lt;br /&gt;
|&lt;br /&gt;
| [Case insensitive] When set to &amp;lt;code&amp;gt;best&amp;lt;/code&amp;gt;, returns preferred values if present, otherwise returns normal values. When set to &amp;lt;code&amp;gt;preferred&amp;lt;/code&amp;gt; returns preferred values. When set to &amp;lt;code&amp;gt;normal&amp;lt;/code&amp;gt;, returns normal values. When set to &amp;lt;code&amp;gt;deprecated&amp;lt;/code&amp;gt; returns deprecated values. Any parameter value beginning with &amp;quot;b&amp;quot; is &amp;quot;best&amp;quot;; beginning with &amp;quot;p&amp;quot; is &amp;quot;preferred&amp;quot;; beginning with &amp;quot;n&amp;quot; is &amp;quot;normal&amp;quot;; beginning with &amp;quot;d&amp;quot; is deprecated. Multiple values are allowed: &amp;quot;p n d&amp;quot; would return all ranks. &amp;quot;Best&amp;quot; overrides the other flags. Other values are ignored and if no ranks are requested, preferred and normal are returned.&lt;br /&gt;
| preferred and normal&lt;br /&gt;
|-&lt;br /&gt;
| qual&lt;br /&gt;
| &lt;br /&gt;
| The property-ID of a qualifier that is to be returned in parentheses after the property. Setting &amp;lt;code&amp;gt;qual=ALL&amp;lt;/code&amp;gt; returns all qualifiers. Setting &amp;lt;code&amp;gt;qual=DATES&amp;lt;/code&amp;gt; returns {{q|P580}} and {{q|P582}} with a date separator.&lt;br /&gt;
| none&lt;br /&gt;
|-&lt;br /&gt;
| fetchwikidata&lt;br /&gt;
| fwd&lt;br /&gt;
| List of fields to fetch values from. &amp;lt;code&amp;gt;ALL&amp;lt;/code&amp;gt; fetches all fields. A value of &amp;lt;code&amp;gt;NONE&amp;lt;/code&amp;gt; or blank or omitting the parameter fetches no fields.&lt;br /&gt;
| none&lt;br /&gt;
|-&lt;br /&gt;
| suppressfields&lt;br /&gt;
| spf&lt;br /&gt;
| List of fields which will never display. This will even force a local value in the field not to display.&lt;br /&gt;
| none&lt;br /&gt;
|-&lt;br /&gt;
| name&lt;br /&gt;
| &lt;br /&gt;
| Name of the field. When encoding an infobox, this is the name that fetchwikidata and suppressfields will recognise. Required if fetchwikidata or suppressfields is specified (except when &amp;lt;code&amp;gt;fetchwikidata=ALL&amp;lt;/code&amp;gt;).&lt;br /&gt;
| nil&lt;br /&gt;
|-&lt;br /&gt;
| onlysourced&lt;br /&gt;
| osd&lt;br /&gt;
| A boolean which will filter out Wikidata values that are unsourced or only sourced to Wikipedia. Values &amp;lt;code&amp;gt;no&amp;lt;/code&amp;gt;, &amp;lt;code&amp;gt;false&amp;lt;/code&amp;gt; and &amp;lt;code&amp;gt;0&amp;lt;/code&amp;gt; are all false; anything else is true.&lt;br /&gt;
| true&lt;br /&gt;
|-&lt;br /&gt;
| df&lt;br /&gt;
| &lt;br /&gt;
| Date format: may be &amp;lt;code&amp;gt;dmy&amp;lt;/code&amp;gt; (day before month) or &amp;lt;code&amp;gt;mdy&amp;lt;/code&amp;gt; (month before day) or &amp;lt;code&amp;gt;y&amp;lt;/code&amp;gt; (year alone).&lt;br /&gt;
| dmy&lt;br /&gt;
|-&lt;br /&gt;
| bc&lt;br /&gt;
| &lt;br /&gt;
| Format of the BC/BCE suffix for dates.&lt;br /&gt;
| BCE&lt;br /&gt;
|-&lt;br /&gt;
| linked&lt;br /&gt;
| &lt;br /&gt;
| A boolean that enables the link to a local page via its sitelink on Wikidata. Values &amp;lt;code&amp;gt;no&amp;lt;/code&amp;gt;, &amp;lt;code&amp;gt;false&amp;lt;/code&amp;gt; and &amp;lt;code&amp;gt;0&amp;lt;/code&amp;gt; are all false; anything else is true.&lt;br /&gt;
| true&lt;br /&gt;
|-&lt;br /&gt;
| wdlinks&lt;br /&gt;
| wdl&lt;br /&gt;
| A boolean that enables the display of links to Wikidata when no local article exists. Values &amp;lt;code&amp;gt;no&amp;lt;/code&amp;gt;, &amp;lt;code&amp;gt;false&amp;lt;/code&amp;gt; and &amp;lt;code&amp;gt;0&amp;lt;/code&amp;gt; are all false; anything else is true.&lt;br /&gt;
| false&lt;br /&gt;
|-&lt;br /&gt;
| unitabbr&lt;br /&gt;
| &lt;br /&gt;
| A boolean that enables unit abbreviations for common units. Values &amp;lt;code&amp;gt;no&amp;lt;/code&amp;gt;, &amp;lt;code&amp;gt;false&amp;lt;/code&amp;gt; and &amp;lt;code&amp;gt;0&amp;lt;/code&amp;gt; are all false; anything else is true.&lt;br /&gt;
| false&lt;br /&gt;
|-&lt;br /&gt;
| maxvals&lt;br /&gt;
| &lt;br /&gt;
| Sets the maximum number of values to be returned when multiple values are available. Setting it to 1 is useful where the returned string is used within another call, e.g. image. Values &amp;lt;code&amp;gt;0&amp;lt;/code&amp;gt; and empty return all values.&lt;br /&gt;
| 0 (all)&lt;br /&gt;
|-&lt;br /&gt;
| collapse&lt;br /&gt;
| &lt;br /&gt;
| Sets the maximum number of values to be returned before the content is auto-collapsed. Values &amp;lt;code&amp;gt;0&amp;lt;/code&amp;gt; and empty allow all content to be displayed uncollapsed.&lt;br /&gt;
| 0 (all)&lt;br /&gt;
|-&lt;br /&gt;
| linkprefix&lt;br /&gt;
| &lt;br /&gt;
| A link prefix that is prepended to the linked value when linked. Applies only to items that have articles and to strings (e.g. url). It triggers linking of strings. Any double-quotes &amp;quot; are stripped out, so that spaces may be passed.&lt;br /&gt;
| empty&lt;br /&gt;
|-&lt;br /&gt;
| linkpostfix&lt;br /&gt;
| &lt;br /&gt;
| A link postfix that is appended to the linked value when linked. Applies only to items that have articles and to strings (e.g. url). It triggers linking of strings. Any double-quotes &amp;quot; are stripped out, so that spaces may be passed.&lt;br /&gt;
| empty&lt;br /&gt;
|-&lt;br /&gt;
| prefix&lt;br /&gt;
| &lt;br /&gt;
| A prefix that is prepended to the displayed value of strings (e.g. url). Any double-quotes &amp;quot; are stripped out, so that spaces may be passed.&lt;br /&gt;
| empty&lt;br /&gt;
|-&lt;br /&gt;
| postfix&lt;br /&gt;
| &lt;br /&gt;
| A postfix that is appended to the displayed value of strings (e.g. url). Any double-quotes &amp;quot; are stripped out, so that spaces may be passed.&lt;br /&gt;
| empty&lt;br /&gt;
|-&lt;br /&gt;
| qlinkprefix&lt;br /&gt;
| &lt;br /&gt;
| Qualifier link prefix (see linkprefix).&lt;br /&gt;
| empty&lt;br /&gt;
|-&lt;br /&gt;
| qlinkpostfix&lt;br /&gt;
| &lt;br /&gt;
| Qualifier link postfix (see linkpostfix).&lt;br /&gt;
| empty&lt;br /&gt;
|-&lt;br /&gt;
| qprefix&lt;br /&gt;
| &lt;br /&gt;
| Qualifier prefix (see prefix).&lt;br /&gt;
| empty&lt;br /&gt;
|-&lt;br /&gt;
| qpostfix&lt;br /&gt;
| &lt;br /&gt;
| Qualifier postfix (see postfix).&lt;br /&gt;
| empty&lt;br /&gt;
|-&lt;br /&gt;
| sorted&lt;br /&gt;
| &lt;br /&gt;
| A boolean which enables sorting of the values returned. Values &amp;lt;code&amp;gt;no&amp;lt;/code&amp;gt;, &amp;lt;code&amp;gt;false&amp;lt;/code&amp;gt; and &amp;lt;code&amp;gt;0&amp;lt;/code&amp;gt; are all false; anything else is true.&lt;br /&gt;
| false&lt;br /&gt;
|-&lt;br /&gt;
| qsorted&lt;br /&gt;
| &lt;br /&gt;
| A boolean which enables sorting of the qualifier values within each item returned. Values &amp;lt;code&amp;gt;no&amp;lt;/code&amp;gt;, &amp;lt;code&amp;gt;false&amp;lt;/code&amp;gt; and &amp;lt;code&amp;gt;0&amp;lt;/code&amp;gt; are all false; anything else is true.&lt;br /&gt;
| false&lt;br /&gt;
|-&lt;br /&gt;
| noicon&lt;br /&gt;
| &lt;br /&gt;
| A boolean which will suppress the trailing &amp;quot;edit at Wikidata&amp;quot; pen-icon. Useful for when the returned value is to be further processed. Values &amp;lt;code&amp;gt;no&amp;lt;/code&amp;gt;, &amp;lt;code&amp;gt;false&amp;lt;/code&amp;gt; and &amp;lt;code&amp;gt;0&amp;lt;/code&amp;gt; are all false; anything else is true.&lt;br /&gt;
| false&lt;br /&gt;
|-&lt;br /&gt;
| list&lt;br /&gt;
| &lt;br /&gt;
| The name of a template that the list of multiple values is then passed through. Examples include &amp;quot;hlist&amp;quot; and &amp;quot;ubl&amp;quot;. Setting it to &amp;quot;prose&amp;quot; produces something like &amp;quot;1, 2, 3, and 4&amp;quot;&lt;br /&gt;
| none&lt;br /&gt;
|-&lt;br /&gt;
| sep&lt;br /&gt;
| &lt;br /&gt;
| Customises the string that is used to separate multiple returned values. Any double-quotes &amp;quot; are stripped out, so that spaces may be passed. If nothing or an empty string is passed it is set to the default list separator (&amp;quot;, &amp;quot; in English).&lt;br /&gt;
| &amp;quot;, &amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
| qsep&lt;br /&gt;
| &lt;br /&gt;
| Customises the string that is used to separate multiple returned qualifier values. Any double-quotes &amp;quot; are stripped out, so that spaces may be passed. If nothing or an empty string is passed it is set to the default list separator (&amp;quot;, &amp;quot; in English).&lt;br /&gt;
| &amp;quot;, &amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
| format&lt;br /&gt;
| &lt;br /&gt;
| Determines whether global coordinates should be rendered as degree/minute/second or as decimal degrees. Any value beginning &amp;quot;dec&amp;quot; (case insensitive) will render as decimal. Anything else will render as DMS.&lt;br /&gt;
| dms&lt;br /&gt;
|-&lt;br /&gt;
| show&lt;br /&gt;
| &lt;br /&gt;
| Determines how global coordinates should be returned. The value &amp;quot;longlat&amp;quot; will return &amp;lt;code&amp;gt;longitude, latitude&amp;lt;/code&amp;gt;. Any other value beginning &amp;quot;lon&amp;quot; (case insensitive) will return just longitude. Any value beginning &amp;quot;lat&amp;quot; (case insensitive) will return just latitude. When used with {{para|noicon|true}}, all of these will be pure numbers in decimal degrees (signed: N and E as positive), which are intended for use in mapping templates, etc. Anything other value (or nothing) will render the usual coordinate values as DMS or decimal with &amp;quot;NSEW&amp;quot; qualifiers, etc.&lt;br /&gt;
| empty&lt;br /&gt;
|-&lt;br /&gt;
| lang&lt;br /&gt;
| &lt;br /&gt;
| Allows an unlinked value to be returned in the chosen language. Takes a standard ISO language code recognised by MediaWiki. If not supplied or blank, the local language (or set language for multi-lingual wikis) is used as normal.&lt;br /&gt;
| local language&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== Base parameters ===&lt;br /&gt;
* getValue can also take a named parameter {{para|qid}} which is the Wikidata ID for an article. This will not normally be used as omitting it defaults to the current article.&lt;br /&gt;
* The property whose value is to be returned is passed in the first unnamed property and is required.&lt;br /&gt;
* The second unnamed parameter, if supplied, will become the returned value and no call to Wikidata will be made.&lt;br /&gt;
&lt;br /&gt;
=== Whitelist and blacklist ===&lt;br /&gt;
* The name of the field that this function is called from is passed in the named parameter {{para|name}}, which is first checked against a blacklist of fields that are never to be displayed, (i.e. the call must return nil in all circumstances). If the field is not on the blacklist, it is then checked against a whitelist. If the name of the field matches, the call will return any locally supplied value if it is supplied as the second unnamed parameter, or the Wikidata value otherwise.&lt;br /&gt;
* The name is compulsory when the blacklist or whitelist is used, so the module returns nil if it is not supplied, other than when {{para|fetchwikidata|ALL}}.&lt;br /&gt;
* The blacklist is passed in the named parameter {{para|suppressfields}}&lt;br /&gt;
* The whitelist is passed in the named parameter {{para|fetchwikidata}}&lt;br /&gt;
&lt;br /&gt;
=== Sourcing ===&lt;br /&gt;
The getValue function will accept a boolean parameter &amp;lt;code&amp;gt;onlysourced&amp;lt;/code&amp;gt; which will suppress return of Wikidata values that are unsourced or only sourced to Wikipedia. The absence of the parameter, an empty parameter ({{para|onlysourced}}) and the empty string (&amp;lt;code&amp;gt;&amp;quot;&amp;quot;&amp;lt;/code&amp;gt;) all default to true (i.e. only referenced values are returned). The values &amp;lt;code&amp;gt;no&amp;lt;/code&amp;gt;, &amp;lt;code&amp;gt;false&amp;lt;/code&amp;gt; and &amp;lt;code&amp;gt;0&amp;lt;/code&amp;gt; are treated as false (i.e. all values are returned); any other value is true (although {{para|onlysourced|yes/no}} is recommended for readability).&lt;br /&gt;
&lt;br /&gt;
=== Link to Wikidata ===&lt;br /&gt;
The getValue function will accept a boolean parameter &amp;lt;code&amp;gt;noicon&amp;lt;/code&amp;gt; which will suppress the trailing &amp;quot;edit at Wikidata&amp;quot; icon and link for cases when the returned value is to be further processed by the infobox (e.g. a url). The absence of the parameter or an empty parameter ({{para|noicon}}) default to false (i.e. the icon is added). The empty string (&amp;lt;code&amp;gt;&amp;quot;&amp;quot;&amp;lt;/code&amp;gt;) and the values &amp;lt;code&amp;gt;no&amp;lt;/code&amp;gt;, &amp;lt;code&amp;gt;false&amp;lt;/code&amp;gt; and &amp;lt;code&amp;gt;0&amp;lt;/code&amp;gt; are treated as false; any other value is true (although {{para|noicon|true}} is recommended for readability).&lt;br /&gt;
&lt;br /&gt;
=== Dates ===&lt;br /&gt;
In order to handle the requirement for dates in mdy, dmy or just year formats, getValue accepts a named parameter {{para|df}} that may take the values &amp;quot;dmy&amp;quot;, &amp;quot;mdy&amp;quot;, or &amp;quot;y&amp;quot; - default is &amp;quot;dmy&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
As an article may require either of suffixes BC and BCE, getValue accepts a named parameter {{para|bc}} that may take the values &amp;quot;BC&amp;quot;, or &amp;quot;BCE&amp;quot; - default is &amp;quot;BCE&amp;quot;. Some test cases are shown at [[Module talk:WikidataIB/testing #Calls to getValue for dates]].&lt;br /&gt;
&lt;br /&gt;
=== Ranks ===&lt;br /&gt;
The {{para|rank}} parameter, when set to preferred, returns only preferred values; when set to normal, returns only normal values; when set to deprecated, returns only deprecated values. If the parameter is set to best, it returns preferred values if present, otherwise normal values. Any parameter value beginning with &amp;quot;p&amp;quot; is &amp;quot;preferred&amp;quot;; any parameter value beginning with &amp;quot;n&amp;quot; is &amp;quot;normal&amp;quot;; any parameter value beginning with &amp;quot;d&amp;quot; is &amp;quot;deprecated&amp;quot;; any parameter value beginning with &amp;quot;b&amp;quot; is &amp;quot;best&amp;quot;. Combinations of values are allowed, e.g. {{para|rank|p n}} returns all the preferred and normal values (which is the default), although &amp;quot;best&amp;quot; overrides any other parameters.&lt;br /&gt;
&lt;br /&gt;
==== Specific value-type handlers ====&lt;br /&gt;
The module has specific handlers for the following data types:&lt;br /&gt;
# Items that correspond to an article in some Wikipedia, called &amp;quot;wikibase-items&amp;quot;. These will be linked to the corresponding (and disambiguated) article on English Wikipedia where possible.&lt;br /&gt;
# Items that represent dates. These may be centuries, years, years and months, or years, months and days.&lt;br /&gt;
# Items that represent Commons media, urls, external ids, or other sorts of plain text.&lt;br /&gt;
# Items that represent quantities. All of these may have an associated unit, or be dimensionless, and may have a range.&lt;br /&gt;
# Items that represent global coordinates. These will be in degrees of latitude and longitude and will have an associated precision.&lt;br /&gt;
Items that represent other types of data are not handled at present.&lt;br /&gt;
&lt;br /&gt;
The third class of data types may be used with the parameters:&lt;br /&gt;
* {{para|prefix}}, {{para|postfix}}, {{para|linkprefix}}, {{para|linkpostfix}}&lt;br /&gt;
If you don&#039;t supply at least one of {{para|linkprefix}} or {{para|linkpostfix}}, then just {{para|prefix}} and {{para|postfix}} are used. For example, when getting the {{Q|P717}} in {{Q|Q532127|}}:&lt;br /&gt;
* &amp;lt;code&amp;gt;&amp;lt;nowiki&amp;gt;{{#invoke:WikidataIB/sandbox|getValue|P717|fetchwikidata=ALL|onlysourced=no |prefix=&amp;quot;before &amp;quot; |postfix=&amp;quot; after&amp;quot; |qid=Q532127}}&amp;lt;/nowiki&amp;gt;&amp;lt;/code&amp;gt; → {{#invoke:WikidataIB/sandbox |getValue |P717 |fetchwikidata=ALL|onlysourced=no |prefix=&amp;quot;before &amp;quot; |postfix=&amp;quot; after&amp;quot; |qid=Q532127}}&lt;br /&gt;
Use double-quotes to enclose the parameter value if it has leading or trailing spaces (otherwise they are stripped out). If you supply {{para|linkprefix}} or {{para|linkpostfix}}, then all four parameters are used and a link is made for each value like this:&lt;br /&gt;
* &amp;lt;code&amp;gt;&amp;lt;nowiki&amp;gt;[[ linkprefix WikidataValue1 linkpostfix | prefix WikidataValue1 postfix]], [[ linkprefix WikidataValue2 linkpostfix | prefix WikidataValue2 postfix]], etc.&amp;lt;/nowiki&amp;gt;&amp;lt;/code&amp;gt;&lt;br /&gt;
That allows multiple links to be made to different sections of a list article, such as [[List of observatory codes]]. For example, when getting the {{Q|P717}} in {{Q|Q532127|}} we can make the links:&lt;br /&gt;
*&amp;lt;code&amp;gt;&amp;lt;nowiki&amp;gt;{{#invoke:WikidataIB/sandbox|getValue|P717|fetchwikidata=ALL|onlysourced=no |prefix= |postfix= |linkprefix=&amp;quot;List of observatory codes#&amp;quot; |linkpostfix= |qid=Q532127}}&amp;lt;/nowiki&amp;gt;&amp;lt;/code&amp;gt; → {{#invoke:WikidataIB/sandbox|getValue|P717|fetchwikidata=ALL|onlysourced=no |prefix= |postfix= |linkprefix=&amp;quot;List of observatory codes#&amp;quot; |linkpostfix= |qid=Q532127}}&lt;br /&gt;
&lt;br /&gt;
The parameters {{para|prefix}}, {{para|postfix}}, {{para|linkprefix}}, {{para|linkpostfix}} are also applied to wikibase-items if they are linked.&lt;br /&gt;
&lt;br /&gt;
==== Formatting multiple returned values ====&lt;br /&gt;
* {{para|sorted|&amp;lt;yes{{!}}no&amp;gt;}} is a boolean passed to enable sorting of the values returned. No parameter, or an empty string, or &amp;quot;false&amp;quot;, or &amp;quot;no&amp;quot;, or &amp;quot;0&amp;quot; disables sorting. It&#039;s only a very dumb alphabetical sort and sorts linked values as &amp;quot;[[ ...&amp;quot;&lt;br /&gt;
* {{para|sep|&amp;lt;separator characters&amp;gt;}} allows the separator between multiple returned values to be defined. The default is &amp;lt;code&amp;gt;&amp;quot;, &amp;quot;&amp;lt;/code&amp;gt; (comma plus normal space). If the separator has leading or trailing spaces, enclose it in double quotes (e.g. {{para|sep|&amp;quot; - &amp;quot;}}). Any double quotes are stripped from the separator. The pipe character (&amp;lt;code&amp;gt;|&amp;lt;/code&amp;gt;) must be escaped as &amp;lt;code&amp;gt;&amp;lt;nowiki&amp;gt;{{!}}&amp;lt;/nowiki&amp;gt;&amp;lt;/code&amp;gt;. For reasons of accessibility (see [[MOS:PLIST]]), do not use {{para|sep|&amp;amp;lt;br&amp;gt;}} for vertical unbulleted lists; use {{para|list|ubl}} instead.&lt;br /&gt;
* {{para|list|&amp;lt;hlist{{!}}ubl&amp;gt;}} allows multiple returned values to be displayed as a horizontal list ({{para|list|hlist}}), or a vertical unbulleted list ({{para|list|ubl}}). These override the separator and do not display the &#039;pen icon&#039; linked to &amp;quot;Edit at Wikidata&amp;quot;&lt;br /&gt;
&lt;br /&gt;
=== Limiting the returned values ===&lt;br /&gt;
Sometimes a property is expected to have a single value, such as {{q|P18}}, but may have multiple values on Wikidata. Setting {{para|maxvals|1}} will limit the number of values returned to 1. Any other value is possible and functions as expected, but zero is treated as &amp;quot;no limit&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
=== Unlinking ===&lt;br /&gt;
A returned value that represents an article on the local wiki will be linked by default. This includes redirects, but not dab pages. Sometimes there is a need not to link that returned values and this may be accomplished by setting {{para|linked|no}}.&lt;br /&gt;
&lt;br /&gt;
=== Unit abbreviations ===&lt;br /&gt;
When the returned value is a quantity, the name of the units in which it is expressed is appended. Infoboxes may wish to use abbreviations instead for common units. This can be done by setting {{para|unitabbr|true}}.&lt;br /&gt;
&lt;br /&gt;
=== Qualifiers ===&lt;br /&gt;
A parameter {{para|qual}} may be supplied, which will return qualifiers of the required property, if they exist. If the value is set to a property id (P12345), then only the values of qualifiers with that property will be returned. If the value is set to {{para|qual|ALL}}, then all of the qualifier values are returned. If the value is set to {{para|qual|DATES}} then the {{q|P580}} and the {{q|P582}} of the property are returned with a date separator. In each case, any qualifier values returned follow the property value, and are enclosed in parentheses. If multiple qualifier values are returned, they will be separated by commas by default, although the separator can be changed by specifying {{para|qsep}} (which may be enclosed in double-quotes, which are stripped out, so that spaces can be included). Setting the parameter {{para|qsorted|yes}} will sort the returned qualifier values alphanumerically.&lt;br /&gt;
&lt;br /&gt;
=== Short form of parameters ===&lt;br /&gt;
Some of the longer parameters may be abbreviated to make infobox designs more compact:&lt;br /&gt;
* &amp;lt;code&amp;gt;fwd → fetchwikidata&amp;lt;/code&amp;gt;&lt;br /&gt;
* &amp;lt;code&amp;gt;osd → onlysourced&amp;lt;/code&amp;gt;&lt;br /&gt;
* &amp;lt;code&amp;gt;spf → suppressfields&amp;lt;/code&amp;gt;&lt;br /&gt;
* &amp;lt;code&amp;gt;wdl → wdlinks&amp;lt;/code&amp;gt;&lt;br /&gt;
&lt;br /&gt;
=== Wrapper template ===&lt;br /&gt;
The template {{tl|wdib}} can be used as a convenient wrapper for &amp;lt;code&amp;gt;&amp;lt;nowiki&amp;gt;{{#invoke:WikidataIB |getValue}}&amp;lt;/nowiki&amp;gt;&amp;lt;/code&amp;gt;.&lt;br /&gt;
&lt;br /&gt;
== Other main functions ==&lt;br /&gt;
=== Function getPreferredValue ===&lt;br /&gt;
The getPreferredValue function works exactly like getValue, taking the same parameters, but if any values for a property have the preferred rank set, it will only return those values. This is now deprecated in favour of &amp;lt;code&amp;gt;getValue|rank=best&amp;lt;/code&amp;gt;.&lt;br /&gt;
&lt;br /&gt;
=== Function getCoords ===&lt;br /&gt;
* getCoords can also take a named parameter {{para|qid}} which is the Wikidata ID for an article. This will not normally be used as omitting it defaults to the current article.&lt;br /&gt;
* The first unnamed parameter, if supplied, will become the returned value and no call to Wikidata will be made.&lt;br /&gt;
* The coordinates from Wikidata are parsed and passed to [[Template:Coord]] which returns the display as if it were called manually.&lt;br /&gt;
* The blacklist of fields that are never to be displayed, and the whitelist are implemented in the same way as for getValue using {{para|suppressfields}} and {{para|fetchwikidata}}&lt;br /&gt;
&lt;br /&gt;
=== Function getQualifierValue ===&lt;br /&gt;
&lt;br /&gt;
The getQualifierValue function is for use when we want to fetch the value of a qualifier. We need to know the property and the value of the property that the qualifier relates to. The parameters are:&lt;br /&gt;
* The property ID passed in the unnamed parameter (or {{para|1}})&lt;br /&gt;
* The target value for that property in {{para|pval}}&lt;br /&gt;
* The qualifier ID for that target value in {{para|qual}}&lt;br /&gt;
* The same parameters to implement whitelisting and blacklisting of the property as in getValue&lt;br /&gt;
* Optional boolean to specify whether only sourced values of the property are returned (defaults to &amp;quot;no&amp;quot;) in {{para|onlysourced}}&lt;br /&gt;
* Optional item ID for arbitrary access in {{para|qid}}&lt;br /&gt;
* The same parameters to format output as in getValue&lt;br /&gt;
&lt;br /&gt;
==== Example of getQualifierValue ====&lt;br /&gt;
In {{Q|Q1513315}} there is a property {{Q|P793}}, which has a value {{Q|Q385378}}. That has two qualifiers, {{Q|P580}} and {{Q|P582}}. To get the start date:&lt;br /&gt;
* &amp;lt;code&amp;gt;&amp;lt;nowiki&amp;gt;{{#invoke:WikidataIB |getQualifierValue |P793 |pval=Q385378 |qual=P580 |name=xyz |fetchwikidata=ALL }}&amp;lt;/nowiki&amp;gt;&amp;lt;/code&amp;gt;&lt;br /&gt;
In [[South Pole Telescope]] it returns:&lt;br /&gt;
* {{#invoke:WikidataIB |getQualifierValue |P793 |pval=Q385378 |qual=P580 |name=xyz |fetchwikidata=ALL |qid=Q1513315}}&lt;br /&gt;
&lt;br /&gt;
=== Function getValueByQual ===&lt;br /&gt;
The getValueByQual function returns the value of a property which has a qualifier with a given entity value. The parameters are:&lt;br /&gt;
* The property ID passed in the unnamed parameter (or {{para|1}})&lt;br /&gt;
* The property ID for a qualifier (or &amp;quot;ALL&amp;quot; or &amp;quot;DATES&amp;quot;) in {{para|qualID}}&lt;br /&gt;
* The Wikibase-entity ID of a value for that qualifier in {{para|qvalue}}&lt;br /&gt;
* The same parameters to implement whitelisting and blacklisting of the property as in getValue&lt;br /&gt;
* Optional boolean to specify whether only sourced values of the property are returned (defaults to &amp;quot;no&amp;quot;) in {{para|onlysourced}}&lt;br /&gt;
* Optional item ID for arbitrary access in {{para|qid}}&lt;br /&gt;
* The same parameters to format output as in getValue&lt;br /&gt;
&lt;br /&gt;
==== Example of getValueByQual ====&lt;br /&gt;
In {{Q|Q10990}} there is a property {{Q|P443}} that has multiple values, each of which has a qualifier {{Q|P407}}. We can return the property value whose qualifier has the value {{Q|Q7979}}&lt;br /&gt;
* &amp;lt;code&amp;gt;&amp;lt;nowiki&amp;gt;{{#invoke:WikidataIB |getValueByQual |qid=Q10990 |P443 |qualID=P407 |qvalue=Q7979 |fwd=ALL |osd=no |noicon=true}}&amp;lt;/nowiki&amp;gt;&amp;lt;/code&amp;gt; → {{#invoke:WikidataIB/sandbox |getValueByQual |qid=Q10990 |P443 |qualID=P407 |qvalue=Q7979 |fwd=ALL |osd=no |noicon=true}}&lt;br /&gt;
&lt;br /&gt;
=== Function getValueByLang ===&lt;br /&gt;
The getValueByLang function returns the value of a property which has a qualifier {{Q|P407}} whose value has the given language code. The parameters are:&lt;br /&gt;
* The property ID passed in the unnamed parameter (or {{para|1}})&lt;br /&gt;
* The MediaWiki language code to match the language whose code is given by {{para|lang|xx[-yy]}}. If no code is supplied, it uses the default language.&lt;br /&gt;
* The same parameters to implement whitelisting and blacklisting of the property as in getValue&lt;br /&gt;
* Optional boolean to specify whether only sourced values of the property are returned (defaults to &amp;quot;no&amp;quot;) in {{para|onlysourced}}&lt;br /&gt;
* Optional item ID for arbitrary access in {{para|qid}}&lt;br /&gt;
* The same parameters to format output as in getValue&lt;br /&gt;
&lt;br /&gt;
== Utility functions ==&lt;br /&gt;
&lt;br /&gt;
=== Function getLink ===&lt;br /&gt;
getLink has the qid of a Wikidata entity passed as the first unnamed parameter or as |qid=&lt;br /&gt;
&lt;br /&gt;
If there is a sitelink to an article on the local Wiki, it returns a link to the article with the Wikidata label as the displayed text.&lt;br /&gt;
If there is no sitelink, it returns the label as plain text.&lt;br /&gt;
If there is no label in the local language, it displays the qid instead.&lt;br /&gt;
: Wikidata: {{q|Q29016906}} and {{q|Q3621491}} &lt;br /&gt;
* &amp;lt;code&amp;gt;&amp;lt;nowiki&amp;gt;{{#invoke:WikidataIB |getLink |Q29016906}}&amp;lt;/nowiki&amp;gt;&amp;lt;/code&amp;gt; → {{#invoke:WikidataIB |getLink |Q29016906}}&lt;br /&gt;
* &amp;lt;code&amp;gt;&amp;lt;nowiki&amp;gt;{{#invoke:WikidataIB |getLink |Q3621491}}&amp;lt;/nowiki&amp;gt;&amp;lt;/code&amp;gt; → {{#invoke:WikidataIB |getLink |Q3621491}}&lt;br /&gt;
&lt;br /&gt;
=== Function getLabel ===&lt;br /&gt;
getLabel has the qid of a Wikidata entity passed as the first unnamed parameter or as |qid=&lt;br /&gt;
&lt;br /&gt;
It returns the Wikidata label for the local language as plain text.&lt;br /&gt;
If there is no label in the local language, it displays the qid instead.&lt;br /&gt;
Note that this is the label given to the Wikidata entry in the same language as the current Wiki, if the label exists.&lt;br /&gt;
: Wikidata: {{q|Q29016906}} and {{q|Q3621491}} &lt;br /&gt;
* &amp;lt;code&amp;gt;&amp;lt;nowiki&amp;gt;{{#invoke:WikidataIB |getLabel |Q29016906}}&amp;lt;/nowiki&amp;gt;&amp;lt;/code&amp;gt; → {{#invoke:WikidataIB |getLabel |Q29016906}}&lt;br /&gt;
* &amp;lt;code&amp;gt;&amp;lt;nowiki&amp;gt;{{#invoke:WikidataIB |getLabel |Q3621491}}&amp;lt;/nowiki&amp;gt;&amp;lt;/code&amp;gt; → {{#invoke:WikidataIB |getLabel |Q3621491}}&lt;br /&gt;
&lt;br /&gt;
=== Function getAT ===&lt;br /&gt;
getAT has the qid of a Wikidata entity passed as the first unnamed parameter or as |qid=&lt;br /&gt;
&lt;br /&gt;
If there is a sitelink to an article on the local Wiki, it returns the sitelink as plain text, i.e. the article title.&lt;br /&gt;
If there is no sitelink, it returns nothing.&lt;br /&gt;
Note that this is the title of the article in the current Wikipedia, if the interlanguage link exists in the Wikidata entry.&lt;br /&gt;
: Wikidata: {{q|Q29016906}} and {{q|Q3621491}} &lt;br /&gt;
* &amp;lt;code&amp;gt;&amp;lt;nowiki&amp;gt;{{#invoke:WikidataIB |getAT |Q29016906}}&amp;lt;/nowiki&amp;gt;&amp;lt;/code&amp;gt; → {{#invoke:WikidataIB |getAT |Q29016906}}&lt;br /&gt;
* &amp;lt;code&amp;gt;&amp;lt;nowiki&amp;gt;{{#invoke:WikidataIB |getAT |Q3621491}}&amp;lt;/nowiki&amp;gt;&amp;lt;/code&amp;gt; → {{#invoke:WikidataIB |getAT |Q3621491}}&lt;br /&gt;
&lt;br /&gt;
=== Function getDescription ===&lt;br /&gt;
getDescription has the qid of a Wikidata entity passed as |qid= (it defaults to the associated qid of the current article if omitted).&lt;br /&gt;
It has a local parameter passed as the first unnamed parameter.&lt;br /&gt;
Any local parameter passed (other than &amp;quot;Wikidata&amp;quot; or &amp;quot;none&amp;quot;) becomes the return value.&lt;br /&gt;
It returns the article description for the Wikidata entity in plain text if the local parameter is &amp;quot;Wikidata&amp;quot;.&lt;br /&gt;
Nothing is returned if the description doesn&#039;t exist or &amp;quot;none&amp;quot; is passed as the local parameter.&lt;br /&gt;
: Wikidata: {{q|Q29016906}} and {{q|Q3621491}} &lt;br /&gt;
* &amp;lt;code&amp;gt;&amp;lt;nowiki&amp;gt;{{#invoke:WikidataIB |getDescription |qid=Q29016906 |wikidata}}&amp;lt;/nowiki&amp;gt;&amp;lt;/code&amp;gt; → {{#invoke:WikidataIB |getDescription |qid=Q29016906 |wikidata}}&lt;br /&gt;
* &amp;lt;code&amp;gt;&amp;lt;nowiki&amp;gt;{{#invoke:WikidataIB |getDescription |qid=Q29016906 |A painting}}&amp;lt;/nowiki&amp;gt;&amp;lt;/code&amp;gt; → {{#invoke:WikidataIB |getDescription |qid=Q29016906 |A painting}}&lt;br /&gt;
* &amp;lt;code&amp;gt;&amp;lt;nowiki&amp;gt;{{#invoke:WikidataIB |getDescription |qid=Q29016906 |none}}&amp;lt;/nowiki&amp;gt;&amp;lt;/code&amp;gt; → {{#invoke:WikidataIB |getDescription |qid=Q29016906 |none}}&lt;br /&gt;
* &amp;lt;code&amp;gt;&amp;lt;nowiki&amp;gt;{{#invoke:WikidataIB |getDescription |qid=Q3621491 |wikidata}}&amp;lt;/nowiki&amp;gt;&amp;lt;/code&amp;gt; → {{#invoke:WikidataIB |getDescription |qid=Q3621491 |wikidata}}&lt;br /&gt;
* &amp;lt;code&amp;gt;&amp;lt;nowiki&amp;gt;{{#invoke:WikidataIB |getDescription |qid=Q3621491 |A profession}}&amp;lt;/nowiki&amp;gt;&amp;lt;/code&amp;gt; → {{#invoke:WikidataIB |getDescription |qid=Q3621491 |A profession}}&lt;br /&gt;
* &amp;lt;code&amp;gt;&amp;lt;nowiki&amp;gt;{{#invoke:WikidataIB |getDescription |qid=Q3621491 |none}}&amp;lt;/nowiki&amp;gt;&amp;lt;/code&amp;gt; → {{#invoke:WikidataIB |getDescription |qid=Q3621491 |none}}&lt;br /&gt;
&lt;br /&gt;
=== Function formatDate ===&lt;br /&gt;
formatDate accepts a datetime of the usual format from mw.wikibase.entity:formatPropertyValues, like &amp;quot;1 August 30 BCE&amp;quot; as parameter 1 and formats it according to the df (date format) and bc parameters.&lt;br /&gt;
* &amp;lt;code&amp;gt;&amp;lt;nowiki&amp;gt;{{#invoke:WikidataIB |formatDate | 1 August 30 BCE |bc=BCE |df=dmy}}&amp;lt;/nowiki&amp;gt;&amp;lt;/code&amp;gt; → {{#invoke:WikidataIB |formatDate | 1 August 30 BCE |bc=BCE |df=dmy}}&lt;br /&gt;
* &amp;lt;code&amp;gt;&amp;lt;nowiki&amp;gt;{{#invoke:WikidataIB |formatDate | 1 August 30 BCE |bc=BC  |df=mdy}}&amp;lt;/nowiki&amp;gt;&amp;lt;/code&amp;gt; → {{#invoke:WikidataIB |formatDate | 1 August 30 BCE |bc=BC  |df=mdy}}&lt;br /&gt;
* df = &amp;quot;dmy&amp;quot; / &amp;quot;mdy&amp;quot; / &amp;quot;y&amp;quot; - default is &amp;quot;dmy&amp;quot;&lt;br /&gt;
* bc = &amp;quot;BC&amp;quot; / &amp;quot;BCE&amp;quot; - default is &amp;quot;BCE&amp;quot;&lt;br /&gt;
&lt;br /&gt;
=== Function checkBlacklist ===&lt;br /&gt;
checkBlacklist allows a test to check whether a named field is allowed.&lt;br /&gt;
It returns true if the field is not blacklisted (i.e. allowed)&lt;br /&gt;
It returns false if the field is blacklisted (i.e. disallowed)&lt;br /&gt;
&lt;br /&gt;
Example:&lt;br /&gt;
* &amp;lt;code&amp;gt;&amp;lt;nowiki&amp;gt;{{#if:{{#invoke:WikidataIB |checkBlacklist |name=nationality |suppressfields=residence; nationality; citizenship}} | not blacklisted | blacklisted}}&amp;lt;/nowiki&amp;gt;&amp;lt;/code&amp;gt; → {{#if:{{#invoke:WikidataIB |checkBlacklist |name=nationality |suppressfields=residence; nationality; citizenship}} | not blacklisted | blacklisted}}&lt;br /&gt;
* &amp;lt;code&amp;gt;&amp;lt;nowiki&amp;gt;{{#if:{{#invoke:WikidataIB |checkBlacklist |name=birth_place |suppressfields=residence; nationality; citizenship}} | not blacklisted | blacklisted}}&amp;lt;/nowiki&amp;gt;&amp;lt;/code&amp;gt; → {{#if:{{#invoke:WikidataIB |checkBlacklist |name=birth_place |suppressfields=residence; nationality; citizenship}} | not blacklisted | blacklisted}}&lt;br /&gt;
&lt;br /&gt;
=== Function emptyor ===&lt;br /&gt;
emptyor returns nil if its first unnamed argument is just punctuation, whitespace or html tags otherwise it returns the argument unchanged (including leading/trailing space).&lt;br /&gt;
&lt;br /&gt;
If the argument could contain &amp;quot;=&amp;quot;, then it must be called explicitly:&lt;br /&gt;
* &amp;lt;code&amp;gt;&amp;lt;nowiki&amp;gt;| 1 = whatever-the-argument-is&amp;lt;/nowiki&amp;gt;&amp;lt;/code&amp;gt;&lt;br /&gt;
In that case, leading and trailing spaces are trimmed.&lt;br /&gt;
&lt;br /&gt;
It finds use in infoboxes where it can replace tests like:&lt;br /&gt;
* &amp;lt;code&amp;gt;&amp;lt;nowiki&amp;gt;{{#if: {{#invoke:WikidataIB |getvalue |P99 |fwd=ALL}} | &amp;lt;span class=&amp;quot;xxx&amp;quot;&amp;gt;{{#invoke:WikidataIB |getvalue |P99 |fwd=ALL}}&amp;lt;/span&amp;gt; | }}&amp;lt;/nowiki&amp;gt;&amp;lt;/code&amp;gt;&lt;br /&gt;
with a form that uses just a single call to Wikidata:&lt;br /&gt;
* &amp;lt;code&amp;gt;&amp;lt;nowiki&amp;gt;{{#invoke |WikidataIB |emptyor |1= &amp;lt;span class=&amp;quot;xxx&amp;quot;&amp;gt;{{#invoke:WikidataIB |getvalue |P99 |fwd=ALL}}&amp;lt;/span&amp;gt; }}&amp;lt;/nowiki&amp;gt;&amp;lt;/code&amp;gt;&lt;br /&gt;
&lt;br /&gt;
=== Function labelorid ===&lt;br /&gt;
labelorid is a public function to expose the output of labelOrId().&lt;br /&gt;
&lt;br /&gt;
The Q-number (entity ID) is passed as |qid= or as an unnamed parameter.&lt;br /&gt;
&lt;br /&gt;
It returns the Wikidata label for that entity or the qid if no label exists.&lt;br /&gt;
&lt;br /&gt;
=== Function getQid ===&lt;br /&gt;
* getQid works with the current page and its associated Wikidata entry.&lt;br /&gt;
* It returns qid, if supplied as the first unnamed parameter or as {{para|qid}};&lt;br /&gt;
* failing that, the Wikidata entity ID of the &amp;quot;category&#039;s main topic (P301)&amp;quot;, if it exists;&lt;br /&gt;
* failing that, the Wikidata entity ID associated with the current page, if it exists;&lt;br /&gt;
* otherwise, nothing&lt;br /&gt;
&lt;br /&gt;
=== Function examine ===&lt;br /&gt;
examine provides a dump of the entire property given in the first unnamed parameter (or in {{para|pid}} as a named alias) from the item given by the parameter &#039;qid&#039;, or from the item corresponding to the current page if qid is not supplied. It works in a similar manner to the [[Module:Wikidata|Dump]] function, but only loads a single claim, rather than the whole Wikidata entry.&lt;br /&gt;
* Example: &amp;lt;code&amp;gt;&amp;lt;nowiki&amp;gt;{{#invoke:WikidataIB |examine |qid=Q1396889 |P50}}&amp;lt;/nowiki&amp;gt;&amp;lt;/code&amp;gt;&lt;br /&gt;
&lt;br /&gt;
== Coding into an infobox ==&lt;br /&gt;
&lt;br /&gt;
Typically, the getValue call will be invoked in an infobox definition, using appropriate template parameters. One simple implementation is given as an example in [[:Template:Infobox book/Wikidata/Sandbox]]. As an illustration, the &#039;author&#039; field in the infobox is coded like this:&lt;br /&gt;
&amp;lt;pre style=&amp;quot;line-height:1.2em;&amp;quot;&amp;gt;&lt;br /&gt;
| label2  = Author{{#if:{{{authors|}}}|s}}&lt;br /&gt;
|  data2  = {{#invoke:WikidataIB |getValue |P50 |name=author |fetchwikidata={{{fetchwikidata|}}} |suppressfields={{{suppressfields|}}} |{{{authors|{{{author|}}}}}} }}&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
The property to be fetched is the first unnamed parameter. In this case it is {{Q|P50}}.&lt;br /&gt;
&lt;br /&gt;
The name of the field is passed in {{para|name}} and that name is checked against the blacklist and the whitelist. To always suppress the author field in a particular article, an editor will set {{para|suppressfields|author}} in the infobox. The author field will then never be displayed.&lt;br /&gt;
&lt;br /&gt;
If the field is not blacklisted, then the infobox can be set to display a locally supplied value for author simply by setting {{para|author|[[George Orwell]]}}, for example, in the infobox. It also accepts {{para|authors}}.  If the name of the field is on the whitelist, e.g. {{para|fetchwikidata|author; genre; pub_date; pages; dewey; congress}}, &#039;&#039;and&#039;&#039; the local value is not supplied, then the infobox will display the value retrieved from Wikidata. Any separators can be used, except | and {}.&lt;br /&gt;
&lt;br /&gt;
As a shorthand, {{para|fetchwikidata|ALL}} will fetch all of the fields that are not blacklisted, as long as no local value is already provided in the article for a given field.&lt;br /&gt;
&lt;br /&gt;
Since Wikidata labels are normally lower case, the sentence case function from [[Module:String2]] can be used to capitalise the first letter of the returned text, e.g.&lt;br /&gt;
* &amp;lt;code&amp;gt;&amp;lt;nowiki&amp;gt;{{#invoke:String2 | sentence | {{#invoke:WikidataIB |getValue |P136 |name=genre |fetchwikidata=ALL |onlysourced=false}} }}&amp;lt;/nowiki&amp;gt;&amp;lt;/code&amp;gt; in {{Q|Q1396889}} produces:&lt;br /&gt;
* {{#invoke:String2 | sentence | {{#invoke:WikidataIB |getValue |P136 |name=genre |fetchwikidata=ALL |onlysourced=false |qid=Q1396889}} }}&lt;br /&gt;
&lt;br /&gt;
=== Example of calls in an infobox ===&lt;br /&gt;
&lt;br /&gt;
Basic use of getValue:&lt;br /&gt;
*&amp;lt;code&amp;gt;&amp;lt;nowiki&amp;gt;{{#invoke:WikidataIB |getValue |P000 |name=fieldname |qid={{{qid|}}} |fetchwikidata={{{fetchwikidata|}}} |onlysourced={{{onlysourced|}}} |{{{localparameter|}}} }}&amp;lt;/nowiki&amp;gt;&amp;lt;/code&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Full collection of parameters:&lt;br /&gt;
*&amp;lt;code&amp;gt;&amp;lt;nowiki&amp;gt;{{#invoke:WikidataIB |getValue |P000 |name=fieldname |qid={{{qid|}}} |suppressfields={{{suppressfields|}}} |fetchwikidata={{{fetchwikidata|}}} |onlysourced={{{onlysourced|}}} |noicon={{{noicon|}}} |wdl={{{wikidatalink|}}} |df={{dateformat|}} |bc={{{bc|}}} |prefix= |postfix= |linkprefix= |linkpostfix= |sorted={{{sorted|}}} |sep={{{separator|}}} |list={{listtype|}}} |{{{localparameter|}}} }}&amp;lt;/nowiki&amp;gt;&amp;lt;/code&amp;gt;&lt;br /&gt;
Any of the parameters can, of course, be fixed for a given field in an infobox, rather than taking the parameter supplied to the infobox, which will affect all fields. For example, one field may set {{para|list|hlist}} where a series of short words is expected; whereas another field could use {{para|list|ubl}} where an unbulleted vertical list of several words on each line is required.&lt;br /&gt;
&lt;br /&gt;
=== Coordinates ===&lt;br /&gt;
&lt;br /&gt;
The getCoords call will display the output of [[Template:Coord]] when supplied with the coordinates returned from Wikidata. It can be coded like this:&lt;br /&gt;
&amp;lt;pre style=&amp;quot;line-height:1.2em;&amp;quot;&amp;gt;&lt;br /&gt;
|label20 = Coordinates&lt;br /&gt;
| data20 = {{#invoke:WikidataIB |getCoords |name=coordinates |suppressfields={{{suppressfields|}}} |fetchwikidata={{{fetchwikidata|}}} |{{{coordinates|}}} }}&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
An example is [[Template:Infobox biosphere reserve]]&lt;br /&gt;
&amp;lt;pre style=&amp;quot;line-height:1.2em;&amp;quot;&amp;gt;&lt;br /&gt;
{{Infobox biosphere reserve&lt;br /&gt;
| fetchwikidata = ALL&lt;br /&gt;
}}&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
Displays coordinates in the usual positions when used in an article where Wikidata has coordinates.&lt;br /&gt;
&lt;br /&gt;
=== Upgrading existing infoboxes ===&lt;br /&gt;
&lt;br /&gt;
Since the parameter {{para|fetchwikidata}} is needed for any Wikidata functionality, an existing infobox may be replaced by an infobox incorporating these calls without any change whatsoever to any article. Each article using the new infobox can later be enabled by supplying {{para|fetchwikidata|ALL}}, or a list of required fields for that article. At that point, the onus is on the editor enabling the functionality to check that no unwanted fields are now being displayed. If so, they can be added to a blacklist for the article by setting {{para|suppressfields}} to the list of unwanted fields.&lt;br /&gt;
&lt;br /&gt;
=== Verifiability ===&lt;br /&gt;
&lt;br /&gt;
Where it will always be essential for a particular field to only contain values that are referenced, use &amp;lt;code&amp;gt;getValue&amp;lt;/code&amp;gt;, making sure that {{para|onlysourced}} is &#039;&#039;not&#039;&#039; set to &#039;false&#039;, &#039;0&#039; or &#039;no&#039;. By default it will exclude values that are unsourced or only sourced to a Wikipedia, thus making the job of checking easier at the article level. If unsourced data is acceptable (!), set {{para|onlysourced|no}}. As it is beyond my wit to produce an automated mechanism that knows whether an existing source is reliable or not in a given context, that job must still be performed at the article level by an editor familiar with the subject. It should always be done when first enabling Wikidata for that article.&lt;br /&gt;
&lt;br /&gt;
== Example of use: Infobox book ==&lt;br /&gt;
&lt;br /&gt;
This section is taken from [[Template:Infobox book/Wikidata/Sandbox/doc]].&lt;br /&gt;
&lt;br /&gt;
=== No Wikidata ===&lt;br /&gt;
&amp;lt;pre style=&amp;quot;line-height:1.2em;&amp;quot;&amp;gt;&lt;br /&gt;
{{Infobox book/Wikidata/Sandbox&lt;br /&gt;
| suppressfields =&lt;br /&gt;
| fetchwikidata  =&lt;br /&gt;
| name           = Animal Farm&lt;br /&gt;
| title_orig     = Animal Farm: A Fairy Story&lt;br /&gt;
| image          = Animal Farm - 1st edition.jpg&lt;br /&gt;
| image_size     = 200px&lt;br /&gt;
| caption        = First edition cover&lt;br /&gt;
| author         = [[George Orwell]]&lt;br /&gt;
| country        = United Kingdom&lt;br /&gt;
| language       = English&lt;br /&gt;
| genre          = Political satire&lt;br /&gt;
}}&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
Works as a non-aware infobox: only locally supplied parameters are displayed.&lt;br /&gt;
&amp;lt;pre style=&amp;quot;line-height:1.2em;&amp;quot;&amp;gt;&lt;br /&gt;
{{Infobox book/Wikidata/Sandbox&lt;br /&gt;
| name           = Animal Farm&lt;br /&gt;
| title_orig     = Animal Farm: A Fairy Story&lt;br /&gt;
| image          = Animal Farm - 1st edition.jpg&lt;br /&gt;
| image_size     = 200px&lt;br /&gt;
| caption        = First edition cover&lt;br /&gt;
| author         = [[George Orwell]]&lt;br /&gt;
| country        = United Kingdom&lt;br /&gt;
| language       = English&lt;br /&gt;
| genre          = Political satire&lt;br /&gt;
}}&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
The blacklist and whitelist can be omitted if unused&lt;br /&gt;
&lt;br /&gt;
=== All Wikidata ===&lt;br /&gt;
&amp;lt;pre style=&amp;quot;line-height:1.2em;&amp;quot;&amp;gt;&lt;br /&gt;
{{Infobox book/Wikidata/Sandbox&lt;br /&gt;
| fetchwikidata  = author; genre; pub_date; pages; dewey; congress&lt;br /&gt;
}}&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
Fetches the author, publication date, number of pages, Dewey index, and Library of Congress catalogue number values from Wikidata.&lt;br /&gt;
&amp;lt;pre style=&amp;quot;line-height:1.2em;&amp;quot;&amp;gt;&lt;br /&gt;
{{Infobox book/Wikidata/Sandbox&lt;br /&gt;
| fetchwikidata  = ALL&lt;br /&gt;
}}&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
As shorthand, the {{para|fetchwikidata}} parameter can be set to ALL to fetch all available fields.&lt;br /&gt;
Any field can be suppressed by naming it in {{para|suppressfields}}, or overridden by supplying a local value.&lt;br /&gt;
&lt;br /&gt;
=== Never display genre ===&lt;br /&gt;
&amp;lt;pre style=&amp;quot;line-height:1.2em;&amp;quot;&amp;gt;&lt;br /&gt;
{{Infobox book/Wikidata/Sandbox&lt;br /&gt;
| suppressfields = genre&lt;br /&gt;
| fetchwikidata  = author; genre; pub_date; pages; dewey; congress&lt;br /&gt;
}}&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
The genre field will always be suppressed, even if a local value is supplied.&lt;br /&gt;
&amp;lt;pre style=&amp;quot;line-height:1.2em;&amp;quot;&amp;gt;&lt;br /&gt;
{{Infobox book/Wikidata/Sandbox&lt;br /&gt;
| suppressfields = genre&lt;br /&gt;
| fetchwikidata  = author; genre; pub_date; pages; dewey; congress&lt;br /&gt;
| genre          = Political satire&lt;br /&gt;
}}&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
=== Local override ===&lt;br /&gt;
&amp;lt;pre style=&amp;quot;line-height:1.2em;&amp;quot;&amp;gt;&lt;br /&gt;
{{Infobox book/Wikidata/Sandbox&lt;br /&gt;
| fetchwikidata  = author; genre; pub_date; pages; dewey; congress&lt;br /&gt;
| genre          = Political satire&lt;br /&gt;
}}&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
The genre field is set to display &amp;quot;Political satire&amp;quot;, no matter what is stored in Wikidata.&lt;br /&gt;
&amp;lt;pre style=&amp;quot;line-height:1.2em;&amp;quot;&amp;gt;&lt;br /&gt;
{{Infobox book/Wikidata/Sandbox&lt;br /&gt;
| fetchwikidata  = ALL&lt;br /&gt;
| genre          = Novel&lt;br /&gt;
}}&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
The genre field is set to display &amp;quot;Novel&amp;quot;, no matter what is stored in Wikidata.&lt;br /&gt;
&lt;br /&gt;
=== Don&#039;t fetch genre ===&lt;br /&gt;
&amp;lt;pre style=&amp;quot;line-height:1.2em;&amp;quot;&amp;gt;&lt;br /&gt;
{{Infobox book/Wikidata/Sandbox&lt;br /&gt;
| suppressfields = &lt;br /&gt;
| fetchwikidata  = author; pub_date; pages; dewey; congress&lt;br /&gt;
}}&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
The genre field will not be fetched from Wikidata. Only the author, publication date, number of pages, Dewey index, and Library of Congress catalogue number are imported. A local value for genre will display.&lt;br /&gt;
&lt;br /&gt;
==See also==&lt;br /&gt;
* [[Module:Wikidata]], handling Wikidata more basically&lt;br /&gt;
&lt;br /&gt;
==Tracking categories==&lt;br /&gt;
* {{clc|Articles with missing Wikidata information}}&lt;br /&gt;
&lt;br /&gt;
{{Wikidata infoboxes}}&lt;br /&gt;
&lt;br /&gt;
&amp;lt;includeonly&amp;gt;{{#ifeq:{{SUBPAGENAME}}|sandbox | |&lt;br /&gt;
&amp;lt;!-- Categories below this line, please; interwikis at Wikidata --&amp;gt;&lt;br /&gt;
[[Category:Wikidata modules]]&lt;br /&gt;
}}&amp;lt;/includeonly&amp;gt;&lt;/div&gt;</summary>
		<author><name>Aron.hives@edubase.net</name></author>
	</entry>
	<entry>
		<id>https://edubase.wiki/index.php?title=Module:String2&amp;diff=27358</id>
		<title>Module:String2</title>
		<link rel="alternate" type="text/html" href="https://edubase.wiki/index.php?title=Module:String2&amp;diff=27358"/>
		<updated>2018-11-12T22:47:33Z</updated>

		<summary type="html">&lt;p&gt;Aron.hives@edubase.net: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;local p = {}&lt;br /&gt;
&lt;br /&gt;
p.upper = function(frame)&lt;br /&gt;
	local s = mw.text.trim(frame.args[1] or &amp;quot;&amp;quot;)&lt;br /&gt;
	return string.upper(s)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
p.lower = function(frame)&lt;br /&gt;
	local s = mw.text.trim(frame.args[1] or &amp;quot;&amp;quot;)&lt;br /&gt;
	return string.lower(s)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
p.sentence = function (frame )&lt;br /&gt;
	frame.args[1] = string.lower(frame.args[1])&lt;br /&gt;
	return p.ucfirst(frame)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
p.ucfirst = function (frame )&lt;br /&gt;
	local s =  mw.text.trim( frame.args[1] or &amp;quot;&amp;quot; )&lt;br /&gt;
	local s1 = &amp;quot;&amp;quot;&lt;br /&gt;
	-- if it&#039;s a list chop off and (store as s1) everything up to the first &amp;lt;li&amp;gt;&lt;br /&gt;
	local lipos = string.find(s, &amp;quot;&amp;lt;li&amp;gt;&amp;quot; )&lt;br /&gt;
	if lipos then&lt;br /&gt;
		s1 = string.sub(s, 1, lipos + 3)&lt;br /&gt;
		s = string.sub(s, lipos + 4)&lt;br /&gt;
	end&lt;br /&gt;
	-- s1 is either &amp;quot;&amp;quot; or the first part of the list markup, so we can continue&lt;br /&gt;
	-- and prepend s1 to the returned string&lt;br /&gt;
	if string.find(s, &amp;quot;^%[%[[^|]+|[^%]]+%]%]&amp;quot;) then&lt;br /&gt;
		-- this is a piped wikilink, so we capitalise the text, not the pipe&lt;br /&gt;
		local b, c = string.find(s, &amp;quot;|%A*%a&amp;quot;) -- find the first letter after the pipe&lt;br /&gt;
		return s1 .. string.sub(s, 1, c-1) .. string.upper(string.sub(s, c, c)) .. string.sub(s, c+1)&lt;br /&gt;
	end&lt;br /&gt;
	local letterpos = string.find(s, &#039;%a&#039;)&lt;br /&gt;
	if letterpos then&lt;br /&gt;
		local first = string.sub(s, 1, letterpos - 1)&lt;br /&gt;
		local letter = string.sub(s, letterpos, letterpos)&lt;br /&gt;
		local rest = string.sub(s, letterpos + 1)&lt;br /&gt;
		return s1 .. first .. string.upper(letter) .. rest&lt;br /&gt;
	else&lt;br /&gt;
		return s1 .. s&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
p.title = function (frame )&lt;br /&gt;
	-- http://grammar.yourdictionary.com/capitalization/rules-for-capitalization-in-titles.html&lt;br /&gt;
	-- recommended by The U.S. Government Printing Office Style Manual:&lt;br /&gt;
	-- &amp;quot;Capitalize all words in titles of publications and documents,&lt;br /&gt;
	-- except a, an, the, at, by, for, in, of, on, to, up, and, as, but, or, and nor.&amp;quot;&lt;br /&gt;
	local alwayslower = {[&#039;a&#039;] = 1, [&#039;an&#039;] = 1, [&#039;the&#039;] = 1, &lt;br /&gt;
		[&#039;and&#039;] = 1, [&#039;but&#039;] = 1, [&#039;or&#039;] = 1, [&#039;for&#039;] = 1,&lt;br /&gt;
		[&#039;nor&#039;] = 1, [&#039;on&#039;] = 1, [&#039;in&#039;] = 1, [&#039;at&#039;] = 1, [&#039;to&#039;] = 1,&lt;br /&gt;
		[&#039;from&#039;] = 1, [&#039;by&#039;] = 1, [&#039;of&#039;] = 1, [&#039;up&#039;] = 1 }&lt;br /&gt;
	local res = &#039;&#039;&lt;br /&gt;
	local s =  mw.text.trim( frame.args[1] or &amp;quot;&amp;quot; )&lt;br /&gt;
	local words = mw.text.split( s, &amp;quot; &amp;quot;)&lt;br /&gt;
	for i, s in ipairs(words) do&lt;br /&gt;
		s = string.lower( s )&lt;br /&gt;
		if( i &amp;gt; 1 and alwayslower[s] == 1) then&lt;br /&gt;
			-- leave in lowercase&lt;br /&gt;
		else&lt;br /&gt;
			s = mw.getContentLanguage():ucfirst(s)&lt;br /&gt;
		end&lt;br /&gt;
		words[i] = s&lt;br /&gt;
	end&lt;br /&gt;
	return table.concat(words, &amp;quot; &amp;quot;)&lt;br /&gt;
end&lt;br /&gt;
-- Capitalizing only first letter for fetched Wikidata labels.&lt;br /&gt;
-- Wikidata English labels generally begin with a lowercase letter. [[:d:Help:Label#Capitalization]]&lt;br /&gt;
p.label = p.ucfirst&lt;br /&gt;
-- stripZeros finds the first number and strips leading zeros (apart from units)&lt;br /&gt;
-- e.g &amp;quot;0940&amp;quot; -&amp;gt; &amp;quot;940&amp;quot;; &amp;quot;Year: 0023&amp;quot; -&amp;gt; &amp;quot;Year: 23&amp;quot;; &amp;quot;00.12&amp;quot; -&amp;gt; &amp;quot;0.12&amp;quot;&lt;br /&gt;
p.stripZeros = function(frame)&lt;br /&gt;
	local s = mw.text.trim(frame.args[1] or &amp;quot;&amp;quot;)&lt;br /&gt;
	n = tonumber( string.match( s, &amp;quot;%d+&amp;quot; ) ) or &amp;quot;&amp;quot;&lt;br /&gt;
	s = string.gsub( s, &amp;quot;%d+&amp;quot;, n, 1 )&lt;br /&gt;
	return s&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- nowiki ensures that a string of text is treated by the MediaWiki software as just a string&lt;br /&gt;
-- it takes an unnamed parameter and trims whitespace, then removes any wikicode&lt;br /&gt;
p.nowiki = function(frame)&lt;br /&gt;
	local str = mw.text.trim(frame.args[1] or &amp;quot;&amp;quot;)&lt;br /&gt;
	return mw.text.nowiki(str)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
return p&lt;/div&gt;</summary>
		<author><name>Aron.hives@edubase.net</name></author>
	</entry>
	<entry>
		<id>https://edubase.wiki/index.php?title=Module:Roman&amp;diff=27356</id>
		<title>Module:Roman</title>
		<link rel="alternate" type="text/html" href="https://edubase.wiki/index.php?title=Module:Roman&amp;diff=27356"/>
		<updated>2018-11-12T22:47:32Z</updated>

		<summary type="html">&lt;p&gt;Aron.hives@edubase.net: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;-- This module implements {{Roman}}.&lt;br /&gt;
&lt;br /&gt;
local p = {}&lt;br /&gt;
&lt;br /&gt;
-- This function implements the {{overline}} template.&lt;br /&gt;
local function overline(s)&lt;br /&gt;
    return mw.ustring.format( &#039;&amp;lt;span style=&amp;quot;text-decoration:overline;&amp;quot;&amp;gt;%s&amp;lt;/span&amp;gt;&#039;, s )&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- Gets the Roman numerals for a given numeral table. Returns both the string of&lt;br /&gt;
-- numerals and the value of the number after it is finished being processed.&lt;br /&gt;
local function getLetters(num, t)&lt;br /&gt;
    local ret = {}&lt;br /&gt;
    for _, v in ipairs(t) do&lt;br /&gt;
        local val, letter = unpack(v)&lt;br /&gt;
        while num &amp;gt;= val do&lt;br /&gt;
            num = num - val&lt;br /&gt;
            table.insert(ret, letter)&lt;br /&gt;
        end&lt;br /&gt;
    end&lt;br /&gt;
&lt;br /&gt;
    return table.concat(ret), num&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- The main control flow of the module.&lt;br /&gt;
local function _main(args)&lt;br /&gt;
    -- Get input and exit displaying nothing if the input is empty.&lt;br /&gt;
    if args[1] == nil then return end&lt;br /&gt;
    local num = tonumber(args[1])&lt;br /&gt;
    if not num or num &amp;lt; 0 or num == math.huge then&lt;br /&gt;
    	error(&#039;Invalid number &#039; .. args[1], 2)&lt;br /&gt;
    elseif num == 0 then&lt;br /&gt;
        return &#039;N&#039;&lt;br /&gt;
    end&lt;br /&gt;
&lt;br /&gt;
    -- Return a message for numbers too big to be expressed in Roman numerals.&lt;br /&gt;
    if num &amp;gt;= 5000000 then&lt;br /&gt;
        return args[2] or &#039;N/A&#039;&lt;br /&gt;
    end&lt;br /&gt;
&lt;br /&gt;
    local ret = &#039;&#039;&lt;br /&gt;
    -- Find the Roman numerals for the large part of numbers.&lt;br /&gt;
    -- 23 April 2016 - tweaked to &amp;gt;= 4000 to accept big Roman &#039;IV&#039;&lt;br /&gt;
    -- The if statement is not strictly necessary, but makes the algorithm &lt;br /&gt;
    -- more efficient for smaller numbers.&lt;br /&gt;
    if num &amp;gt;= 4000 then&lt;br /&gt;
        local bigRomans = {&lt;br /&gt;
            { 1000000, &#039;M&#039; },&lt;br /&gt;
            { 900000, &#039;CM&#039; }, { 500000, &#039;D&#039; }, { 400000, &#039;CD&#039; }, { 100000, &#039;C&#039; },&lt;br /&gt;
            {  90000, &#039;XC&#039; }, {  50000, &#039;L&#039; }, {  40000, &#039;XL&#039; }, {  10000, &#039;X&#039; },&lt;br /&gt;
            {   9000, &#039;IX&#039; }, {   5000, &#039;V&#039; }, {   4000, &#039;IV&#039; },&lt;br /&gt;
        }&lt;br /&gt;
        local bigLetters&lt;br /&gt;
        bigLetters, num = getLetters(num, bigRomans)&lt;br /&gt;
        ret = overline(bigLetters)&lt;br /&gt;
    end&lt;br /&gt;
&lt;br /&gt;
    -- Find the Roman numerals for numbers less than the big Roman threshold.&lt;br /&gt;
    local smallRomans = {&lt;br /&gt;
        { 1000, &#039;M&#039; },&lt;br /&gt;
        { 900, &#039;CM&#039; }, { 500, &#039;D&#039; }, { 400, &#039;CD&#039; }, { 100, &#039;C&#039; },&lt;br /&gt;
        {  90, &#039;XC&#039; }, {  50, &#039;L&#039; }, {  40, &#039;XL&#039; }, {  10, &#039;X&#039; },&lt;br /&gt;
        {   9, &#039;IX&#039; }, {   5, &#039;V&#039; }, {   4, &#039;IV&#039; }, {   1, &#039;I&#039; }&lt;br /&gt;
    }&lt;br /&gt;
    local smallLetters = getLetters( num, smallRomans )&lt;br /&gt;
    ret = ret .. smallLetters&lt;br /&gt;
&lt;br /&gt;
    if args.fraction == &#039;yes&#039; then&lt;br /&gt;
        -- Find the Roman numerals for the fractional parts of numbers.&lt;br /&gt;
        -- If num is not a whole number, add half of 1/1728 (the smallest unit) to equate to rounding.&lt;br /&gt;
        -- Ensure we&#039;re not less than the smallest unit or larger than 1 - smallest unit&lt;br /&gt;
        -- to avoid getting two &amp;quot;half&amp;quot; symbols or no symbols at all&lt;br /&gt;
        num = num - math.floor(num)&lt;br /&gt;
        if num ~= 0 then&lt;br /&gt;
            num = math.max(1.1/1728, math.min(1727.1/1728, num + 1/3456))&lt;br /&gt;
        end&lt;br /&gt;
        local fractionalRomans = {&lt;br /&gt;
            { 1/2, &#039;S&#039; }, { 5/12, &amp;quot;&#039;&#039;&#039;:&#039;&#039;&#039;•&#039;&#039;&#039;:&#039;&#039;&#039;&amp;quot; }, { 1/3, &amp;quot;&#039;&#039;&#039;::&#039;&#039;&#039;&amp;quot; },&lt;br /&gt;
            { 1/4, &amp;quot;&#039;&#039;&#039;:&#039;&#039;&#039;•&amp;quot; }, { 1/6, &amp;quot;&#039;&#039;&#039;:&#039;&#039;&#039;&amp;quot; }, { 1/12, &#039;•&#039; },&lt;br /&gt;
            { 1/24, &#039;Є&#039; }, { 1/36, &#039;ƧƧ&#039; }, { 1/48, &#039;Ɔ&#039; }, { 1/72, &#039;Ƨ&#039; }, { 1/144, &#039;&amp;lt;s&amp;gt;Ƨ&amp;lt;/s&amp;gt;&#039; },&lt;br /&gt;
            { 1/288, &#039;℈&#039; }, { 1/1728, &#039;»&#039; },&lt;br /&gt;
        }&lt;br /&gt;
        local fractionalLetters = getLetters(num, fractionalRomans)&lt;br /&gt;
        &lt;br /&gt;
        ret = ret .. fractionalLetters&lt;br /&gt;
    end&lt;br /&gt;
&lt;br /&gt;
    return ret&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.main(frame)&lt;br /&gt;
    -- If called via #invoke, use the args passed into the invoking&lt;br /&gt;
    -- template, or the args passed to #invoke if any exist. Otherwise&lt;br /&gt;
    -- assume args are being passed directly in from the debug console&lt;br /&gt;
    -- or from another Lua module.&lt;br /&gt;
    local origArgs&lt;br /&gt;
    if frame == mw.getCurrentFrame() then&lt;br /&gt;
        origArgs = frame:getParent().args&lt;br /&gt;
        for k, v in pairs(frame.args) do&lt;br /&gt;
            origArgs = frame.args&lt;br /&gt;
            break&lt;br /&gt;
        end&lt;br /&gt;
    else&lt;br /&gt;
        origArgs = frame&lt;br /&gt;
    end&lt;br /&gt;
    -- Trim whitespace and remove blank arguments.&lt;br /&gt;
    local args = {}&lt;br /&gt;
    for k, v in pairs(origArgs) do&lt;br /&gt;
        if type( v ) == &#039;string&#039; then&lt;br /&gt;
            v = mw.text.trim(v)&lt;br /&gt;
        end&lt;br /&gt;
        if v ~= &#039;&#039; then&lt;br /&gt;
            args[k] = v&lt;br /&gt;
        end&lt;br /&gt;
    end&lt;br /&gt;
    &lt;br /&gt;
    -- exit if not given anything&lt;br /&gt;
    if args == nil or args == {} then return end&lt;br /&gt;
    -- Given mathematical expression, simplify to a number&lt;br /&gt;
    if type(args[1]) == &#039;string&#039; then&lt;br /&gt;
        args[1] = mw.ext.ParserFunctions.expr(args[1])&lt;br /&gt;
    end&lt;br /&gt;
    return _main(args)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
return p&lt;/div&gt;</summary>
		<author><name>Aron.hives@edubase.net</name></author>
	</entry>
	<entry>
		<id>https://edubase.wiki/index.php?title=Module:Ordinal&amp;diff=27354</id>
		<title>Module:Ordinal</title>
		<link rel="alternate" type="text/html" href="https://edubase.wiki/index.php?title=Module:Ordinal&amp;diff=27354"/>
		<updated>2018-11-12T22:47:32Z</updated>

		<summary type="html">&lt;p&gt;Aron.hives@edubase.net: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;--[[  &lt;br /&gt;
 &lt;br /&gt;
This template will add the appropriate ordinal suffix to a given integer.&lt;br /&gt;
 &lt;br /&gt;
Please do not modify this code without applying the changes first at&lt;br /&gt;
Module:Ordinal/sandbox and testing at Module:Ordinal/sandbox/testcases and&lt;br /&gt;
Module talk:Ordinal/sandbox/testcases.&lt;br /&gt;
 &lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local p = {}&lt;br /&gt;
&lt;br /&gt;
local yesno     = require(&#039;Module:Yesno&#039;) -- boolean value interpretation&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
This function converts an integer value into a numeral followed by ordinal indicator.&lt;br /&gt;
The output string might contain HTML tags.&lt;br /&gt;
 &lt;br /&gt;
Usage:&lt;br /&gt;
{{#invoke:Ordinal|ordinal|1=|2=|sup=}}&lt;br /&gt;
{{#invoke:Ordinal|ordinal}} - uses the caller&#039;s parameters&lt;br /&gt;
 &lt;br /&gt;
Parameters&lt;br /&gt;
    1: Any number or string.&lt;br /&gt;
    2: Set to &amp;quot;d&amp;quot; if the module should display &amp;quot;d&amp;quot; instead of &amp;quot;nd&amp;quot; and &amp;quot;rd&amp;quot;.&lt;br /&gt;
    sup: Set to yes/no to toggle superscript ordinal suffix.&lt;br /&gt;
]]&lt;br /&gt;
function p.ordinal(frame)&lt;br /&gt;
	local args = frame.args&lt;br /&gt;
    if args[1] == nil then&lt;br /&gt;
        args = frame:getParent().args&lt;br /&gt;
    end&lt;br /&gt;
    if args[1] == nil then&lt;br /&gt;
    	args[1] = &amp;quot;{{{1}}}&amp;quot;&lt;br /&gt;
    end&lt;br /&gt;
    return p._ordinal(args[1], (args[2] == &#039;d&#039;), yesno(args.sup))&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p._ordinal(n, d, sup)&lt;br /&gt;
	local x = tonumber(mw.ustring.match(n, &amp;quot;(%d*)%W*$&amp;quot;))&lt;br /&gt;
	local suffix = &amp;quot;th&amp;quot;&lt;br /&gt;
	-- If tonumber(n) worked:&lt;br /&gt;
	if x then&lt;br /&gt;
		local mod10 = math.abs(x) % 10&lt;br /&gt;
		local mod100 = math.abs(x) % 100&lt;br /&gt;
		if     mod10 == 1 and mod100 ~= 11 then&lt;br /&gt;
			suffix = &amp;quot;st&amp;quot;&lt;br /&gt;
		elseif mod10 == 2 and mod100 ~= 12 then&lt;br /&gt;
			if d then suffix = &amp;quot;d&amp;quot; else suffix = &amp;quot;nd&amp;quot; end&lt;br /&gt;
		elseif mod10 == 3 and mod100 ~= 13 then&lt;br /&gt;
			if d then suffix = &amp;quot;d&amp;quot; else suffix = &amp;quot;rd&amp;quot; end&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	if sup then&lt;br /&gt;
		suffix = &amp;quot;&amp;lt;sup&amp;gt;&amp;quot; .. suffix .. &amp;quot;&amp;lt;/sup&amp;gt;&amp;quot;&lt;br /&gt;
	end&lt;br /&gt;
	return n .. suffix&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
return p&lt;/div&gt;</summary>
		<author><name>Aron.hives@edubase.net</name></author>
	</entry>
	<entry>
		<id>https://edubase.wiki/index.php?title=Module:ISOdate&amp;diff=27352</id>
		<title>Module:ISOdate</title>
		<link rel="alternate" type="text/html" href="https://edubase.wiki/index.php?title=Module:ISOdate&amp;diff=27352"/>
		<updated>2018-11-12T22:47:32Z</updated>

		<summary type="html">&lt;p&gt;Aron.hives@edubase.net: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;--[[  &lt;br /&gt;
 &lt;br /&gt;
This module is intended for processing of date strings.&lt;br /&gt;
&lt;br /&gt;
Please do not modify this code without applying the changes first at Module:ISOdate/sandbox and testing &lt;br /&gt;
at Module:ISOdate/sandbox/testcases and Module talk:ISOdate/sandbox/testcases.&lt;br /&gt;
&lt;br /&gt;
Authors and maintainers:&lt;br /&gt;
* User:Parent5446 - original version of the function mimicking template:ISOdate&lt;br /&gt;
* User:Jarekt - original version of the functions mimicking template:Date and template:ISOyear&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
 &lt;br /&gt;
local p = {}&lt;br /&gt;
&lt;br /&gt;
-- =======================================&lt;br /&gt;
-- === Dependencies ======================&lt;br /&gt;
-- =======================================&lt;br /&gt;
local D = require(&#039;Module:DateI18n&#039;) -- the enwp version of c:Module:Date&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
ISOyear&lt;br /&gt;
 &lt;br /&gt;
This function returns year part of date string.&lt;br /&gt;
 &lt;br /&gt;
Usage:&lt;br /&gt;
{{#invoke:ISOdate|ISOyear|target_string}}&lt;br /&gt;
 &lt;br /&gt;
Parameters&lt;br /&gt;
    1: The date string &lt;br /&gt;
 &lt;br /&gt;
Error Handling:&lt;br /&gt;
   If the string does not look like it contain the year than the function will not return anything.&lt;br /&gt;
   That is the preferred treatment for the template:Creator which is the main (only?) template calling it.&lt;br /&gt;
]]&lt;br /&gt;
function p.ISOyear( frame )&lt;br /&gt;
	 return p._ISOyear( frame.args[1] )&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p._ISOyear( input )&lt;br /&gt;
	if not input then&lt;br /&gt;
		return &#039;&#039;&lt;br /&gt;
	end&lt;br /&gt;
	input = mw.text.trim( input )&lt;br /&gt;
    &lt;br /&gt;
	-- if empty string then return it&lt;br /&gt;
	if input == &amp;quot;&amp;quot; then&lt;br /&gt;
		return input&lt;br /&gt;
	end&lt;br /&gt;
    &lt;br /&gt;
	-- if number then return it&lt;br /&gt;
	if tonumber( input ) then&lt;br /&gt;
		return mw.ustring.format( &#039;%04i&#039;, input )&lt;br /&gt;
	end&lt;br /&gt;
    &lt;br /&gt;
	-- otherwise use regular expression match&lt;br /&gt;
	input = mw.ustring.match( input, &#039;^+?(-?%d%d?%d?%d?)-&#039; )&lt;br /&gt;
	if input and tonumber( input ) then&lt;br /&gt;
		return mw.ustring.format( &#039;%04i&#039;, input )&lt;br /&gt;
	else&lt;br /&gt;
		return &#039;&#039;&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
ISOdate&lt;br /&gt;
 &lt;br /&gt;
This function is the core part of the ISOdate template. &lt;br /&gt;
 &lt;br /&gt;
Usage:&lt;br /&gt;
{{#invoke:ISOdate|ISOdate|target_string|lang=}}&lt;br /&gt;
 &lt;br /&gt;
Parameters:&lt;br /&gt;
     1: The date string &lt;br /&gt;
  lang: The language to display it in&lt;br /&gt;
  form: Language format (genitive, etc.) for some languages&lt;br /&gt;
 class: CSS class for the &amp;lt;time&amp;gt; node&lt;br /&gt;
&lt;br /&gt;
 Error Handling:&lt;br /&gt;
   If the string does not look like it contain the proper ISO date than the function will return the original string.&lt;br /&gt;
   &lt;br /&gt;
   That is the preferred treatment for the template:Information (and similar templates) which calling it.&lt;br /&gt;
]]&lt;br /&gt;
function p.ISOdate(frame)&lt;br /&gt;
	local datestr, succeded&lt;br /&gt;
	local args = frame.args&lt;br /&gt;
	if not (args.lang and mw.language.isSupportedLanguage(args.lang)) then &lt;br /&gt;
		args.lang = frame:callParserFunction( &amp;quot;int&amp;quot;, &amp;quot;lang&amp;quot; ) -- get user&#039;s chosen language &lt;br /&gt;
	end&lt;br /&gt;
	datestr, succeded = p._ISOdate(&lt;br /&gt;
		mw.text.trim(args[1]),&lt;br /&gt;
		args.lang,                  -- language&lt;br /&gt;
		args.case  or &#039;&#039;,           -- allows to specify grammatical case for the month for languages that use them&lt;br /&gt;
		args.class or &#039;dtstart&#039;,    -- allows to set the html class of the time node where the date is included. &lt;br /&gt;
		args.trim_year or &#039;100-999&#039; -- by default pad one and 2 digit years to be 4 digit long, while keeping 3 digit years as is	&lt;br /&gt;
	)&lt;br /&gt;
	return datestr&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p._ISOdate(datestr, lang, case, class, trim_year)&lt;br /&gt;
&lt;br /&gt;
	-- pattern: regexp - regular expresion to test; dlen - number of date elements; tail = which element is a &amp;quot;tail&amp;quot; if any&lt;br /&gt;
	-- regexp hints:&lt;br /&gt;
	--  1) Strings starting with &amp;quot;^&amp;quot; and ending with &amp;quot;$&amp;quot; indicate whole string match&lt;br /&gt;
	--  2) optional tail part copied as-is and following the main parsed part of the date have to be separated from the date by a whitespace, so &amp;quot;(\s.+)?&amp;quot;&lt;br /&gt;
	local patterns = {&lt;br /&gt;
		-- strings starting with YYYY-MM-DD HH:MM:SS. Year 4 digits (if we know seconds than it was within the last 100 years), the rest 1-2&lt;br /&gt;
		-- date and time can be separated by space or &amp;quot;T&amp;quot; and there could be a &amp;quot;Z&amp;quot; on the end indicating &amp;quot;Zulu&amp;quot; time zone&lt;br /&gt;
		{dlen=6, tail=7, regexp=&amp;quot;^+?(%d%d%d%d)-(%d%d?)-(%d%d?)[ T](%d%d?):(%d%d?):(%d%d?)Z?(%s.*)&amp;quot;}, &lt;br /&gt;
		{dlen=6, tail=0, regexp=&amp;quot;^+?(%d%d%d%d)-(%d%d?)-(%d%d?)[ T](%d%d?):(%d%d?):(%d%d?)Z?$&amp;quot;}, &lt;br /&gt;
		-- strings starting with YYYY-MM-DD HH:MM. Year 4 digits, the rest 1-2&lt;br /&gt;
		-- (if one knows hour and minute than it was probably after a year 1000)&lt;br /&gt;
		{dlen=5, tail=6, regexp=&amp;quot;^+?(%d%d%d%d)-(%d%d?)-(%d%d?)[ T](%d%d?):(%d%d?)(%s.+)&amp;quot;},&lt;br /&gt;
		{dlen=5, tail=0, regexp=&amp;quot;^+?(%d%d%d%d)-(%d%d?)-(%d%d?)[ T](%d%d?):(%d%d?)$&amp;quot;},&lt;br /&gt;
		-- strings starting with YYYY-MM-DD. Year 1-4 digits, the rest 1-2&lt;br /&gt;
		{dlen=3, tail=4, regexp=&amp;quot;^+?(%d%d?%d?%d?)-(%d%d?)-(%d%d?)(%s.+)&amp;quot;},&lt;br /&gt;
		{dlen=3, tail=0, regexp=&amp;quot;^+?(%d%d?%d?%d?)-(%d%d?)-(%d%d?)$&amp;quot;},&lt;br /&gt;
		-- strings starting with YYYY-MM. Year 3-4 digits, month 2 digits&lt;br /&gt;
		-- (want to avoit converting to dates strings like 10-5 = 5&lt;br /&gt;
		{dlen=2, tail=3, regexp=&amp;quot;^+?(%d%d%d%d?)-(%d%d)(%s.+)&amp;quot;}, &lt;br /&gt;
		-- if whole string is in YYYY-MM form: If Year 1-4 digits, month 1-2 digits&lt;br /&gt;
		{dlen=2, tail=0, regexp=&amp;quot;^+?(%d%d?%d?%d?)-(%d%d?)$&amp;quot;}, &lt;br /&gt;
		-- string starts with a number -&amp;gt; it has to be 3 or 4 digit long to be a year&lt;br /&gt;
		{dlen=1, tail=2, regexp=&amp;quot;^+?(%d%d%d%d?)(%s.+)&amp;quot;},	&lt;br /&gt;
		 -- if whole string is a number (1-4 digit long) than it will be interpreted as a year&lt;br /&gt;
		{dlen=1, tail=0, regexp=&amp;quot;^+?(%d%d?%d?%d?)$&amp;quot;},&lt;br /&gt;
	}&lt;br /&gt;
	&lt;br /&gt;
	-- create datevec based on which variables are provided&lt;br /&gt;
	local datevec, tail, formatNum&lt;br /&gt;
	datevec, tail, formatNum = p.test_date_formats(datestr or &#039;&#039;, patterns)&lt;br /&gt;
	if datevec[1]==&#039;&#039; or datevec[1]==nil then&lt;br /&gt;
		-- quickly return if datestr does not look like date (it could be a template)&lt;br /&gt;
		return datestr, false&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- call p._Date function to format date string&lt;br /&gt;
	local succeded, datestr2&lt;br /&gt;
	succeded, datestr2 = pcall( D._Date, datevec, lang, case, class, trim_year)&lt;br /&gt;
	if succeded and datestr2~=&#039;&#039; then&lt;br /&gt;
		return mw.text.trim( datestr2 .. tail), true&lt;br /&gt;
	else -- in case of errors return the original string&lt;br /&gt;
		return datestr, false&lt;br /&gt;
	end	&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.ISOdate_extended(frame)&lt;br /&gt;
	-- pattern: regexp - regular expresion to test; dlen - number of date elements; tail = which element is a &amp;quot;tail&amp;quot; if any&lt;br /&gt;
	-- regexp hints:&lt;br /&gt;
	--  1) Strings starting with &amp;quot;^&amp;quot; and ending with &amp;quot;$&amp;quot; indicate whole string match&lt;br /&gt;
	--  2) optional tail part copied as-is and following the main parsed part of the date have to be separated from the date by a whitespace, so &amp;quot;(\s.+)?&amp;quot;&lt;br /&gt;
&lt;br /&gt;
	local datestr, succeded&lt;br /&gt;
	local args = frame.args&lt;br /&gt;
	if not (args.lang and mw.language.isSupportedLanguage(args.lang)) then &lt;br /&gt;
		args.lang = frame:callParserFunction( &amp;quot;int&amp;quot;, &amp;quot;lang&amp;quot; ) -- get user&#039;s chosen language &lt;br /&gt;
	end&lt;br /&gt;
	datestr, succeded = p._ISOdate(&lt;br /&gt;
		mw.text.trim(args[1]),&lt;br /&gt;
		args.lang,                  -- language&lt;br /&gt;
		args.case  or &#039;&#039;,           -- allows to specify grammatical case for the month for languages that use them&lt;br /&gt;
		args.class or &#039;dtstart&#039;,    -- allows to set the html class of the time node where the date is included. &lt;br /&gt;
		args.trim_year or &#039;100-999&#039; -- by default pad one and 2 digit years to be 4 digit long, while keeping 3 digit years as is	&lt;br /&gt;
	)&lt;br /&gt;
	if succeded then&lt;br /&gt;
		return datestr&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	local patterns = {&lt;br /&gt;
		-- Exended set of recognized formats: like MM/DD/YYYY&lt;br /&gt;
		{dlen=3, tail=4, regexp=&amp;quot;^(%d%d?)[-./](%d%d?)[-./](%d%d%d%d)(%s.+)&amp;quot;},&lt;br /&gt;
		{dlen=3, tail=0, regexp=&amp;quot;^(%d%d?)[-./](%d%d?)[-./](%d%d%d%d)$&amp;quot;},&lt;br /&gt;
		{dlen=3, tail=0, regexp=&amp;quot;^(%d%d?)%s(%w+)%s(%d%d%d%d)$&amp;quot;},&lt;br /&gt;
		{dlen=3, tail=0, regexp=&amp;quot;^(%w+)%s(%d%d?),%s(%d%d%d%d)$&amp;quot;},&lt;br /&gt;
	}&lt;br /&gt;
	&lt;br /&gt;
	local datevec, tail, formatNum, category = &#039;&#039;&lt;br /&gt;
	datevec, tail, formatNum = p.test_date_formats(frame.args[1], patterns)&lt;br /&gt;
	if formatNum==1 or formatNum==2 then&lt;br /&gt;
		vec = datevec;&lt;br /&gt;
		if tonumber(datevec[1])&amp;gt;12 then&lt;br /&gt;
			frame.args[1] = string.format(&#039;%04i-%02i-%02i&#039;, datevec[3], datevec[2], datevec[1] )&lt;br /&gt;
			category = &#039;[[Category:Date in DD/MM/YYYY format]]&#039;&lt;br /&gt;
			return mw.text.trim( p.ISOdate(frame) .. tail);&lt;br /&gt;
		elseif tonumber(datevec[2])&amp;gt;12 then&lt;br /&gt;
			frame.args[1] = string.format(&#039;%04i-%02i-%02i&#039;, datevec[3], datevec[1], datevec[2] )&lt;br /&gt;
			category = &#039;[[Category:Date in MM/DD/YYYY format]]&#039;&lt;br /&gt;
			return mw.text.trim( p.ISOdate(frame) .. tail);&lt;br /&gt;
		end&lt;br /&gt;
	elseif (formatNum==3 or formatNum==4) and (datevec[3]==&#039;&#039; or datevec[3]~=nil) then&lt;br /&gt;
		local str = mw.getCurrentFrame():callParserFunction( &amp;quot;#time&amp;quot;, { &#039;Y-m-d&#039;, datestr} )&lt;br /&gt;
		local vec = {str:match( &amp;quot;^(%d%d?%d?%d?)-(%d%d?)-(%d%d?)$&amp;quot; )}&lt;br /&gt;
		if vec and vec[1]~=nil then&lt;br /&gt;
			frame.args[1] = string.format(&#039;%04i-%02i-%02i&#039;, vec[1], vec[2], vec[3] )&lt;br /&gt;
			category = &#039;[[Category:Date in word format]]&#039;&lt;br /&gt;
			return p.ISOdate(frame);&lt;br /&gt;
		end&lt;br /&gt;
	end	&lt;br /&gt;
	return datestr&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.test_date_formats(datestr, patterns)&lt;br /&gt;
	-- pattern: regexp - regular expresion to test; dlen - number of date elements; tail = which element is a &amp;quot;tail&amp;quot; if any&lt;br /&gt;
&lt;br /&gt;
	local datevec = {&#039;&#039;,&#039;&#039;,&#039;&#039;,&#039;&#039;,&#039;&#039;,&#039;&#039;}&lt;br /&gt;
	local tail = &#039;&#039;&lt;br /&gt;
	local vec, pat&lt;br /&gt;
	local formatNum = 0&lt;br /&gt;
	for i, pat in ipairs( patterns ) do&lt;br /&gt;
		vec = {datestr:match( pat.regexp )}&lt;br /&gt;
		if vec and vec[1]~=nil then&lt;br /&gt;
			for j=1,pat.dlen do&lt;br /&gt;
				datevec[j] = vec[j]&lt;br /&gt;
			end&lt;br /&gt;
			if pat.tail&amp;gt;0 and vec[pat.tail]~=nil then&lt;br /&gt;
				tail = mw.ustring.gsub(&#039; &#039; .. vec[pat.tail], &#039; +&#039;, &#039; &#039;)&lt;br /&gt;
			end&lt;br /&gt;
			formatNum = i&lt;br /&gt;
			break&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	return datevec, tail, formatNum&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
return p&lt;/div&gt;</summary>
		<author><name>Aron.hives@edubase.net</name></author>
	</entry>
	<entry>
		<id>https://edubase.wiki/index.php?title=Module:I18n/date&amp;diff=27350</id>
		<title>Module:I18n/date</title>
		<link rel="alternate" type="text/html" href="https://edubase.wiki/index.php?title=Module:I18n/date&amp;diff=27350"/>
		<updated>2018-11-12T22:47:32Z</updated>

		<summary type="html">&lt;p&gt;Aron.hives@edubase.net: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;--[[&lt;br /&gt;
  __  __           _       _        ___ _  ___           __  _       _       &lt;br /&gt;
 |  \/  | ___   __| |_   _| | ___ _|_ _/ |( _ ) _ __    / /_| | __ _| |_ ___ &lt;br /&gt;
 | |\/| |/ _ \ / _` | | | | |/ _ (_)| || |/ _ \| &#039;_ \  / / _` |/ _` | __/ _ \&lt;br /&gt;
 | |  | | (_) | (_| | |_| | |  __/_ | || | (_) | | | |/ / (_| | (_| | ||  __/&lt;br /&gt;
 |_|  |_|\___/ \__,_|\__,_|_|\___(_)___|_|\___/|_| |_/_/ \__,_|\__,_|\__\___|&lt;br /&gt;
                                                                             &lt;br /&gt;
This Module handles per language customization of dates&lt;br /&gt;
Copied from https://commons.wikimedia.org/wiki/Module:I18n/date&lt;br /&gt;
used by Module:ISOdate, Module:Complex date, Module:WikidataIB&lt;br /&gt;
Authors and Maintainers:&lt;br /&gt;
* Jarekt &lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
local p = {}&lt;br /&gt;
&lt;br /&gt;
--[[ Different languages use different date formats, and many formats are shared among whole families of languages. &lt;br /&gt;
&amp;quot;DateLang&amp;quot; picks a cluster of languages associated with a single date format, based on the language to be used. &lt;br /&gt;
All unlisted languages default to English form. Languages like &amp;quot;de-formal&amp;quot; follows regular language fallback chain &lt;br /&gt;
and would default to German, and only if that does not exist then to English.&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
p.DateLang = {&lt;br /&gt;
	[&#039;be&#039;] 		= &#039;ru-form&#039;, -- Belarusian&lt;br /&gt;
	[&#039;be-tarsk&#039;] 	= &#039;ru-form&#039;, -- Belarusian (Tara۫ievica)&lt;br /&gt;
	[&#039;bn&#039;] 		= &#039;en-form&#039;, -- Bengali&lt;br /&gt;
	[&#039;bpy&#039;] 	= &#039;bpy-form&#039;, -- Bishnupuriya Manipuri&lt;br /&gt;
	[&#039;ce&#039;] 		= &#039;ce-form&#039;, -- Chechen&lt;br /&gt;
	[&#039;cs&#039;] 		= &#039;cs-form&#039;, -- Czech&lt;br /&gt;
	[&#039;da&#039;] 		= &#039;de-form&#039;, -- Danish&lt;br /&gt;
	[&#039;de&#039;] 		= &#039;de-form&#039;, -- German&lt;br /&gt;
	[&#039;el&#039;] 		= &#039;ru-form&#039;, -- Greek&lt;br /&gt;
	[&#039;en&#039;] 		= &#039;en-form&#039;, -- English&lt;br /&gt;
	[&#039;eo&#039;] 		= &#039;eo-form&#039;, -- Esperanto&lt;br /&gt;
	[&#039;es&#039;] 		= &#039;es-form&#039;, -- Spanish&lt;br /&gt;
	[&#039;et&#039;] 		= &#039;de-form&#039;, -- Estonian&lt;br /&gt;
	[&#039;eu&#039;] 		= &#039;eu-form&#039;, -- Basque&lt;br /&gt;
	[&#039;fa&#039;] 		= &#039;he-form&#039;, -- Persian&lt;br /&gt;
	[&#039;fi&#039;] 		= &#039;fi-form&#039;, -- Finnish&lt;br /&gt;
	[&#039;fr&#039;] 		= &#039;fr-form&#039;, -- French&lt;br /&gt;
	[&#039;ga&#039;] 		= &#039;ga-form&#039;, -- Gallic&lt;br /&gt;
	[&#039;gl&#039;] 		= &#039;es-form&#039;, -- Galician based on https://translatewiki.net/wiki/MediaWiki:Pagetriage-info-timestamp-date-format/gl&lt;br /&gt;
	[&#039;hi&#039;] 		= &#039;en-form&#039;, -- Hindi&lt;br /&gt;
	[&#039;he&#039;] 		= &#039;he-form&#039;, -- Hebrew &lt;br /&gt;
	[&#039;hr&#039;] 		= &#039;hr-form&#039;, -- Croatian &lt;br /&gt;
	[&#039;hu&#039;] 		= &#039;hu-form&#039;, -- Hungarian&lt;br /&gt;
	[&#039;hsb&#039;] 	= &#039;cs-form&#039;, -- Upper Sorbian&lt;br /&gt;
	[&#039;ia&#039;] 		= &#039;ia-form&#039;, -- Interlingua&lt;br /&gt;
	[&#039;is&#039;] 		= &#039;de-form&#039;, -- Icelandic&lt;br /&gt;
	[&#039;ja&#039;] 		= &#039;zh-form&#039;, -- Japanese&lt;br /&gt;
	[&#039;kn&#039;] 		= &#039;kn-form&#039;, -- Kannada&lt;br /&gt;
	[&#039;ko&#039;] 		= &#039;ko-form&#039;, -- Korean&lt;br /&gt;
	[&#039;lt&#039;] 		= &#039;lt-form&#039;, -- Lithuanian&lt;br /&gt;
	[&#039;lv&#039;] 		= &#039;lv-form&#039;, -- Latvian&lt;br /&gt;
	[&#039;mk&#039;] 		= &#039;en-form&#039;, -- Macedonian&lt;br /&gt;
	[&#039;ml&#039;] 		= &#039;ml-form&#039;, -- Malayalam&lt;br /&gt;
	[&#039;mr&#039;] 		= &#039;mr-form&#039;, -- Marathi&lt;br /&gt;
	[&#039;new&#039;] 	= &#039;new-form&#039;, -- Newari&lt;br /&gt;
	[&#039;nn&#039;] 		= &#039;de-form&#039;, -- Norwegian Nynorsk&lt;br /&gt;
	[&#039;no&#039;] 		= &#039;de-form&#039;, -- Norwegian (bokm欩&lt;br /&gt;
	[&#039;oc&#039;] 		= &#039;oc-form&#039;, -- Occitan&lt;br /&gt;
	[&#039;pa&#039;] 		= &#039;en-form&#039;, -- Punjabi&lt;br /&gt;
	[&#039;pl&#039;] 		= &#039;ru-form&#039;, -- Polish&lt;br /&gt;
	[&#039;pt&#039;] 		= &#039;es-form&#039;, -- Portuguese&lt;br /&gt;
	[&#039;qu&#039;] 		= &#039;qu-form&#039;, -- Quechua based on https://translatewiki.net/wiki/MediaWiki:Pagetriage-info-timestamp-date-format/qu&lt;br /&gt;
	[&#039;qug&#039;] 	= &#039;qug-form&#039;, -- Kichwa based on Template_talk:Date#Kichwa_.5Bqug.5D&lt;br /&gt;
	[&#039;ru&#039;] 		= &#039;ru-form&#039;, -- Russian&lt;br /&gt;
	[&#039;sk&#039;] 		= &#039;cs-form&#039;, -- Slovakian&lt;br /&gt;
	[&#039;sl&#039;] 		= &#039;sl-form&#039;, -- Slovene&lt;br /&gt;
	[&#039;sr&#039;] 		= &#039;hr-form&#039;, -- Serbian&lt;br /&gt;
	[&#039;th&#039;] 		= &#039;th-form&#039;, -- Thai solar calendar&lt;br /&gt;
	[&#039;uk&#039;] 		= &#039;ru-form&#039;, -- Ukrainian&lt;br /&gt;
	[&#039;vi&#039;] 		= &#039;vi-form&#039;, -- Vietnamese&lt;br /&gt;
	[&#039;zh-hans&#039;] 	= &#039;zh-form&#039;, -- Chinese&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
--[[ Date format parameter which will be passed to {{#time:}} parser function. &lt;br /&gt;
  It depends on the language and which parts of the date need to be displayed. &lt;br /&gt;
  Different forms are:&lt;br /&gt;
  * YMDHMS = stands for YYYY:MM:DD, HH:MM:SS format or equivalent&lt;br /&gt;
  * YMDHM  = stands for YYYY:MM:DD, HH:MM format or equivalent&lt;br /&gt;
  * YMD    = stands for YYYY:MM:DD format or equivalent&lt;br /&gt;
  * YM     = stands for YYYY:MM (year-month) format or equivalent&lt;br /&gt;
  * MD     = stands for MM:DD (month-day) format or equivalent&lt;br /&gt;
  * Y      = stands for YYYY (year only) format or equivalent&lt;br /&gt;
  * M      = stands for month name only&lt;br /&gt;
  &lt;br /&gt;
  The left hand side follows encoding used by {{#time}} parser function , &lt;br /&gt;
  see https://www.mediawiki.org/wiki/Help:Extension:ParserFunctions#.23time for documentation.&lt;br /&gt;
	To summerize:&lt;br /&gt;
	 * Y - 4-digit year, like &amp;quot;2017&amp;quot;&lt;br /&gt;
	 * y - 2-digit year, like &amp;quot;17&amp;quot;&lt;br /&gt;
	 * M - An abbreviation of the month name, in the site language, like &amp;quot;Mar&amp;quot;&lt;br /&gt;
	 * F - The full month name in the site language, like &amp;quot;March&amp;quot;&lt;br /&gt;
	 * xg - Output the full month name in the genitive form for site languages that distinguish &lt;br /&gt;
	        between genitive and nominative forms. This option is useful for many Slavic languages &lt;br /&gt;
					like Polish, Russian, Belarusian, Czech, Slovak, Slovene, Ukrainian, etc.&lt;br /&gt;
	 * j - Day of the month, not zero-padded, like &amp;quot;1&amp;quot;&lt;br /&gt;
	 * d - Day of the month, zero-padded, like &amp;quot;01&amp;quot;&lt;br /&gt;
	 * a - &amp;quot;am&amp;quot; during the morning (00:00:00 → 11:59:59), &amp;quot;pm&amp;quot; otherwise (12:00:00 → 23:59:59).&lt;br /&gt;
	 * A - Uppercase version of a above.&lt;br /&gt;
	 * g - Hour in 12-hour format, not zero-padded. &lt;br /&gt;
	 * h - Hour in 12-hour format, zero-padded.&lt;br /&gt;
	 * G - Hour in 24-hour format, not zero-padded. &lt;br /&gt;
	 * H - Hour in 24-hour format, zero-padded. &lt;br /&gt;
	 * i - Minutes past the hour, zero-padded.&lt;br /&gt;
	 * s - Seconds past the minute, zero-padded.&lt;br /&gt;
	 &lt;br /&gt;
  Original set was developed to match the output of the pre-Lua {{date}} template, preserved as {{date/old}}&lt;br /&gt;
]]&lt;br /&gt;
p.DateFormat = {&lt;br /&gt;
	-- day/month/year languages&lt;br /&gt;
	[&#039;en-form&#039;] = {&lt;br /&gt;
		YMDHMS=&#039;j F Y, H:i:s&#039;,		&lt;br /&gt;
		YMDHM =&#039;j F Y, H:i&#039;,		&lt;br /&gt;
		YMD   =&#039;j F Y&#039;,		&lt;br /&gt;
		YM    =&#039;F Y&#039;,		&lt;br /&gt;
		MD    =&#039;j F&#039;,		&lt;br /&gt;
		Y     =&#039;Y&#039;,&lt;br /&gt;
		M     =&#039;F&#039;		&lt;br /&gt;
	},&lt;br /&gt;
	[&#039;de-form&#039;] = {&lt;br /&gt;
		YMDHMS=&#039;j. F Y, H:i:s&#039;,		&lt;br /&gt;
		YMDHM =&#039;j. F Y, H:i&#039;,		&lt;br /&gt;
		YMD   =&#039;j. F Y&#039;,		&lt;br /&gt;
		YM    =&#039;F Y&#039;,		&lt;br /&gt;
		MD    =&#039;j. F&#039;,		&lt;br /&gt;
		Y     =&#039;Y&#039;,&lt;br /&gt;
		M     =&#039;F&#039;&lt;br /&gt;
	},&lt;br /&gt;
	[&#039;hr-form&#039;] = {&lt;br /&gt;
		YMDHMS=&#039;j. F Y., H:i:s&#039;,		&lt;br /&gt;
		YMDHM =&#039;j. F Y., H:i&#039;,		&lt;br /&gt;
		YMD   =&#039;j. F Y.&#039;,		&lt;br /&gt;
		YM    =&#039;F Y.&#039;,		&lt;br /&gt;
		MD    =&#039;j. F&#039;,		&lt;br /&gt;
		Y     =&#039;Y.&#039;,&lt;br /&gt;
		M     =&#039;F&#039;&lt;br /&gt;
	},&lt;br /&gt;
	[&#039;ml-form&#039;] = {&lt;br /&gt;
		YMDHMS=&#039;j F Y, H:i:s&#039;,		&lt;br /&gt;
		YMDHM =&#039;j F Y, H:i&#039;,		&lt;br /&gt;
		YMD   =&#039;j F Y&#039;,		&lt;br /&gt;
		YM    =&#039;F Y&#039;,		&lt;br /&gt;
		MD    =&#039;F j&#039;,		&lt;br /&gt;
		Y     =&#039;Y&#039;,&lt;br /&gt;
		M     =&#039;F&#039;&lt;br /&gt;
	},&lt;br /&gt;
	[&#039;th-form&#039;] = {&lt;br /&gt;
		YMDHMS=&#039;j F &amp;quot;พ.ศ.&amp;quot; xkY, H:i:s&#039;,	&lt;br /&gt;
		YMDHM =&#039;j F &amp;quot;พ.ศ.&amp;quot; xkY, H:i&#039;,	&lt;br /&gt;
		YMD   =&#039;j F &amp;quot;พ.ศ.&amp;quot; xkY&#039;,	&lt;br /&gt;
		YM    =&#039;F &amp;quot;พ.ศ.&amp;quot; xkY&#039;,&lt;br /&gt;
		MD    =&#039;j F&#039;,		&lt;br /&gt;
		Y     =&#039;&amp;quot;พ.ศ.&amp;quot; xkY&#039;,&lt;br /&gt;
		M     =&#039;F&#039;&lt;br /&gt;
	},&lt;br /&gt;
	[&#039;fi-form&#039;] = {&lt;br /&gt;
		YMDHMS=&#039;j. F&amp;quot;ta&amp;quot; Y, H:i:s&#039;,	&lt;br /&gt;
		YMDHM =&#039;j. F&amp;quot;ta&amp;quot; Y, H:i&#039;,	&lt;br /&gt;
		YMD   =&#039;j. F&amp;quot;ta&amp;quot; Y&#039;,	&lt;br /&gt;
		YM    =&#039;F Y&#039;,		&lt;br /&gt;
		MD    =&#039;j. F&amp;quot;ta&amp;quot;&#039;,		&lt;br /&gt;
		Y     =&#039;Y&#039;,&lt;br /&gt;
		M     =&#039;F&#039;&lt;br /&gt;
	},&lt;br /&gt;
	[&#039;es-form&#039;] = {&lt;br /&gt;
		YMDHMS=&#039;j &amp;quot;de&amp;quot; F &amp;quot;de&amp;quot; Y, H:i:s&#039;,	&lt;br /&gt;
		YMDHM =&#039;j &amp;quot;de&amp;quot; F &amp;quot;de&amp;quot; Y, H:i&#039;,	&lt;br /&gt;
		YMD   =&#039;j &amp;quot;de&amp;quot; F &amp;quot;de&amp;quot; Y&#039;,	&lt;br /&gt;
		YM    =&#039;F &amp;quot;de&amp;quot; Y&#039;,		&lt;br /&gt;
		MD    =&#039;j &amp;quot;de&amp;quot; F&#039;,		&lt;br /&gt;
		Y     =&#039;Y&#039;,&lt;br /&gt;
		M     =&#039;F&#039;&lt;br /&gt;
	},&lt;br /&gt;
	[&#039;oc-form&#039;] = {&lt;br /&gt;
		YMDHMS=&#039;j F &amp;quot;de&amp;quot; Y, H:i:s&#039;,	&lt;br /&gt;
		YMDHM =&#039;j F &amp;quot;de&amp;quot; Y, H:i&#039;,	&lt;br /&gt;
		YMD   =&#039;j F &amp;quot;de&amp;quot; Y&#039;,	&lt;br /&gt;
		YM    =&#039;F &amp;quot;de&amp;quot; Y&#039;,		&lt;br /&gt;
		MD    =&#039;j F&#039;,			&lt;br /&gt;
		Y     =&#039;Y&#039;,&lt;br /&gt;
		M     =&#039;F&#039;&lt;br /&gt;
	},&lt;br /&gt;
	[&#039;ia-form&#039;] = {&lt;br /&gt;
		YMDHMS=&#039;j &amp;quot;de&amp;quot; F Y, H:i:s&#039;,	&lt;br /&gt;
		YMDHM =&#039;j &amp;quot;de&amp;quot; F Y, H:i&#039;,	&lt;br /&gt;
		YMD   =&#039;j &amp;quot;de&amp;quot; F Y&#039;,	&lt;br /&gt;
		YM    =&#039;F Y&#039;,		&lt;br /&gt;
		MD    =&#039;j &amp;quot;de&amp;quot; F&#039;,		&lt;br /&gt;
		Y     =&#039;Y&#039;,&lt;br /&gt;
		M     =&#039;F&#039;&lt;br /&gt;
	},&lt;br /&gt;
	[&#039;eo-form&#039;] = {&lt;br /&gt;
		YMDHMS=&#039;&amp;quot;la&amp;quot; j&amp;quot;-a de&amp;quot; F Y, H:i:s&#039;,&lt;br /&gt;
		YMDHM =&#039;&amp;quot;la&amp;quot; j&amp;quot;-a de&amp;quot; F Y, H:i&#039;,&lt;br /&gt;
		YMD   =&#039;&amp;quot;la&amp;quot; j&amp;quot;-a de&amp;quot; F Y&#039;,&lt;br /&gt;
		YM    =&#039;F Y&#039;,		&lt;br /&gt;
		MD    =&#039;&amp;quot;la&amp;quot; j&amp;quot;-a de&amp;quot; F&#039;,	&lt;br /&gt;
		Y     =&#039;Y&#039;,&lt;br /&gt;
		M     =&#039;F&#039;&lt;br /&gt;
	},&lt;br /&gt;
	[&#039;vi-form&#039;] = {&lt;br /&gt;
		YMDHMS=&#039;j F &amp;quot;năm&amp;quot; Y &amp;quot;lúc&amp;quot; H:i:s&#039;,	&lt;br /&gt;
		YMDHM =&#039;j F &amp;quot;năm&amp;quot; Y &amp;quot;lúc&amp;quot; H:i&#039;,	&lt;br /&gt;
		YMD   =&#039;j F &amp;quot;năm&amp;quot; Y&#039;,	&lt;br /&gt;
		YM    =&#039;F &amp;quot;năm&amp;quot; Y&#039;,		&lt;br /&gt;
		MD    =&#039;j F&#039;,		&lt;br /&gt;
		Y     =&#039;Y&#039;,&lt;br /&gt;
		M     =&#039;F&#039;&lt;br /&gt;
	},&lt;br /&gt;
	[&#039;qu-form&#039;] = {&lt;br /&gt;
		YMDHMS=&#039;j &amp;quot;ñiqin&amp;quot; F&amp;quot;pi&amp;quot; Y &amp;quot;watapi&amp;quot;, H:i:s&#039;,	&lt;br /&gt;
		YMDHM =&#039;j &amp;quot;ñiqin&amp;quot; F&amp;quot;pi&amp;quot; Y &amp;quot;watapi&amp;quot;, H:i&#039;,	&lt;br /&gt;
		YMD   =&#039;j &amp;quot;ñiqin&amp;quot; F&amp;quot;pi&amp;quot; Y &amp;quot;watapi&amp;quot;&#039;,	&lt;br /&gt;
		YM    =&#039;F&amp;quot;pi&amp;quot; Y &amp;quot;watapi&amp;quot;&#039;,		&lt;br /&gt;
		MD    =&#039;j &amp;quot;ñiqin&amp;quot; F&amp;quot;pi&amp;quot;&#039;,		&lt;br /&gt;
		Y     =&#039;Y&#039;,&lt;br /&gt;
		M     =&#039;F&#039;&lt;br /&gt;
	},&lt;br /&gt;
	[&#039;qug-form&#039;] = {&lt;br /&gt;
		YMDHMS=&#039;j &amp;quot;niki&amp;quot; F&amp;quot;pi&amp;quot; Y &amp;quot;watapi&amp;quot;, H:i:s&#039;,	&lt;br /&gt;
		YMDHM =&#039;j &amp;quot;niki&amp;quot; F&amp;quot;pi&amp;quot; Y &amp;quot;watapi&amp;quot;, H:i&#039;,	&lt;br /&gt;
		YMD   =&#039;j &amp;quot;niki&amp;quot; F&amp;quot;pi&amp;quot; Y &amp;quot;watapi&amp;quot;&#039;,	&lt;br /&gt;
		YM    =&#039;F&amp;quot;pi&amp;quot; Y &amp;quot;watapi&amp;quot;&#039;,		&lt;br /&gt;
		MD    =&#039;j &amp;quot;niki&amp;quot; F&amp;quot;pi&amp;quot;&#039;,		&lt;br /&gt;
		Y     =&#039;Y&#039;,&lt;br /&gt;
		M     =&#039;F&#039;&lt;br /&gt;
	},&lt;br /&gt;
	[&#039;he-form&#039;] = {&lt;br /&gt;
		YMDHMS=&#039;&amp;quot;&amp;lt;span dir=rtl&amp;gt;&amp;quot;j xg Y&amp;quot;&amp;lt;/span&amp;gt;&amp;quot;, H:i:s&#039;,		&lt;br /&gt;
		YMDHM =&#039;&amp;quot;&amp;lt;span dir=rtl&amp;gt;&amp;quot;j xg Y&amp;quot;&amp;lt;/span&amp;gt;&amp;quot;, H:i&#039;,		&lt;br /&gt;
		YMD   =&#039;&amp;quot;&amp;lt;span dir=rtl&amp;gt;&amp;quot;j xg Y&amp;quot;&amp;lt;/span&amp;gt;&amp;quot;&#039;,		&lt;br /&gt;
		YM    =&#039;&amp;quot;&amp;lt;span dir=rtl&amp;gt;&amp;quot;F Y&amp;quot;&amp;lt;/span&amp;gt;&amp;quot;&#039;,		&lt;br /&gt;
		MD    =&#039;&amp;quot;&amp;lt;span dir=rtl&amp;gt;&amp;quot;j xg&amp;quot;&amp;lt;/span&amp;gt;&amp;quot;&#039;,		&lt;br /&gt;
		Y     =&#039;Y&#039;,&lt;br /&gt;
		M     =&#039;&amp;quot;&amp;lt;span dir=rtl&amp;gt;&amp;quot;F&amp;quot;&amp;lt;/span&amp;gt;&amp;quot;&#039;&lt;br /&gt;
	},&lt;br /&gt;
	&lt;br /&gt;
	-- French and Gallic languages require different form for first day of the month and &lt;br /&gt;
	-- different for the other days&lt;br /&gt;
	[&#039;fr-form&#039;] = {&lt;br /&gt;
		YMDHMS=&#039;j F Y, H:i:s&#039;,		&lt;br /&gt;
		YMDHM =&#039;j F Y, H:i&#039;,		&lt;br /&gt;
		YMD   =&#039;j F Y&#039;,		&lt;br /&gt;
		YM    =&#039;F Y&#039;,		&lt;br /&gt;
		MD    =&#039;j F&#039;,		&lt;br /&gt;
		Y     =&#039;Y&#039;,&lt;br /&gt;
		M     =&#039;F&#039;&lt;br /&gt;
	},&lt;br /&gt;
	[&#039;ga-form&#039;] = {&lt;br /&gt;
		YMDHMS=&#039;j F Y, H:i:s&#039;,		&lt;br /&gt;
		YMDHM =&#039;j F Y, H:i&#039;,		&lt;br /&gt;
		YMD   =&#039;j F Y&#039;,		&lt;br /&gt;
		YM    =&#039;F Y&#039;,		&lt;br /&gt;
		MD    =&#039;j F&#039;,		&lt;br /&gt;
		Y     =&#039;Y&#039;,&lt;br /&gt;
		M     =&#039;F&#039;&lt;br /&gt;
	},&lt;br /&gt;
	[&#039;fr-form1&#039;] = { -- 1st of the month form&lt;br /&gt;
		YMDHMS=&#039;j&amp;quot;&amp;lt;sup&amp;gt;er&amp;lt;/sup&amp;gt;&amp;quot; F Y, H:i:s&#039;, &lt;br /&gt;
		YMDHM =&#039;j&amp;quot;&amp;lt;sup&amp;gt;er&amp;lt;/sup&amp;gt;&amp;quot; F Y, H:i&#039;, &lt;br /&gt;
		YMD   =&#039;j&amp;quot;&amp;lt;sup&amp;gt;er&amp;lt;/sup&amp;gt;&amp;quot; F Y&#039;, &lt;br /&gt;
		YM    =&#039;F Y&#039;, 	&lt;br /&gt;
		MD    =&#039;j&amp;quot;&amp;lt;sup&amp;gt;er&amp;lt;/sup&amp;gt;&amp;quot; F&#039;, &lt;br /&gt;
		Y     =&#039;Y&#039;,&lt;br /&gt;
		M     =&#039;F&#039;&lt;br /&gt;
	},&lt;br /&gt;
	[&#039;ga-form1&#039;] = { -- 1st of the month form&lt;br /&gt;
		YMDHMS=&#039;j&amp;quot;&amp;lt;sup&amp;gt;ú&amp;lt;/sup&amp;gt;&amp;quot; F Y, H:i:s&#039;,  &lt;br /&gt;
		YMDHM =&#039;j&amp;quot;&amp;lt;sup&amp;gt;ú&amp;lt;/sup&amp;gt;&amp;quot; F Y, H:i&#039;,  &lt;br /&gt;
		YMD   =&#039;j&amp;quot;&amp;lt;sup&amp;gt;ú&amp;lt;/sup&amp;gt;&amp;quot; F Y&#039;,  &lt;br /&gt;
		YM    =&#039;F Y&#039;, 	&lt;br /&gt;
		MD    =&#039;j&amp;quot;&amp;lt;sup&amp;gt;ú&amp;lt;/sup&amp;gt;&amp;quot; F&#039;,  &lt;br /&gt;
		Y     =&#039;Y&#039;,&lt;br /&gt;
		M     =&#039;F&#039;&lt;br /&gt;
	},&lt;br /&gt;
		&lt;br /&gt;
	-- day/month/year Slavic languages&lt;br /&gt;
	[&#039;ru-form&#039;] = {&lt;br /&gt;
		YMDHMS=&#039;j xg Y, H:i:s&#039;,		&lt;br /&gt;
		YMDHM =&#039;j xg Y, H:i&#039;,		&lt;br /&gt;
		YMD   =&#039;j xg Y&#039;,		&lt;br /&gt;
		YM    =&#039;F Y&#039;,		&lt;br /&gt;
		MD    =&#039;j xg&#039;,		&lt;br /&gt;
		Y     =&#039;Y&#039;,&lt;br /&gt;
		M     =&#039;F&#039;&lt;br /&gt;
	},&lt;br /&gt;
	[&#039;cs-form&#039;] = {&lt;br /&gt;
		YMDHMS=&#039;j. xg Y, H:i:s&#039;,		&lt;br /&gt;
		YMDHM =&#039;j. xg Y, H:i&#039;,		&lt;br /&gt;
		YMD   =&#039;j. xg Y&#039;,		&lt;br /&gt;
		YM    =&#039;F Y&#039;,		&lt;br /&gt;
		MD    =&#039;j. xg&#039;,		&lt;br /&gt;
		Y     =&#039;Y&#039;,&lt;br /&gt;
		M     =&#039;F&#039;&lt;br /&gt;
	},&lt;br /&gt;
	[&#039;sl-form&#039;] = {&lt;br /&gt;
		YMDHMS=&#039;j. xg Y &amp;quot;ob&amp;quot; H:i:s&#039;,	&lt;br /&gt;
		YMDHM =&#039;j. xg Y &amp;quot;ob&amp;quot; H:i&#039;,	&lt;br /&gt;
		YMD   =&#039;j. xg Y&#039;,		&lt;br /&gt;
		YM    =&#039;F Y&#039;,		&lt;br /&gt;
		MD    =&#039;j. xg&#039;,		&lt;br /&gt;
		Y     =&#039;Y&#039;,&lt;br /&gt;
		M     =&#039;F&#039;&lt;br /&gt;
	},&lt;br /&gt;
		&lt;br /&gt;
	-- year/month/day languages&lt;br /&gt;
	[&#039;zh-form&#039;] = {&lt;br /&gt;
		YMDHMS=&#039;Y年Fj日, H:i:s&#039;,		&lt;br /&gt;
		YMDHM =&#039;Y年Fj日, H:i&#039;,		&lt;br /&gt;
		YMD   =&#039;Y年Fj日&#039;,		&lt;br /&gt;
		YM    =&#039;Y年F&#039;,		&lt;br /&gt;
		MD    =&#039;Fj日&#039;,		&lt;br /&gt;
		Y     =&#039;Y年&#039;,&lt;br /&gt;
		M     =&#039;F&#039;&lt;br /&gt;
	},&lt;br /&gt;
	[&#039;ko-form&#039;] = {&lt;br /&gt;
		YMDHMS=&#039;Y년 F j일, H:i:s&#039;,	&lt;br /&gt;
		YMDHM =&#039;Y년 F j일, H:i&#039;,		&lt;br /&gt;
		YMD   =&#039;Y년 F j일&#039;,		&lt;br /&gt;
		YM    =&#039;Y년 F&#039;,		&lt;br /&gt;
		MD    =&#039;F j일&#039;,		&lt;br /&gt;
		Y     =&#039;Y년&#039;,&lt;br /&gt;
		M     =&#039;F&#039;&lt;br /&gt;
	},&lt;br /&gt;
	[&#039;hu-form&#039;] = {&lt;br /&gt;
		YMDHMS=&#039;Y. F j., H:i:s&#039;,		&lt;br /&gt;
		YMDHM =&#039;Y. F j., H:i&#039;,		&lt;br /&gt;
		YMD   =&#039;Y. F j.&#039;,		&lt;br /&gt;
		YM    =&#039;Y. F&#039;,		&lt;br /&gt;
		MD    =&#039;F j.&#039;,		&lt;br /&gt;
		Y     =&#039;Y&#039;,&lt;br /&gt;
		M     =&#039;F&#039;&lt;br /&gt;
	},&lt;br /&gt;
	[&#039;lt-form&#039;] = {&lt;br /&gt;
		YMDHMS=&#039;Y &amp;quot;m&amp;quot;. F j &amp;quot;d&amp;quot;., H:i:s&#039;,	&lt;br /&gt;
		YMDHM =&#039;Y &amp;quot;m&amp;quot;. F j &amp;quot;d&amp;quot;., H:i&#039;,	&lt;br /&gt;
		YMD   =&#039;Y &amp;quot;m&amp;quot;. F j &amp;quot;d&amp;quot;.&#039;,	&lt;br /&gt;
		YM    =&#039;Y &amp;quot;m&amp;quot;. F&#039;,		&lt;br /&gt;
		MD    =&#039;F j &amp;quot;d&amp;quot;.&#039;,		&lt;br /&gt;
		Y     =&#039;Y &amp;quot;m&amp;quot;.&#039;,&lt;br /&gt;
		M     =&#039;F&#039;&lt;br /&gt;
	},&lt;br /&gt;
	[&#039;eu-form&#039;] = {&lt;br /&gt;
		YMDHMS=&#039;Y&amp;quot;ko&amp;quot; F&amp;quot;ren&amp;quot; j&amp;quot;a&amp;quot;, H:i:s&#039;,		&lt;br /&gt;
		YMDHM =&#039;Y&amp;quot;ko&amp;quot; F&amp;quot;ren&amp;quot; j&amp;quot;a&amp;quot;, H:i&#039;,		&lt;br /&gt;
		YMD   =&#039;Y&amp;quot;ko&amp;quot; F&amp;quot;ren&amp;quot; j&amp;quot;a&amp;quot;&#039;,		&lt;br /&gt;
		YM    =&#039;Y&amp;quot;ko&amp;quot; F&#039;,		&lt;br /&gt;
		MD    =&#039;F&amp;quot;ren&amp;quot; j&amp;quot;a&amp;quot;&#039;,		&lt;br /&gt;
		Y     =&#039;Y&#039;,&lt;br /&gt;
		M     =&#039;F&#039;&lt;br /&gt;
	},&lt;br /&gt;
	[&#039;eu-form01&#039;] = { -- 1st and 21st of the month  uses different form&lt;br /&gt;
                YMDHMS=&#039;Y&amp;quot;ko&amp;quot; F&amp;quot;ren&amp;quot; j&amp;quot;ea&amp;quot;, H:i:s&#039;,		&lt;br /&gt;
		YMDHM =&#039;Y&amp;quot;ko&amp;quot; F&amp;quot;ren&amp;quot; j&amp;quot;ea&amp;quot;, H:i&#039;,		&lt;br /&gt;
		YMD   =&#039;Y&amp;quot;ko&amp;quot; F&amp;quot;ren&amp;quot; j&amp;quot;ea&amp;quot;&#039;,		&lt;br /&gt;
		YM    =&#039;Y&amp;quot;ko&amp;quot; F&#039;,		&lt;br /&gt;
		MD    =&#039;F&amp;quot;ren&amp;quot; j&amp;quot;ea&amp;quot;&#039;,		&lt;br /&gt;
		Y     =&#039;Y&#039;,&lt;br /&gt;
		M     =&#039;F&#039;&lt;br /&gt;
	},&lt;br /&gt;
	[&#039;eu-form11&#039;] = { -- 11th and 31st of the month  uses different form&lt;br /&gt;
                YMDHMS=&#039;Y&amp;quot;ko&amp;quot; F&amp;quot;ren&amp;quot; j, H:i:s&#039;,		&lt;br /&gt;
		YMDHM =&#039;Y&amp;quot;ko&amp;quot; F&amp;quot;ren&amp;quot; j, H:i&#039;,		&lt;br /&gt;
		YMD   =&#039;Y&amp;quot;ko&amp;quot; F&amp;quot;ren&amp;quot; j&#039;,		&lt;br /&gt;
		YM    =&#039;Y&amp;quot;ko&amp;quot; F&#039;,		&lt;br /&gt;
		MD    =&#039;F&amp;quot;ren&amp;quot; j&#039;,		&lt;br /&gt;
		Y     =&#039;Y&#039;,&lt;br /&gt;
		M     =&#039;F&#039;&lt;br /&gt;
	},&lt;br /&gt;
	[&#039;ce-form&#039;] = {&lt;br /&gt;
		YMDHMS=&#039;Y &amp;quot;шаран&amp;quot; j F, H:i:s&#039;,	&lt;br /&gt;
		YMDHM =&#039;Y &amp;quot;шаран&amp;quot; j F, H:i&#039;,	&lt;br /&gt;
		YMD   =&#039;Y &amp;quot;шаран&amp;quot; j F&#039;,	&lt;br /&gt;
		YM    =&#039;Y &amp;quot;шаран&amp;quot; F&#039;,	&lt;br /&gt;
		MD    =&#039;j F&#039;,		&lt;br /&gt;
		Y     =&#039;Y &amp;quot;шо&amp;quot;&#039;,&lt;br /&gt;
		M     =&#039;F&#039;&lt;br /&gt;
	},&lt;br /&gt;
			&lt;br /&gt;
	-- year/day/month languages&lt;br /&gt;
	[&#039;lv-form&#039;] = {&lt;br /&gt;
		YMDHMS=&#039;Y&amp;quot;. gada&amp;quot; j. F, H:i:s&#039;,	&lt;br /&gt;
		YMDHM =&#039;Y&amp;quot;. gada&amp;quot; j. F, H:i&#039;,	&lt;br /&gt;
		YMD   =&#039;Y&amp;quot;. gada&amp;quot; j. F&#039;,	&lt;br /&gt;
		YM    =&#039;Y&amp;quot;. gada&amp;quot; F&#039;,	&lt;br /&gt;
		MD    =&#039;j. F&#039;,		&lt;br /&gt;
		Y     =&#039;Y&amp;quot;. gada&amp;quot;&#039;,&lt;br /&gt;
		M     =&#039;F&#039;&lt;br /&gt;
	},&lt;br /&gt;
&lt;br /&gt;
	-- month/day/year languages&lt;br /&gt;
	[&#039;kn-form&#039;] = {&lt;br /&gt;
		YMDHMS=&#039;F j, Y, H:i:s&#039;,		&lt;br /&gt;
		YMDHM =&#039;F j, Y, H:i&#039;,		&lt;br /&gt;
		YMD   =&#039;F j, Y&#039;,		&lt;br /&gt;
		YM    =&#039;F, Y&#039;,		&lt;br /&gt;
		MD    =&#039;F j&#039;,		&lt;br /&gt;
		Y     =&#039;Y&#039;,&lt;br /&gt;
		M     =&#039;F&#039;&lt;br /&gt;
	}, &lt;br /&gt;
	[&#039;bpy-form&#039;]= {&lt;br /&gt;
		YMDHMS=&#039;F j, মারি Y, H:i:s&#039;,	&lt;br /&gt;
		YMDHM =&#039;F j, মারি Y, H:i&#039;,		&lt;br /&gt;
		YMD   =&#039;F j, মারি Y&#039;,	&lt;br /&gt;
		YM    =&#039;F, মারি Y&#039;,		&lt;br /&gt;
		MD    =&#039;F j&#039;,		&lt;br /&gt;
		Y     =&#039;মারি Y&#039;,&lt;br /&gt;
		M     =&#039;F&#039;&lt;br /&gt;
	},&lt;br /&gt;
	[&#039;mr-form&#039;] = {&lt;br /&gt;
		YMDHMS=&#039;F j, इ.स. Y, H:i:s&#039;,	&lt;br /&gt;
		YMDHM =&#039;F j, इ.स. Y, H:i&#039;,	&lt;br /&gt;
		YMD   =&#039;F j, इ.स. Y&#039;,	&lt;br /&gt;
		YM    =&#039;F, इ.स. Y&#039;,		&lt;br /&gt;
		MD    =&#039;F j&#039;,		&lt;br /&gt;
		Y     =&#039;इ.स. Y&#039;,&lt;br /&gt;
		M     =&#039;F&#039;&lt;br /&gt;
	},&lt;br /&gt;
	[&#039;new-form&#039;]= {&lt;br /&gt;
		YMDHMS=&#039;F j, ई सं  Y, H:i:s&#039;,	&lt;br /&gt;
		YMDHM =&#039;F j, ई सं  Y, H:i&#039;,	&lt;br /&gt;
		YMD   =&#039;F j, ई सं  Y&#039;,	&lt;br /&gt;
		YM    =&#039;F, ई सं  Y&#039;,		&lt;br /&gt;
		MD    =&#039;F j&#039;,		&lt;br /&gt;
		Y     =&#039;ई सं Y&#039;,&lt;br /&gt;
		M     =&#039;F&#039;&lt;br /&gt;
	},&lt;br /&gt;
}&lt;br /&gt;
 &lt;br /&gt;
return p&lt;/div&gt;</summary>
		<author><name>Aron.hives@edubase.net</name></author>
	</entry>
	<entry>
		<id>https://edubase.wiki/index.php?title=Module:I18n/complex_date&amp;diff=27348</id>
		<title>Module:I18n/complex date</title>
		<link rel="alternate" type="text/html" href="https://edubase.wiki/index.php?title=Module:I18n/complex_date&amp;diff=27348"/>
		<updated>2018-11-12T22:47:31Z</updated>

		<summary type="html">&lt;p&gt;Aron.hives@edubase.net: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;local Ordinal    = require(&#039;Module:Ordinal&#039;)._Ordinal&lt;br /&gt;
local Roman      = require(&#039;Module:Roman&#039;)._Numeral&lt;br /&gt;
&lt;br /&gt;
local p = {} &lt;br /&gt;
&lt;br /&gt;
-- ===  Helper functions ====================================================&lt;br /&gt;
-- form of French &amp;quot;of&amp;quot; based on &amp;quot;precision&amp;quot;, which is wikibase compatible date precision format: &lt;br /&gt;
-- 6=millennium, 7=century, 8=decade, 9=year, 10=month, 11=day&lt;br /&gt;
--             1    2    3    4    5    mill  cent  deca  year  month  day&lt;br /&gt;
local frOf = {&#039;du&#039;,&#039;du&#039;,&#039;du&#039;,&#039;du&#039;,&#039;du&#039;, &#039;du&#039;, &#039;du&#039;, &#039;de&#039;, &#039;de&#039;, &#039;de&#039;, &#039;du&#039;}&lt;br /&gt;
&lt;br /&gt;
function decYear(state,lang,case)&lt;br /&gt;
--Declension of word &amp;quot;year&amp;quot; in several languages&lt;br /&gt;
if state.precision == 9 then&lt;br /&gt;
	yearCase = {&lt;br /&gt;
		fi={xxx=&#039;vuosien&#039;, gen=&#039;vuoden&#039;, ill=&#039;vuoteen&#039;, ptv=&#039;vuotta&#039;, ela=&#039;vuodesta&#039;, ine=&#039;vuonna&#039;},&lt;br /&gt;
		sl={insP=&#039;letoma&#039;, ins=&#039;letom&#039;, gen=&#039;leta&#039;, loc=&#039;letu&#039;},&lt;br /&gt;
		hsb={insP=&#039;lětami&#039;, ins=&#039;lětom&#039;, gen=&#039;lěta&#039;, loc=&#039;lěće&#039;}&lt;br /&gt;
	}&lt;br /&gt;
	return yearCase[lang][case] .. &#039; &#039;&lt;br /&gt;
else&lt;br /&gt;
	return &#039;&#039;&lt;br /&gt;
end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function decCentury(lang,case)&lt;br /&gt;
--Declension of word &amp;quot;century&amp;quot; in several languages&lt;br /&gt;
	centuryCase = {&lt;br /&gt;
		pl={nom=&#039;wiek&#039;, gen=&#039;wieku&#039;, ins=&#039;wiekiem&#039;, loc=&#039;wieku&#039;, default = &#039;wiek&#039;},&lt;br /&gt;
		hsb={nom=&#039;lětstotk&#039;, gen=&#039;lětstotka&#039;, ins=&#039;lětstotkom&#039;, loc=&#039;lětstotku&#039;, default = &#039;lětstotk&#039;}&lt;br /&gt;
	}&lt;br /&gt;
	return centuryCase[lang][case] or centuryCase[lang][&#039;default&#039;]&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function decMillennium(lang,case)&lt;br /&gt;
--Declension of word &amp;quot;century&amp;quot; in several languages&lt;br /&gt;
	millenniumCase = {&lt;br /&gt;
		pl={nom=&#039;tysiąclecie&#039;, gen=&#039;tysiąclecia&#039;, ins=&#039;tysiącleciem&#039;, loc=&#039;tysiącleciu&#039;, default = &#039;tysiąclecie&#039;},&lt;br /&gt;
		hsb={nom=&#039;lěttysac&#039;, gen=&#039;lěttysaca&#039;, ins=&#039;lěttysacom&#039;, loc=&#039;lěttysacu&#039;, default = &#039;lěttysac&#039;}&lt;br /&gt;
	}&lt;br /&gt;
	return millenniumCase[lang][case] or millenniumCase[lang][&#039;default&#039;]&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
 Multiple formats are possible:&lt;br /&gt;
  1) string with key words &amp;quot;$date1&amp;quot; and &amp;quot;$date2&amp;quot; which will be replaced later by the date strings&lt;br /&gt;
  2) function which can be used to create output string&lt;br /&gt;
    * Function INPUTS: &lt;br /&gt;
	  - date1 and date2 string with date strings. &amp;quot;$date1&amp;quot; and &amp;quot;$date2&amp;quot; can also be used which will be replaced latter&lt;br /&gt;
	  - state is a table with full description of the phrase we are trying to construct. It includes state.precision1 (and 2) &lt;br /&gt;
		which is wikibase compatible date precision format: 6=millennium, 7=century, 8=decade, 9=year, 10=month, 11=day&lt;br /&gt;
  3) table with following fields:&lt;br /&gt;
    * table[1] is either string or a function&lt;br /&gt;
    * table.case is a 2 element table with Grammatical cases used by given language to alter &lt;br /&gt;
	    month name or other adjective related to date # 1 and 2&lt;br /&gt;
]]&lt;br /&gt;
p.Translations = {&lt;br /&gt;
&lt;br /&gt;
	-- ==========================================&lt;br /&gt;
	-- === Two date phrases =====================&lt;br /&gt;
	-- ==========================================&lt;br /&gt;
	[&#039;from-until&#039;] = {&lt;br /&gt;
		nDates = 2, &lt;br /&gt;
		ar=&#039;من $date1 إلى $date2&#039;,&lt;br /&gt;
		[&#039;be-tarask&#039;]={&#039;з $date1 да $date2&#039;, case={&#039;gen&#039;,&#039;gen&#039;}},&lt;br /&gt;
		bn=&#039;$date1 থেকে $date2 পর্যন্ত&#039;,&lt;br /&gt;
		ca=&#039;$date1 fins $date2&#039;,&lt;br /&gt;
		cs=&#039;$date1 až $date2&#039;,&lt;br /&gt;
		da=&#039;fra $date1 til $date2&#039;,&lt;br /&gt;
		de=&#039;$date1 bis $date2&#039;,&lt;br /&gt;
		el=&#039;από $date1 έως $date2&#039;,&lt;br /&gt;
		en=&#039;from $date1 until $date2&#039;,&lt;br /&gt;
		[&#039;en-gb&#039;]=&#039;from $date1 until $date2&#039;,&lt;br /&gt;
		[&#039;en-ca&#039;]=&#039;from $date1 until $date2&#039;,&lt;br /&gt;
		eo=&#039;de $date1 al $date2&#039;,&lt;br /&gt;
		es=&#039;de $date1 a $date2&#039;,&lt;br /&gt;
		et=&#039;$date1 kuni $date2&#039;,&lt;br /&gt;
		fa=&#039;از $date1 تا $date2&#039;,&lt;br /&gt;
		fi=&#039;$date1–$date2&#039;, -- välisenä aikana&lt;br /&gt;
		fr=function(date1, date2, state) -- could actually be better should be &amp;quot;d&#039;octobre à mars 2013&#039; not &amp;quot;de octore 2013 à mars 2013&amp;quot; &lt;br /&gt;
			if state.precision &amp;gt; 10 then -- precision &amp;gt; month&lt;br /&gt;
				return &#039;du $date1 au $date2&#039;&lt;br /&gt;
			else				-- &amp;quot;DE septebmbre&amp;quot; / &amp;quot;D&#039;octobre&amp;quot;&lt;br /&gt;
				return require(&amp;quot;Module:Linguistic&amp;quot;).of(date1, &#039;fr&#039;) .. &amp;quot; à $date2&amp;quot;&lt;br /&gt;
			end&lt;br /&gt;
		end,&lt;br /&gt;
		gl=&#039;de $date1 a $date2&#039;, --Template:From until used &#039;desde $date1 ata $date2&#039;&lt;br /&gt;
		he=&#039;מ- $date1 עד $date2&#039;,&lt;br /&gt;
		hr=&#039;od $date1 do $date2&#039;,&lt;br /&gt;
		hsb={&#039;wot $date1 do $date2&#039;, case={&#039;gen&#039;,&#039;gen&#039;}},&lt;br /&gt;
		hu=&#039;$date1 – $date2&#039;,&lt;br /&gt;
		it=&#039;dal $date1 al $date2&#039;,&lt;br /&gt;
		ja=&#039;$date1から$date2まで&#039;,&lt;br /&gt;
		mk=&#039;од $date1 до $date2&#039;,&lt;br /&gt;
		ml=&#039;$date1 മുതൽ $date2 വരെ&#039;,&lt;br /&gt;
		nb=&#039;fra $date1 til $date2&#039;,&lt;br /&gt;
		nds=&#039;$date1 bet $date2&#039;,&lt;br /&gt;
		nn=&#039;fra $date1 til $date2&#039;,&lt;br /&gt;
		nl=&#039;$date1 tot $date2&#039;,&lt;br /&gt;
		no=&#039;fra $date1 til $date2&#039;,&lt;br /&gt;
		pl={&#039;od $date1 do $date2&#039;, case={&#039;gen&#039;,&#039;gen&#039;}},&lt;br /&gt;
		ro=&#039;din $date1 până în $date2&#039;,&lt;br /&gt;
		pt=&#039;de $date1 a $date2&#039;,&lt;br /&gt;
		qu=&amp;quot;$date1 p&#039;unchawmanta $date2 p\&#039;unchawkama&amp;quot;,&lt;br /&gt;
		ru={&#039;с $date1 по $date2&#039;, case={&#039;gen&#039;,&#039;gen&#039;}},&lt;br /&gt;
		sk={&#039;od $date1 do $date2&#039;, case={&#039;gen&#039;,&#039;gen&#039;}},&lt;br /&gt;
		sl={&#039;od $date1 do $date2&#039;, case={&#039;gen&#039;,&#039;gen&#039;}},&lt;br /&gt;
		sv=&#039;från $date1 till $date2&#039;,&lt;br /&gt;
		uk={&#039;з $date1 до $date2&#039;, case={&#039;gen&#039;,&#039;gen&#039;}},&lt;br /&gt;
		ur=&#039;از $date1 تا $date2&#039;,&lt;br /&gt;
		vi=&#039;từ $date1 đến $date2&#039;,&lt;br /&gt;
		[&#039;zh-hans&#039;]=&#039;从$date1到$date2&#039;,&lt;br /&gt;
		[&#039;zh-hant&#039;]=&#039;從$date1到$date2&#039;,&lt;br /&gt;
		--[&#039;default&#039;]=&#039;{{Please translate|$date1-$date2|Module:I18n/complex date}}&#039;,&lt;br /&gt;
		default=&#039;&amp;lt;span style=&amp;quot;color:red&amp;quot;&amp;gt;$date1 - $date2&amp;lt;/span&amp;gt;&#039;,&lt;br /&gt;
	},&lt;br /&gt;
&lt;br /&gt;
	[&#039;between&#039;]={&lt;br /&gt;
		nDates = 2,&lt;br /&gt;
		ar=&#039;بين $date1 و $date2&#039;,&lt;br /&gt;
		[&#039;be-tarask&#039;]={&#039;між $date1 і $date2&#039;, case={&#039;ins&#039;,&#039;ins&#039;}},&lt;br /&gt;
		bn=&#039;$date1 এবং $date2-এর মাঝামাঝি&#039;,&lt;br /&gt;
		ca=&#039;entre $date1 i $date2&#039;,&lt;br /&gt;
		cs={&#039;mezi $date1 a $date2&#039;, case={&#039;ins&#039;,&#039;ins&#039;}},&lt;br /&gt;
		da=&#039;mellem $date1 og $date2&#039;,&lt;br /&gt;
		de=&#039;zwischen $date1 und $date2&#039;,&lt;br /&gt;
		el=&#039;μεταξύ $date1 και $date2&#039;,&lt;br /&gt;
		en=&#039;between $date1 and $date2&#039;,&lt;br /&gt;
		[&#039;en-gb&#039;]=&#039;between $date1 and $date2&#039;,&lt;br /&gt;
		[&#039;en-ca&#039;]=&#039;between $date1 and $date2&#039;,&lt;br /&gt;
		eo=&#039;inter $date1 kaj $date2&#039;,&lt;br /&gt;
		es=&#039;entre $date1 y $date2&#039;,&lt;br /&gt;
		et=&#039;$date1 ja $date2 vahel&#039;,&lt;br /&gt;
		fa=&#039;بین $date1 و $date2&#039;,&lt;br /&gt;
		fi={function(date1, date2, state) return decYear(state,&#039;fi&#039;,&#039;xxx&#039;) .. &#039;$date1 ja $date2 välisenä aikana&#039;	end, case={&#039;gen&#039;,&#039;gen&#039;}},&lt;br /&gt;
		fr=&#039;entre $date1 et $date2&#039;,&lt;br /&gt;
		gl=&#039;entre $date1 e $date2&#039;,&lt;br /&gt;
		he=&#039;בין $date1 ו- $date2&#039;,&lt;br /&gt;
		hr=&#039;između $date1 i $date2&#039;,&lt;br /&gt;
		hsb={&#039;mjez $date1 a $date2&#039;, case={&#039;ins&#039;,&#039;ins&#039;}},&lt;br /&gt;
		hu=&#039;$date1 és $date2 között&#039;,&lt;br /&gt;
		hi=&#039;$date1 और $date2 के बीच&#039;,&lt;br /&gt;
		it=&#039;tra il $date1 e il $date2&#039;,&lt;br /&gt;
		ja=&#039;$date1と$date2の間&#039;,&lt;br /&gt;
		mk=&#039;помеѓу $date1 и $date2&#039;,&lt;br /&gt;
		ml=&#039;$date1, $date2 എന്നിവയ്ക്കിടയ്ക്ക്&#039;,&lt;br /&gt;
		nb=&#039;mellom $date1 og $date2&#039;,&lt;br /&gt;
		nds=&#039;twischen $date1 un $date2&#039;,&lt;br /&gt;
		nn=&#039;mellom $date1 og $date2&#039;,&lt;br /&gt;
		nl=&#039;tussen $date1 en $date2&#039;,&lt;br /&gt;
		no=&#039;mellom $date1 og $date2&#039;,&lt;br /&gt;
		pl={&#039;między $date1 a $date2&#039;, case={&#039;ins&#039;,&#039;ins&#039;}},&lt;br /&gt;
		ro=&#039;între $date1 și $date2&#039;,&lt;br /&gt;
		pt=&#039;entre $date1 e $date2&#039;,&lt;br /&gt;
		qu=&amp;quot;$date1 p&#039;unchawpa $date2 p&#039;unchawpapas chawpin&amp;quot;,&lt;br /&gt;
		ru={&#039;между $date1 и $date2&#039;, case={&#039;ins&#039;,&#039;ins&#039;}},&lt;br /&gt;
		sk={&#039;medzi $date1 a $date2&#039;, case={&#039;ins&#039;,&#039;ins&#039;}},&lt;br /&gt;
		sl={function(date1, date2, state) return &#039;med &#039; .. decYear(state,&#039;sl&#039;,&#039;insP&#039;) .. &#039;$date1 in $date2&#039;	end, case={&#039;ins&#039;,&#039;ins&#039;}},&lt;br /&gt;
		sv=&#039;mellan $date1 och $date2&#039;,&lt;br /&gt;
		uk={&#039;між $date1 та $date2&#039;, case={&#039;ins&#039;,&#039;ins&#039;}},&lt;br /&gt;
		ur=&#039;بین $date1 و $date2&#039;,&lt;br /&gt;
		vec=&#039;tra el $date1 e el $date2&#039;,&lt;br /&gt;
		vi=&#039;giữa $date1 và $date2&#039;,&lt;br /&gt;
		[&#039;zh-hans&#039;]=&#039;在$date1到$date2之间&#039;,&lt;br /&gt;
		[&#039;zh-hant&#039;]=&#039;在$date1到$date2之間&#039;,&lt;br /&gt;
		--default=&#039;{{Please translate|$date1-$date2|Module:I18n/complex date}}&#039;,&lt;br /&gt;
		default=&#039;&amp;lt;span style=&amp;quot;color:red&amp;quot;&amp;gt;$date1 - $date2&amp;lt;/span&amp;gt;&#039;,&lt;br /&gt;
	},&lt;br /&gt;
&lt;br /&gt;
	[&#039;or&#039;] = {&lt;br /&gt;
		nDates = 2,&lt;br /&gt;
		ar=&#039;$date1 أو $date2&#039;,&lt;br /&gt;
		[&#039;be-tarask&#039;]=&#039;$date1 ці $date2&#039;,&lt;br /&gt;
		bn=&#039;$date1 অথবা $date2&#039;,&lt;br /&gt;
		ca=&#039;$date1 o $date2&#039;,&lt;br /&gt;
		cs=&#039;$date1 nebo $date2&#039;,&lt;br /&gt;
		da=&#039;$date1 eller $date2&#039;,&lt;br /&gt;
		de=&#039;$date1 oder $date2&#039;,&lt;br /&gt;
		el=&#039;$date1 ή $date2&#039;,&lt;br /&gt;
		en=&#039;$date1 or $date2&#039;,&lt;br /&gt;
		[&#039;en-gb&#039;]=&#039;$date1 or $date2&#039;,&lt;br /&gt;
		[&#039;en-ca&#039;]=&#039;$date1 or $date2&#039;,&lt;br /&gt;
		eo=&#039;$date1 aŭ $date2&#039;,&lt;br /&gt;
		es=&#039;$date1 o $date2&#039;,&lt;br /&gt;
		et=&#039;$date1 või $date2&#039;,&lt;br /&gt;
		fa=&#039;$date1 یا $date2&#039;,&lt;br /&gt;
		fi=&#039;$date1 tai $date2&#039;,&lt;br /&gt;
		fr=&#039;$date1 ou $date2&#039;,&lt;br /&gt;
		gl=&#039;$date1 ou $date2&#039;,&lt;br /&gt;
		he=&#039;$date1 או $date2&#039;,&lt;br /&gt;
		hr=&#039;$date1 ili $date2&#039;,&lt;br /&gt;
		hsb=&#039;$date1 abo $date2&#039;,&lt;br /&gt;
		hu=&#039;$date1 vagy $date2&#039;,&lt;br /&gt;
		it=&#039;$date1 o $date2&#039;,&lt;br /&gt;
		ja=&#039;$date1または$date2&#039;,&lt;br /&gt;
		mk=&#039;$date1 или $date2&#039;,&lt;br /&gt;
		ml=&#039;$date1 അഥവാ $date2&#039;,&lt;br /&gt;
		nb=&#039;$date1 eller $date2&#039;,&lt;br /&gt;
		nn=&#039;$date1 eller $date2&#039;,&lt;br /&gt;
		nds=&#039;$date1 oder $date2&#039;,&lt;br /&gt;
		nl=&#039;$date1 of $date2&#039;,&lt;br /&gt;
		no=&#039;$date1 eller $date2&#039;,&lt;br /&gt;
		pl=&#039;$date1 lub $date2&#039;,&lt;br /&gt;
		pt=&#039;$date1 ou $date2&#039;,&lt;br /&gt;
		qu=&#039;$date1 icha $date2&#039;,&lt;br /&gt;
		ro=&#039;$date1 sau $date2&#039;,&lt;br /&gt;
		ru=&#039;$date1 или $date2&#039;,&lt;br /&gt;
		sk=&#039;$date1 alebo $date2&#039;,&lt;br /&gt;
		sl=&#039;$date1 ali $date2&#039;,&lt;br /&gt;
		sv=&#039;$date1 eller $date2&#039;,&lt;br /&gt;
		uk=&#039;$date1 або $date2&#039;,&lt;br /&gt;
		ur=&#039;$date1 یا $date2&#039;,&lt;br /&gt;
		th=&#039;$date1 หรือ $date2&#039;,&lt;br /&gt;
		vi=&#039;$date1 hoặc $date2&#039;,&lt;br /&gt;
		[&#039;zh-hans&#039;]=&#039;$date1或$date2&#039;,&lt;br /&gt;
		[&#039;zh-hant&#039;]=&#039;$date1或$date2&#039;,&lt;br /&gt;
		default=function(date1, date2, state) return require(&amp;quot;Module:Linguistic&amp;quot;).conj({date1, date2}, state.lang, &#039;or&#039;) end,&lt;br /&gt;
	}, &lt;br /&gt;
&lt;br /&gt;
	[&#039;and&#039;] = {&lt;br /&gt;
		nDates = 2,&lt;br /&gt;
		ar=&#039;$date1 و $date2&#039;,&lt;br /&gt;
		[&#039;be-tarask&#039;]=&#039;$date1 і $date2&#039;,&lt;br /&gt;
		bn=&#039;$date1 এবং $date2&#039;,&lt;br /&gt;
		ca=&#039;$date1 i $date2&#039;,&lt;br /&gt;
		cs=&#039;$date1 a $date2&#039;,&lt;br /&gt;
		da=&#039;$date1 og $date2&#039;,&lt;br /&gt;
		de=&#039;$date1 und $date2&#039;,&lt;br /&gt;
		el=&#039;$date1 και $date2&#039;,&lt;br /&gt;
		en=&#039;$date1 and $date2&#039;,&lt;br /&gt;
		[&#039;en-gb&#039;]=&#039;$date1 and $date2&#039;,&lt;br /&gt;
		[&#039;en-ca&#039;]=&#039;$date1 and $date2&#039;,&lt;br /&gt;
		eo=&#039;$date1 kaj $date2&#039;,&lt;br /&gt;
		es=&#039;$date1 y $date2&#039;,&lt;br /&gt;
		et=&#039;$date1 ja $date2&#039;,&lt;br /&gt;
		fa=&#039;$date1 و $date2&#039;,&lt;br /&gt;
		fi=&#039;$date1 ja $date2&#039;,&lt;br /&gt;
		fr=&#039;$date1 et $date2&#039;,&lt;br /&gt;
		gl=&#039;$date1 e $date2&#039;,&lt;br /&gt;
		he=&#039;$date1 ו- $date2&#039;,&lt;br /&gt;
		hu=&#039;$date1 és $date2&#039;,&lt;br /&gt;
		hsb=&#039;$date1 a $date2&#039;,&lt;br /&gt;
		it=&#039;$date1 e $date2&#039;,&lt;br /&gt;
		ja=&#039;$date1および$date2&#039;,&lt;br /&gt;
		mk=&#039;$date1 и $date2&#039;,&lt;br /&gt;
		ml=&#039;$date1 ഒപ്പം $date2&#039;,&lt;br /&gt;
		nb=&#039;$date1 og $date2&#039;,&lt;br /&gt;
		nn=&#039;$date1 og $date2&#039;,&lt;br /&gt;
		nds=&#039;$date1 un $date2&#039;,&lt;br /&gt;
		nl=&#039;$date1 en $date2&#039;,&lt;br /&gt;
		no=&#039;$date1 og $date2&#039;,&lt;br /&gt;
		pl=&#039;$date1 i $date2&#039;,&lt;br /&gt;
		pt=&#039;$date1 e $date2&#039;,&lt;br /&gt;
		qu=&#039;$date1wan $date2pas&#039;,&lt;br /&gt;
		ro=&#039;$date1 și $date2&#039;,&lt;br /&gt;
		ru=&#039;$date1 и $date2&#039;,&lt;br /&gt;
		sk=&#039;$date1 a $date2&#039;,&lt;br /&gt;
		sl=&#039;$date1 in $date2&#039;,&lt;br /&gt;
		sv=&#039;$date1 och $date2&#039;,&lt;br /&gt;
		uk=&#039;$date1 та $date2&#039;,&lt;br /&gt;
		ur=&#039;$date1 و $date2&#039;,&lt;br /&gt;
		vi=&#039;$date1 và $date2&#039;,&lt;br /&gt;
		[&#039;zh-hans&#039;]=&#039;$date1和$date2&#039;,&lt;br /&gt;
		[&#039;zh-hant&#039;]=&#039;$date1和$date2&#039;,&lt;br /&gt;
		default=function(date1, date2, state) return require(&amp;quot;Module:Linguistic&amp;quot;).conj({date1, date2}, state.lang, &#039;and&#039;) end,&lt;br /&gt;
	},&lt;br /&gt;
&lt;br /&gt;
	-- ==========================================&lt;br /&gt;
	-- === Prepositions =========================&lt;br /&gt;
	-- ==========================================&lt;br /&gt;
	[&#039;by&#039;] = {&lt;br /&gt;
		nDates = 1,&lt;br /&gt;
		ar=&#039;حوالي $date1&#039;,&lt;br /&gt;
		[&#039;be-tarask&#039;]={&#039;да $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		bn=&#039;$date1 কর্তৃক&#039;,&lt;br /&gt;
		ca=&#039;vers $date1&#039;,&lt;br /&gt;
		cs={&#039;kolem $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		da=&#039;mod $date1&#039;,&lt;br /&gt;
		de=&#039;spätestens $date1&#039;,&lt;br /&gt;
		el=&#039;έως $date1&#039;,&lt;br /&gt;
		en=&#039;by $date1&#039;,&lt;br /&gt;
		[&#039;en-gb&#039;]=&#039;by $date1&#039;,&lt;br /&gt;
		[&#039;en-ca&#039;]=&#039;by $date1&#039;,&lt;br /&gt;
		eo=&#039;ne post $date1&#039;,&lt;br /&gt;
		es=&#039;para $date1&#039;,&lt;br /&gt;
		et=&#039;hiljemalt $date1&#039;,&lt;br /&gt;
		fa=&#039;توسط $date1&#039;,&lt;br /&gt;
		fi={function(date1, state) return decYear(state,&#039;fi&#039;,&#039;ill&#039;) .. &#039;$date1 mennessä&#039; end, case={&#039;ill&#039;,&#039;&#039;}},&lt;br /&gt;
		fr=&#039;$date1 (au plus tard)&#039;,&lt;br /&gt;
		gl=&#039;cara a $date1&#039;,&lt;br /&gt;
		he=&#039;עד $date1&#039;,&lt;br /&gt;
		hr=&#039;do $date1&#039;,&lt;br /&gt;
		hsb={&#039;do $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		it=&#039;entro il $date1&#039;,&lt;br /&gt;
		ja=&#039;$date1まで&#039;,&lt;br /&gt;
		mk=&#039;кон $date1&#039;,&lt;br /&gt;
		ml=&#039;$date1-ൽ&#039;,&lt;br /&gt;
		nb=&#039;innen $date1&#039;,&lt;br /&gt;
		nn=&#039;innan $date1&#039;,&lt;br /&gt;
		nds=&#039;$date1 oder vördem al&#039;,&lt;br /&gt;
		nl=&#039;tegen $date1&#039;,&lt;br /&gt;
		no=&#039;innen $date1&#039;,&lt;br /&gt;
		pl={&#039;przed $date1&#039;, case={&#039;ins&#039;,&#039;&#039;}},&lt;br /&gt;
		pt=&#039;por $date1&#039;,&lt;br /&gt;
		qu=&amp;quot;$date1 p&#039;unchawkama&amp;quot;,&lt;br /&gt;
		ro=&#039;de $date1&#039;,&lt;br /&gt;
		ru={&#039;к $date1&#039;, case={&#039;dat&#039;,&#039;&#039;}},&lt;br /&gt;
		sk={&#039;okolo $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		sl={function(date1, state) return &#039;najpozneje &#039; .. decYear(state,&#039;sl&#039;,&#039;gen&#039;) .. &#039; $date1&#039; end, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		sv=&#039;senast $date1&#039;,&lt;br /&gt;
		uk={&#039;до $date1&#039;, case={&#039;dat&#039;,&#039;&#039;}},&lt;br /&gt;
		ur=&#039;توسط $date1&#039;,&lt;br /&gt;
		vi=&#039;vào $date1&#039;, -- need to insert &amp;quot;đã&amp;quot; somewhere later in the sentence --&amp;gt;&lt;br /&gt;
		[&#039;zh-hans&#039;]=&#039;$date1前后&#039;,&lt;br /&gt;
		[&#039;zh-hant&#039;]=&#039;$date1前后&#039;,&lt;br /&gt;
		--default=&#039;{{Please translate|by $date1|Module:I18n/complex date}}&#039;,&lt;br /&gt;
		default=&#039;&amp;lt;span style=&amp;quot;color:red&amp;quot;&amp;gt;by $date1&amp;lt;/span&amp;gt;&#039;,&lt;br /&gt;
	},&lt;br /&gt;
&lt;br /&gt;
	[&#039;before&#039;] = {&lt;br /&gt;
		nDates = 1,&lt;br /&gt;
		ar=&#039;قبل $date1&#039;,&lt;br /&gt;
		[&#039;be-tarask&#039;]={&#039;перад $date1&#039;, case={&#039;ins&#039;,&#039;&#039;}},&lt;br /&gt;
		bn=&#039;$date1-এর আগে&#039;,&lt;br /&gt;
		bg=&#039;Преди $date1&#039;,&lt;br /&gt;
		ca=&#039;abans $date1&#039;,&lt;br /&gt;
		cs={&#039;před $date1&#039;, case={&#039;ins&#039;,&#039;&#039;}},&lt;br /&gt;
		da=&#039;før $date1&#039;,&lt;br /&gt;
		de=&#039;vor $date1&#039;,&lt;br /&gt;
		el=&#039;πριν από $date1&#039;,&lt;br /&gt;
		en=&#039;before $date1&#039;,&lt;br /&gt;
		[&#039;en-gb&#039;]=&#039;before $date1&#039;,&lt;br /&gt;
		[&#039;en-ca&#039;]=&#039;before $date1&#039;,&lt;br /&gt;
		eo=&#039;antaŭ $date1&#039;,&lt;br /&gt;
		es=&#039;antes de $date1&#039;,&lt;br /&gt;
		et=&#039;enne $date1&#039;,&lt;br /&gt;
		fa=&#039;پیش از $date1&#039;,&lt;br /&gt;
		fi={function(date1, state) return &#039;ennen &#039; .. decYear(state,&#039;fi&#039;,&#039;ptv&#039;) .. &#039;$date1&#039; end, case={&#039;ptv&#039;,&#039;&#039;}},&lt;br /&gt;
		fr=&#039;avant $date1&#039;,&lt;br /&gt;
		gl=&#039;antes do $date1&#039;,&lt;br /&gt;
		he=&#039;לפני $date1&#039;,&lt;br /&gt;
		hr=&#039;prije $date1&#039;,&lt;br /&gt;
		hsb={&#039;do $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		hu=&#039;$date1 előtt&#039;,&lt;br /&gt;
		it=&#039;prima del $date1&#039;,&lt;br /&gt;
		ja=&#039;$date1より前&#039;,&lt;br /&gt;
		mk=&#039;пред $date1&#039;,&lt;br /&gt;
		ml=&#039;$date1-നു മുമ്പ്&#039;,&lt;br /&gt;
		nb=&#039;før $date1&#039;,&lt;br /&gt;
		nn=&#039;før $date1&#039;,&lt;br /&gt;
		nds=&#039;vör $date1&#039;,&lt;br /&gt;
		nl=&#039;voor $date1&#039;,&lt;br /&gt;
		no=&#039;før $date1&#039;,&lt;br /&gt;
		pl={&#039;przed $date1&#039;, case={&#039;ins&#039;,&#039;&#039;}},&lt;br /&gt;
		pt=&#039;antes de $date1&#039;,&lt;br /&gt;
		qu=&amp;quot;$date1 p&#039;unchaw ñawpan&amp;quot;,&lt;br /&gt;
		ro=&#039;înainte de $date1&#039;,&lt;br /&gt;
		ru={&#039;ранее $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		sk={&#039;pred $date1&#039;, case={&#039;ins&#039;,&#039;&#039;}},&lt;br /&gt;
		sl={function(date1, state) return &#039;pred &#039; .. decYear(state,&#039;sl&#039;,&#039;ins&#039;) .. &#039; $date1&#039; end, case={&#039;ins&#039;,&#039;&#039;}},&lt;br /&gt;
		sv=&#039;före $date1&#039;,&lt;br /&gt;
		uk={&#039;до $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		ur=&#039;قبل $date1&#039;,&lt;br /&gt;
		vi=&#039;trước $date1&#039;,&lt;br /&gt;
		[&#039;zh-hans&#039;]=&#039;在$date1之前&#039;,&lt;br /&gt;
		[&#039;zh-hant&#039;]=&#039;在$date1之前&#039;,&lt;br /&gt;
		--default=&#039;{{Please translate|before $date1|Module:I18n/complex date}}&#039;,&lt;br /&gt;
		default=&#039;&amp;lt;span style=&amp;quot;color:red&amp;quot;&amp;gt;before $date1&amp;lt;/span&amp;gt;&#039;,&lt;br /&gt;
	},&lt;br /&gt;
&lt;br /&gt;
	[&#039;from&#039;] = {&lt;br /&gt;
		nDates = 1,&lt;br /&gt;
		ar=&#039;من $date1&#039;,&lt;br /&gt;
		[&#039;be-tarask&#039;]={&#039;з $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		bn=&#039;$date1 থেকে&#039;,&lt;br /&gt;
		cs={&#039;od $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		de=&#039;Seit $date1&#039;,&lt;br /&gt;
		el=&#039;από $date1&#039;,&lt;br /&gt;
		en=&#039;from $date1&#039;,&lt;br /&gt;
		[&#039;en-gb&#039;]=&#039;from $date1&#039;,&lt;br /&gt;
		[&#039;en-ca&#039;]=&#039;from $date1&#039;,&lt;br /&gt;
		eo=&#039;ekde $date1&#039;,&lt;br /&gt;
		es=&#039;desde $date1&#039;,&lt;br /&gt;
		et=&#039;alates $date1&#039;,&lt;br /&gt;
		fa=&#039;از $date1&#039;,&lt;br /&gt;
		fi={function(date1, state) return decYear(state,&#039;fi&#039;,&#039;ela&#039;) .. &#039;$date1 alkaen&#039; end, case={&#039;ela&#039;,&#039;&#039;}},&lt;br /&gt;
		fr= function(date1, state) return &#039;à partir &#039;.. frOf[state.precision] ..&#039; $date1&#039; end,&lt;br /&gt;
		gl=&#039;desde o $date1&#039;,&lt;br /&gt;
		he=&#039;מ- $date1&#039;,&lt;br /&gt;
		hr=&#039;od $date1&#039;,&lt;br /&gt;
		hsb={&#039;wot $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		it=&#039;dal $date1&#039;,&lt;br /&gt;
		ja=&#039;$date1から&#039;,&lt;br /&gt;
		nds=&#039;vonaf $date1&#039;,&lt;br /&gt;
		mk=&#039;од $date1&#039;,&lt;br /&gt;
		nb=&#039;fra $date1&#039;,&lt;br /&gt;
		nn=&#039;frå $date1&#039;,&lt;br /&gt;
		ml=&#039;$date1 മുതൽ&#039;,&lt;br /&gt;
		nl=&#039;vanaf $date1&#039;,&lt;br /&gt;
		no=&#039;fra $date1&#039;,&lt;br /&gt;
		pl={&#039;od $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		qu=&amp;quot;$date1 p&#039;unchawmanta&amp;quot;,&lt;br /&gt;
		ro=&#039;din $date1&#039;,&lt;br /&gt;
		ru={&#039;С $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		sk={&#039;od $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		sl={function(date1, state) return &#039;od &#039; .. decYear(state,&#039;sl&#039;,&#039;gen&#039;) .. &#039; $date1&#039; end, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		sv=&#039;från $date1&#039;,&lt;br /&gt;
		uk={&#039;з $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		ur=&#039;از $date1&#039;,&lt;br /&gt;
		vi=&#039;từ $date1&#039;,&lt;br /&gt;
		[&#039;zh-hans&#039;]=&#039;自$date1&#039;,&lt;br /&gt;
		[&#039;zh-hant&#039;]=&#039;自$date1&#039;,&lt;br /&gt;
		--default=&#039;{{Please translate|from $date1|Module:I18n/complex date}}&#039;,&lt;br /&gt;
		default=&#039;&amp;lt;span style=&amp;quot;color:red&amp;quot;&amp;gt;from $date1&amp;lt;/span&amp;gt;&#039;,&lt;br /&gt;
	},&lt;br /&gt;
&lt;br /&gt;
	[&#039;until&#039;] = {&lt;br /&gt;
		nDates = 1,&lt;br /&gt;
		[&#039;be-tarask&#039;]={&#039;усутыч да $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		bn=&#039;$date1 পর্যন্ত&#039;,&lt;br /&gt;
		cs={&#039;do $date1&#039;, case={&#039;gen&#039;, &#039;&#039;}},&lt;br /&gt;
		de=&#039;bis $date1&#039;,&lt;br /&gt;
		en=&#039;until $date1&#039;,&lt;br /&gt;
		[&#039;en-gb&#039;]=&#039;until $date1&#039;,&lt;br /&gt;
		[&#039;en-ca&#039;]=&#039;until $date1&#039;,&lt;br /&gt;
		eo=&#039;ĝis $date1&#039;,&lt;br /&gt;
		es=&#039;hasta $date1&#039;,&lt;br /&gt;
		fr=function(date1, state)&lt;br /&gt;
			if state.precision &amp;gt; 10 then -- precision &amp;gt; month&lt;br /&gt;
				return &amp;quot;jusqu&#039;au $date1&amp;quot;&lt;br /&gt;
			else &lt;br /&gt;
				return &amp;quot;jusqu&#039;à $date1&amp;quot; &lt;br /&gt;
			end&lt;br /&gt;
		end,&lt;br /&gt;
		hr=&#039;do $date1&#039;,&lt;br /&gt;
		hsb={&#039;do $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		it=&#039;al $date1&#039;,&lt;br /&gt;
		nb= &#039;til $date1&#039;,&lt;br /&gt;
		nl= &#039;tot $date1&#039;,&lt;br /&gt;
		nn= &#039;til $date1&#039;,&lt;br /&gt;
		pl={&#039;do $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		ru={&#039;вплоть до $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		sk={&#039;do $date1&#039;, case={&#039;gen&#039;, &#039;&#039;}},&lt;br /&gt;
		uk={&#039;аж до $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		ur=&#039;تک $date1&#039;,&lt;br /&gt;
		[&#039;zh-hans&#039;]=&#039;直到$date1&#039;,&lt;br /&gt;
		[&#039;zh-hant&#039;]=&#039;直到$date1&#039;,&lt;br /&gt;
		--default=&#039;{{Please translate|until $date1|Module:I18n/complex date}}&#039;,&lt;br /&gt;
		default=&#039;&amp;lt;span style=&amp;quot;color:red&amp;quot;&amp;gt;until $date1&amp;lt;/span&amp;gt;&#039;,&lt;br /&gt;
	},&lt;br /&gt;
	&lt;br /&gt;
	[&#039;after&#039;] = {&lt;br /&gt;
		nDates = 1,&lt;br /&gt;
		ar=&#039;بعد $date1&#039;,&lt;br /&gt;
		[&#039;be-tarask&#039;]={&#039;пасьля $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		bn=&#039;$date1-এর পরে&#039;,&lt;br /&gt;
		ca=&#039;desprès $date1&#039;,&lt;br /&gt;
		cs={&#039;po $date1&#039;, case={&#039;loc&#039;,&#039;&#039;}},&lt;br /&gt;
		de=&#039;nach $date1&#039;,&lt;br /&gt;
		da=&#039;efter $date1&#039;,&lt;br /&gt;
		el=&#039;μετά από $date1&#039;,&lt;br /&gt;
		en=&#039;after $date1&#039;,&lt;br /&gt;
		[&#039;en-gb&#039;]=&#039;after $date1&#039;,&lt;br /&gt;
		[&#039;en-ca&#039;]=&#039;after $date1&#039;,&lt;br /&gt;
		eo=&#039;post $date1&#039;,&lt;br /&gt;
		es=&#039;después de $date1&#039;,&lt;br /&gt;
		et=&#039;pärast $date1&#039;,&lt;br /&gt;
		fa=&#039;پس از $date1&#039;,&lt;br /&gt;
		fi={function(date1, state) return decYear(state,&#039;fi&#039;,&#039;gen&#039;) .. &#039;$date1 jälkeen&#039; end, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		fr=&#039;après $date1&#039;,&lt;br /&gt;
		gl=&#039;despois do $date1&#039;,&lt;br /&gt;
		he=&#039;לאחר $date1&#039;,&lt;br /&gt;
		hr=&#039;nakon $date1&#039;,&lt;br /&gt;
		hu=&#039;$date1 után&#039;,&lt;br /&gt;
		hsb={&#039;po $date1&#039;, case={&#039;loc&#039;,&#039;&#039;}},&lt;br /&gt;
		it=&#039;dopo il $date1&#039;,&lt;br /&gt;
		ja=&#039;$date1より後&#039;,&lt;br /&gt;
		mk=&#039;по $date1&#039;,&lt;br /&gt;
		ml=&#039;$date1-നു ശേഷം&#039;,&lt;br /&gt;
		nb=&#039;etter $date1&#039;,&lt;br /&gt;
		nn=&#039;etter $date1&#039;,&lt;br /&gt;
		nds=&#039;na $date1&#039;,&lt;br /&gt;
		nl=&#039;na $date1&#039;,&lt;br /&gt;
		no=&#039;etter $date1&#039;,&lt;br /&gt;
		pl={&#039;po $date1&#039;, case={&#039;loc&#039;,&#039;&#039;}},&lt;br /&gt;
		pt=&#039;após $date1&#039;,&lt;br /&gt;
		qu=&amp;quot;$date1 p&#039;unchaw qhipan&amp;quot;,&lt;br /&gt;
		ro=&#039;după $date1&#039;,&lt;br /&gt;
		ru={&#039;после $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		sk={&#039;po $date1&#039;, case={&#039;loc&#039;,&#039;&#039;}},&lt;br /&gt;
		sl={function(date1, state) return &#039;po &#039; .. decYear(state,&#039;sl&#039;,&#039;loc&#039;) .. &#039; $date1&#039; end, case={&#039;loc&#039;,&#039;&#039;}},&lt;br /&gt;
		sv=&#039;efter $date1&#039;,&lt;br /&gt;
		uk={&#039;після $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		ur=&#039;بعد $date1&#039;,&lt;br /&gt;
		vi=&#039;sau $date1&#039;,&lt;br /&gt;
		[&#039;zh-hans&#039;]=&#039;在$date1之后&#039;,&lt;br /&gt;
		[&#039;zh-hant&#039;]=&#039;在$date1之後&#039;,&lt;br /&gt;
		--default=&#039;{{Please translate|after $date1|Module:I18n/complex date}}&#039;,&lt;br /&gt;
		default=&#039;&amp;lt;span style=&amp;quot;color:red&amp;quot;&amp;gt;after $date1&amp;lt;/span&amp;gt;&#039;,&lt;br /&gt;
	},&lt;br /&gt;
&lt;br /&gt;
	-- ==========================================&lt;br /&gt;
	-- === Adjectives ===========================&lt;br /&gt;
	-- ==========================================&lt;br /&gt;
	[&#039;early&#039;] = {&lt;br /&gt;
		nDates = 1,&lt;br /&gt;
		ar=&#039;بداية $date1&#039;,&lt;br /&gt;
		[&#039;be-tarask&#039;]={&#039;пачатак $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		bn=&#039;$date1-এর শুরুতে&#039;,&lt;br /&gt;
		ca=&#039;al principi de $date1&#039;,&lt;br /&gt;
		cs={&#039;začátek $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		da=&#039;tidlig $date1&#039;,&lt;br /&gt;
		de=&#039;Anfang $date1&#039;,&lt;br /&gt;
		el=&#039;αρχές του $date1&#039;,&lt;br /&gt;
		en=&#039;early $date1&#039;,&lt;br /&gt;
		[&#039;en-gb&#039;]=&#039;early $date1&#039;,&lt;br /&gt;
		[&#039;en-ca&#039;]=&#039;early $date1&#039;,&lt;br /&gt;
		eo=&#039;komence de $date1&#039;,&lt;br /&gt;
		es=&#039;a principios de $date1&#039;,&lt;br /&gt;
		et=&#039;$date1 algus&#039;,&lt;br /&gt;
		fa=&#039;اوایل $date1&#039;,&lt;br /&gt;
		fi={function(date1, state) return decYear(state,&#039;fi&#039;,&#039;gen&#039;) .. &#039;$date1 alku&#039; end, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		fr=&#039;début $date1&#039;,&lt;br /&gt;
		gl=&#039;a principios de $date1&#039;,&lt;br /&gt;
		he=&#039;תחילת $date1&#039;,&lt;br /&gt;
		hr=&#039;početak $date1&#039;,&lt;br /&gt;
		hsb={&#039;spočatk $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		hu=&#039;$date1 elején&#039;,&lt;br /&gt;
		it=&#039;inizio del $date1&#039;,&lt;br /&gt;
		ja=&#039;$date1初頭&#039;,&lt;br /&gt;
		mk=&#039;почеток на $date1&#039;,&lt;br /&gt;
		ml=&#039;$date1 ആദ്യപാദം&#039;,&lt;br /&gt;
		nb=&#039;tidlig $date1&#039;,&lt;br /&gt;
		nn=&#039;tidleg $date1&#039;,&lt;br /&gt;
		nds=&#039;Anfang $date1&#039;,&lt;br /&gt;
		nl=&#039;begin $date1&#039;,&lt;br /&gt;
		no=&#039;tidlig $date1&#039;,&lt;br /&gt;
		pl={&#039;początek $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		pt=&#039;a princípios de $date1&#039;,&lt;br /&gt;
		qu=&amp;quot;$date1 ñawpaq p&#039;unchawkunapi&amp;quot;,&lt;br /&gt;
		ro=&#039;începând cu $date1&#039;,&lt;br /&gt;
		ru={&#039;начало $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		sk={&#039;začiatok $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		sl=function(date1, state)-- could actually be better should be &amp;quot;d&#039;octobre à mars 2013&#039; not &amp;quot;de octore 2013 à mars 2013&amp;quot; &lt;br /&gt;
			if state.precision == 9 then -- precision &amp;gt; month&lt;br /&gt;
				return &#039;zgodnje leto $date1&#039;&lt;br /&gt;
			else				-- &amp;quot;DE septebmbre&amp;quot; / &amp;quot;D&#039;octobre&amp;quot;&lt;br /&gt;
				return &#039;zgodnji $date1&#039;&lt;br /&gt;
			end&lt;br /&gt;
		end, &lt;br /&gt;
		sv=&#039;början av $date1&#039;,&lt;br /&gt;
		uk={&#039;початок $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		ur=&#039;ابتدا $date1&#039;,&lt;br /&gt;
		vi=&#039;đầu năm $date1&#039;,&lt;br /&gt;
		[&#039;zh-hans&#039;]=&#039;$date1早期&#039;,&lt;br /&gt;
		[&#039;zh-hant&#039;]=&#039;$date1早期&#039;,&lt;br /&gt;
		--default=&#039;{{Please translate|early $date1|Module:I18n/complex date}}&#039;,&lt;br /&gt;
		default=&#039;&amp;lt;span style=&amp;quot;color:red&amp;quot;&amp;gt;early $date1&amp;lt;/span&amp;gt;&#039;,&lt;br /&gt;
	},&lt;br /&gt;
&lt;br /&gt;
	[&#039;mid&#039;] = {&lt;br /&gt;
		nDates = 1,&lt;br /&gt;
		ar=&#039;منتصف $date1&#039;,&lt;br /&gt;
		[&#039;be-tarask&#039;]={&#039;сярэдзіна $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		bn=&#039;$date1-এর মাঝামাঝি&#039;,&lt;br /&gt;
		ca=&#039;a mitjan $date1&#039;,&lt;br /&gt;
		cs={&#039;polovina $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		da=&#039;midten af $date1&#039;,&lt;br /&gt;
		de=&#039;Mitte $date1&#039;,&lt;br /&gt;
		el=&#039;μέσα του $date1&#039;,&lt;br /&gt;
		en=&#039;mid $date1&#039;,&lt;br /&gt;
		[&#039;en-gb&#039;]=&#039;mid $date1&#039;,&lt;br /&gt;
		[&#039;en-ca&#039;]=&#039;mid $date1&#039;,&lt;br /&gt;
		eo=&#039;meze de $date1&#039;,&lt;br /&gt;
		es=&#039;a mediados de $date1&#039;,&lt;br /&gt;
		et=&#039;$date1 keskel&#039;,&lt;br /&gt;
		fa=&#039;اواسط $date1&#039;,&lt;br /&gt;
		fi={function(date1, state) return decYear(state,&#039;fi&#039;,&#039;gen&#039;) .. &#039;$date1 puoliväli&#039; end, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		fr=&#039;mi $date1&#039;,&lt;br /&gt;
		gl=&#039;a mediados de $date1&#039;,&lt;br /&gt;
		he=&#039;אמצע $date1&#039;,&lt;br /&gt;
		hr=&#039;sredina $date1&#039;,&lt;br /&gt;
		hsb={&#039;srjedź $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		hu=&#039;$date1 közepén&#039;,&lt;br /&gt;
		it=&#039;metà del $date1&#039;,&lt;br /&gt;
		ja=&#039;$date1半ば&#039;,&lt;br /&gt;
		mk=&#039;средина на $date1&#039;,&lt;br /&gt;
		ml=&#039;$date1 മദ്ധ്യം&#039;,&lt;br /&gt;
		nb=&#039;midten av $date1&#039;,&lt;br /&gt;
		nn=&#039;midten av $date1&#039;,&lt;br /&gt;
		nds=&#039;Midd $date1&#039;,&lt;br /&gt;
		nl=&#039;midden $date1&#039;,&lt;br /&gt;
		no=&#039;midten av $date1&#039;,&lt;br /&gt;
		pl={&#039;środek $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		pt=&#039;meados de $date1&#039;,&lt;br /&gt;
		qu=&amp;quot;$date1 chawpin p&#039;unchawkunapi&amp;quot;,&lt;br /&gt;
		ro=&#039;mijlocul lui $date1&#039;,&lt;br /&gt;
		ru={&#039;середина $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		sk={&#039;polovica $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		sl={function(date1, state) return &#039;sredina &#039; .. decYear(state,&#039;sl&#039;,&#039;gen&#039;) .. &#039; $date1&#039; end, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		sv=&#039;mitten av $date1&#039;,&lt;br /&gt;
		uk={&#039;середина $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		ur=&#039;وسط $date1&#039;,&lt;br /&gt;
		vi=&#039;giữa năm $date1&#039;,&lt;br /&gt;
		[&#039;zh-hans&#039;]=&#039;$date1中期&#039;,&lt;br /&gt;
		[&#039;zh-hant&#039;]=&#039;$date1中期&#039;,&lt;br /&gt;
		--default=&#039;{{Please translate|mid $date1|Module:I18n/complex date}}&#039;,&lt;br /&gt;
		default=&#039;&amp;lt;span style=&amp;quot;color:red&amp;quot;&amp;gt;mid $date1&amp;lt;/span&amp;gt;&#039;,&lt;br /&gt;
	},&lt;br /&gt;
&lt;br /&gt;
	[&#039;late&#039;] = {&lt;br /&gt;
		nDates = 1,&lt;br /&gt;
		ar=&#039;نهاية $date1&#039;,&lt;br /&gt;
		bn=&#039;$date1-এর শেষে&#039;,&lt;br /&gt;
		[&#039;be-tarask&#039;]={&#039;канец $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		ca=&#039;al final de $date1&#039;,&lt;br /&gt;
		cs=&#039;konec $date1&#039;,&lt;br /&gt;
		da=&#039;sen $date1&#039;,&lt;br /&gt;
		de=&#039;Ende $date1&#039;,&lt;br /&gt;
		el=&#039;τέλη του $date1&#039;,&lt;br /&gt;
		en=&#039;late $date1&#039;,&lt;br /&gt;
		[&#039;en-gb&#039;]=&#039;late $date1&#039;,&lt;br /&gt;
		[&#039;en-ca&#039;]=&#039;late $date1&#039;,&lt;br /&gt;
		eo=&#039;fine de $date1&#039;,&lt;br /&gt;
		es=&#039;a fines de $date1&#039;,&lt;br /&gt;
		et=&#039;$date1 lõpp&#039;,&lt;br /&gt;
		fa=&#039;اواخر $date1&#039;,&lt;br /&gt;
		fi={function(date1, state) return decYear(state,&#039;fi&#039;,&#039;gen&#039;) .. &#039;$date1 loppu&#039; end, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		fr=&#039;fin $date1&#039;,&lt;br /&gt;
		gl=&#039;a finais de $date1&#039;,&lt;br /&gt;
		he=&#039;סוף $date1&#039;,&lt;br /&gt;
		hr=&#039;kraj $date1&#039;,&lt;br /&gt;
		hsb={&#039;kónc $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		hu=&#039;$date1 végén&#039;,&lt;br /&gt;
		it=&#039;fine del $date1&#039;,&lt;br /&gt;
		ja=&#039;$date1末&#039;,&lt;br /&gt;
		mk=&#039;крајот на $date1&#039;,&lt;br /&gt;
		ml=&#039;$date1 അന്ത്യപാദം&#039;,&lt;br /&gt;
		nb=&#039;sent $date1&#039;,&lt;br /&gt;
		no=&#039;seint $date1&#039;,&lt;br /&gt;
		nds=&#039;Enn $date1&#039;,&lt;br /&gt;
		nl=&#039;eind $date1&#039;,&lt;br /&gt;
		no=&#039;sent $date1&#039;,&lt;br /&gt;
		pl={&#039;koniec $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		pt=&#039;ao final de $date1&#039;,&lt;br /&gt;
		qu=&amp;quot;$date1 qhipaq p&#039;unchawkunapi&amp;quot;,&lt;br /&gt;
		ro=&#039;sfârșitul lui $date1&#039;,&lt;br /&gt;
		ru={&#039;конец $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		sk={&#039;koniec $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		sl={function(date1, state) return &#039;pozno &#039; .. decYear(state,&#039;sl&#039;,&#039;gen&#039;) .. &#039; $date1&#039; end, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		sv=&#039;slutet av $date1&#039;,&lt;br /&gt;
		uk={&#039;кінець $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		ur=&#039;اخیر $date1&#039;,&lt;br /&gt;
		vi=&#039;cuối năm $date1&#039;,&lt;br /&gt;
		[&#039;zh-hans&#039;]=&#039;$date1晚期&#039;,&lt;br /&gt;
		[&#039;zh-hant&#039;]=&#039;$date1晚期&#039;,&lt;br /&gt;
		--default=&#039;{{Please translate|late $date1|Module:I18n/complex date}}&#039;,&lt;br /&gt;
		default=&#039;&amp;lt;span style=&amp;quot;color:red&amp;quot;&amp;gt;late $date1&amp;lt;/span&amp;gt;&#039;,&lt;br /&gt;
	},&lt;br /&gt;
	&lt;br /&gt;
	[&#039;circa&#039;] = {&lt;br /&gt;
		nDates = 1,&lt;br /&gt;
		ar=&#039;حوالي $date1&#039;,&lt;br /&gt;
		[&#039;be-tarask&#039;]={&#039;каля $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		bn=&#039;প্রায় $date1&#039;,&lt;br /&gt;
		ca=&#039;cap a $date1&#039;,&lt;br /&gt;
		cs=&#039;cca $date1&#039;,&lt;br /&gt;
		da=&#039;ca. $date1&#039;,&lt;br /&gt;
		de=&#039;etwa $date1&#039;,&lt;br /&gt;
		el=&#039;περ. $date1&#039;,&lt;br /&gt;
		en=&#039;circa $date1&#039;,&lt;br /&gt;
		[&#039;en-gb&#039;]=&#039;circa $date1&#039;,&lt;br /&gt;
		[&#039;en-ca&#039;]=&#039;circa $date1&#039;,&lt;br /&gt;
		eo=&#039;ĉirkaŭ $date1&#039;,&lt;br /&gt;
		es=&#039;hacia $date1&#039;, -- suggestion use &amp;quot;hacia&amp;quot;/&amp;quot;hacia el&amp;quot; or leave the latin circa or ca. &lt;br /&gt;
		et=&#039;ca. $date1&#039;,&lt;br /&gt;
		fa=&#039;حوالی $date1&#039;, -- template:Circa used &#039;حدود $date1&#039;&lt;br /&gt;
		fi={function(date1, state) return &#039;suunnilleen &#039; .. decYear(state,&#039;fi&#039;,&#039;ine&#039;) .. &#039;$date1&#039; end, case={&#039;ine&#039;,&#039;&#039;}}, -- template:Circa used &#039;noin $date1&#039;&lt;br /&gt;
		fr=function(date1, state) 			&lt;br /&gt;
			if state.precision &amp;gt;= 11 then -- precision &amp;gt;= day&lt;br /&gt;
				return &#039;vers le $date1&#039;&lt;br /&gt;
			else&lt;br /&gt;
				return &#039;vers $date1&#039;&lt;br /&gt;
			end&lt;br /&gt;
		end,&lt;br /&gt;
		gl=&#039;entre $date1&#039;, -- template:Circa used &#039;cara a $date1&#039;&lt;br /&gt;
		he=&#039;בסביבות $date1&#039;,&lt;br /&gt;
		hr=&#039;oko $date1&#039;,&lt;br /&gt;
		hsb={&#039;wokoło $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		hu=&#039;$date1 körül&#039;,&lt;br /&gt;
		it=&#039;$date1 circa&#039;,&lt;br /&gt;
		ja=&#039;$date1頃&#039;,&lt;br /&gt;
		ko=&#039;$date1경&#039;,&lt;br /&gt;
		mk=&#039;~ $date1&#039;, -- template:Circa used &#039;o. $date1&#039;&lt;br /&gt;
		nb=&#039;ca. $date1&#039;,&lt;br /&gt;
		nn=&#039;ca. $date1&#039;,&lt;br /&gt;
		nds=&#039;üm un bi $date1&#039;,&lt;br /&gt;
		nl=&#039;ca. $date1&#039;,&lt;br /&gt;
		no=&#039;ca. $date1&#039;,&lt;br /&gt;
		pl={&#039;około $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		pt=&#039;cerca de $date1&#039;,&lt;br /&gt;
		qu=&#039;$date1chá&#039;,&lt;br /&gt;
		ro=&#039;circa $date1&#039;,&lt;br /&gt;
		ru={&#039;около $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		sk=&#039;cca $date1&#039;,&lt;br /&gt;
		sl={function(date1, state) return &#039;ok. &#039; .. decYear(state,&#039;sl&#039;,&#039;gen&#039;) .. &#039; $date1&#039; end, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		sv=&#039;c:a $date1&#039;, -- template:Circa used &#039;ca $date1&#039;&lt;br /&gt;
		uk={&#039;близько $date1&#039;, case={&#039;gen&#039;, &#039;&#039;}},&lt;br /&gt;
		ur=&#039;قریباً $date1&#039;,&lt;br /&gt;
		vi=&#039;vào khoảng $date1&#039;,&lt;br /&gt;
		[&#039;zh-hans&#039;]=&#039;约$date1&#039;,&lt;br /&gt;
		[&#039;zh-hant&#039;]=&#039;約$date1&#039;,&lt;br /&gt;
		--default=&#039;{{Please translate|circa $date1|Module:I18n/complex date}}&#039;,&lt;br /&gt;
		default=&#039;&amp;lt;span style=&amp;quot;color:red&amp;quot;&amp;gt;circa $date1&amp;lt;/span&amp;gt;&#039;,&lt;br /&gt;
	},&lt;br /&gt;
	&lt;br /&gt;
	[&#039;uncertain&#039;] = {&lt;br /&gt;
		nDates = 1,&lt;br /&gt;
		[&#039;zh-hans&#039;]=&#039;$date1（？）&#039;,&lt;br /&gt;
		[&#039;zh-hant&#039;]=&#039;$date1（？）&#039;,&lt;br /&gt;
		default=&#039;$date1 (?)&#039;,&lt;br /&gt;
	},&lt;br /&gt;
&lt;br /&gt;
	[&#039;year unknown&#039;]= {&lt;br /&gt;
		nDates = 0,&lt;br /&gt;
		ca=&#039;Any desconegut&#039;,&lt;br /&gt;
		[&#039;be-tarask&#039;]=&#039;Год невядомы&#039;,&lt;br /&gt;
		bn=&#039;অজানা বছর&#039;,&lt;br /&gt;
		cs=&#039;neznámý rok&#039;,&lt;br /&gt;
		de=&#039;Jahr unbekannt&#039;,&lt;br /&gt;
		el=&#039;άγνωστο έτος&#039;,&lt;br /&gt;
		en=&#039;year unknown&#039;,&lt;br /&gt;
		[&#039;en-gb&#039;]=&#039;year unknown&#039;,&lt;br /&gt;
		[&#039;en-ca&#039;]=&#039;year unknown&#039;,&lt;br /&gt;
		eo=&#039;jaro nesciata&#039;,&lt;br /&gt;
		es=&#039;Año desconocido&#039;,&lt;br /&gt;
		fa=&#039;سال نامعلوم&#039;,&lt;br /&gt;
		fi=&#039;tuntematon vuosi&#039;,&lt;br /&gt;
		fr=&#039;Année inconnue&#039;,&lt;br /&gt;
		he=&#039;שנה לא ידועה&#039;,&lt;br /&gt;
		hsb=&#039;lěto njeznate&#039;,&lt;br /&gt;
		hr=&#039;nepoznata godina&#039;,&lt;br /&gt;
		it=&#039;anno sconosciuto&#039;,&lt;br /&gt;
		ja=&#039;年代不明&#039;,&lt;br /&gt;
		la=&#039;Sine anno&#039;,&lt;br /&gt;
		ml=&#039;വർഷം ലഭ്യമല്ല&#039;,&lt;br /&gt;
		mk=&#039;непозната година&#039;,&lt;br /&gt;
		nb=&#039;ukjent år&#039;,&lt;br /&gt;
		nn=&#039;ukjent år&#039;,&lt;br /&gt;
		nl=&#039;zonder jaar&#039;,&lt;br /&gt;
		no=&#039;ukjent år&#039;,&lt;br /&gt;
		pl=&#039;rok nieznany&#039;,&lt;br /&gt;
		qu=&#039;Mana riqsisqa wata&#039;,&lt;br /&gt;
		ru=&#039;Год неизвестен&#039;,&lt;br /&gt;
		sk=&#039;neznámy rok&#039;,&lt;br /&gt;
		sl=&#039;neznano leto&#039;,&lt;br /&gt;
		sv=&#039;Okänt år&#039;,&lt;br /&gt;
		uk=&#039;рік невідомий&#039;,&lt;br /&gt;
		ur=&#039;سال نامعلوم&#039;,&lt;br /&gt;
		vi=&#039;không rõ năm&#039;,&lt;br /&gt;
		[&#039;zh-hans&#039;]=&#039;年份未知&#039;,&lt;br /&gt;
		[&#039;zh-hant&#039;]=&#039;年份未知&#039;,&lt;br /&gt;
		--default=&#039;{{Please translate|year unknown|Module:I18n/complex date}}&#039;,&lt;br /&gt;
		default=&#039;&amp;lt;span style=&amp;quot;color:red&amp;quot;&amp;gt;year unknown&amp;lt;/span&amp;gt;&#039;,&lt;br /&gt;
	},&lt;br /&gt;
&lt;br /&gt;
	-- ==========================================&lt;br /&gt;
	-- === Parts of a whole =====================&lt;br /&gt;
	-- ==========================================&lt;br /&gt;
	[&#039;firsthalf&#039;] = {&lt;br /&gt;
		nDates = 1,&lt;br /&gt;
		ar=&#039;النصف الأول من $date1&#039;,&lt;br /&gt;
		[&#039;be-tarask&#039;]={&#039;першая палова $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		bn=&#039;$date1-এর প্রথমার্ধ&#039;,&lt;br /&gt;
		ca=&#039;1a meitat de $date1&#039;,&lt;br /&gt;
		cs={&#039;1. polovina $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		da=&#039;1. halvdel af $date1&#039;,&lt;br /&gt;
		de=&#039;1. Hälfte $date1&#039;,&lt;br /&gt;
		el=&#039;πρώτο μισό του $date1&#039;,&lt;br /&gt;
		en=&#039;first half of $date1&#039;,&lt;br /&gt;
		[&#039;en-gb&#039;]=&#039;first half of $date1&#039;,&lt;br /&gt;
		[&#039;en-ca&#039;]=&#039;first half of $date1&#039;,&lt;br /&gt;
		eo=&#039;unua duono de $date1&#039;,&lt;br /&gt;
		es=&#039;primera mitad de $date1&#039;,&lt;br /&gt;
		et=&#039;$date1 esimene pool&#039;,&lt;br /&gt;
		fa=&#039;نیمهٔ نخست $date1&#039;,&lt;br /&gt;
		fi={function(date1, state) return decYear(state,&#039;fi&#039;,&#039;gen&#039;) .. &#039;$date1 alkupuolisko&#039; end, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		fr=&#039;1&amp;lt;sup&amp;gt;re&amp;lt;/sup&amp;gt; moitié de $date1&#039;,&lt;br /&gt;
		gl=&#039;primeira metade de $date1&#039;,&lt;br /&gt;
		he=&#039;במחצית הראשונה של $date1&#039;,&lt;br /&gt;
		hsb={&#039;prěnja połojca $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		hu=&#039;$date1 első felében&#039;,&lt;br /&gt;
		hr=&#039;prva polovina $date1&#039;,&lt;br /&gt;
		it=&#039;prima metà del $date1&#039;,&lt;br /&gt;
		ja=&#039;$date1上半期&#039;,&lt;br /&gt;
		mk=&#039;прва половина на $date1&#039;,&lt;br /&gt;
		ml=&#039;$date1 ആദ്യപകുതി&#039;,&lt;br /&gt;
		nb=&#039;første halvdel av $date1&#039;,&lt;br /&gt;
		nn=&#039;fyrste halvdelen av $date1&#039;,&lt;br /&gt;
		nds=&#039;1. Helft $date1&#039;,&lt;br /&gt;
		nl=&#039;eerste helft $date1&#039;,&lt;br /&gt;
		no=&#039;første halvdel av $date1&#039;,&lt;br /&gt;
		pl={&#039;pierwsza połowa $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		pt=&#039;primeira metade de $date1&#039;,&lt;br /&gt;
		qu=&#039;$date1 ñawpaq kuskanpi&#039;,&lt;br /&gt;
		ro=&#039;prima jumătate a lui $date1&#039;,&lt;br /&gt;
		ru={&#039;первая половина $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		sk={&#039;1. polovica $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		sl={function(date1, state) return &#039;prva polovica &#039; .. decYear(state,&#039;sl&#039;,&#039;gen&#039;) .. &#039; $date1&#039; end, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		sv=&#039;första halvan av $date1&#039;,&lt;br /&gt;
		uk={&#039;перша половина $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		ur=&#039;نصف اول $date1&#039;,&lt;br /&gt;
		vi=&#039;nửa đầu năm $date1&#039;,&lt;br /&gt;
		[&#039;zh-hans&#039;]=&#039;$date1上半期&#039;,&lt;br /&gt;
		[&#039;zh-hant&#039;]=&#039;$date1上半期&#039;,&lt;br /&gt;
		--default=&#039;{{Please translate|first half of $date1|Module:I18n/complex date}}&#039;,&lt;br /&gt;
		default=&#039;&amp;lt;span style=&amp;quot;color:red&amp;quot;&amp;gt;first half of $date1&amp;lt;/span&amp;gt;&#039;,&lt;br /&gt;
	},&lt;br /&gt;
&lt;br /&gt;
	[&#039;secondhalf&#039;] = {&lt;br /&gt;
		nDates = 1,&lt;br /&gt;
		ar=&#039;النصف الثاني من $date1&#039;,&lt;br /&gt;
		[&#039;be-tarask&#039;]={&#039;другая палова $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		bn=&#039;$date1-এর দ্বিতীয়ার্ধ&#039;,&lt;br /&gt;
		ca=&#039;2a meitat de $date1&#039;,&lt;br /&gt;
		cs={&#039;2. polovina $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		da=&#039;2. halvdel af $date1&#039;,&lt;br /&gt;
		de=&#039;2. Hälfte $date1&#039;,&lt;br /&gt;
		el=&#039;δεύτερο μισό του $date1&#039;,&lt;br /&gt;
		en=&#039;second half of $date1&#039;,&lt;br /&gt;
		[&#039;en-gb&#039;]=&#039;second half of $date1&#039;,&lt;br /&gt;
		[&#039;en-ca&#039;]=&#039;second half of $date1&#039;,&lt;br /&gt;
		eo=&#039;dua duono de $date1&#039;,&lt;br /&gt;
		es=&#039;segunda mitad de $date1&#039;,&lt;br /&gt;
		et=&#039;$date1 teine pool&#039;,&lt;br /&gt;
		fa=&#039;نیمهٔ دوم $date1&#039;,&lt;br /&gt;
		fi={function(date1, state) return decYear(state,&#039;fi&#039;,&#039;gen&#039;) .. &#039;$date1 loppupuolisko&#039; end, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		fr=&#039;2&amp;lt;sup&amp;gt;e&amp;lt;/sup&amp;gt; moitié de $date1&#039;,&lt;br /&gt;
		gl=&#039;segunda metade de $date1&#039;,&lt;br /&gt;
		he=&#039;במחצית השנייה של $date1&#039;,&lt;br /&gt;
		hsb={&#039;druha połojca $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		hr=&#039;druga polovina $date1&#039;,&lt;br /&gt;
		hu=&#039;$date1 második felében&#039;,&lt;br /&gt;
		it=&#039;seconda metà del $date1&#039;,&lt;br /&gt;
		ja=&#039;$date1下半期&#039;,&lt;br /&gt;
		mk=&#039;втора половина на $date1&#039;,&lt;br /&gt;
		ml=&#039;$date1 രണ്ടാം പകുതി&#039;,&lt;br /&gt;
		nb=&#039;andre halvdel av $date1&#039;,&lt;br /&gt;
		nn=&#039;andre halvdelen av $date1&#039;,&lt;br /&gt;
		nds=&#039;2. Helft vun $date1&#039;,&lt;br /&gt;
		nl=&#039;tweede helft $date1&#039;,&lt;br /&gt;
		no=&#039;andre halvdel av $date1&#039;,&lt;br /&gt;
		pl={&#039;druga połowa $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		pt=&#039;segunda metade de $date1&#039;,&lt;br /&gt;
		qu=&#039;$date1 qhipaq kuskanpi&#039;,&lt;br /&gt;
		ro=&#039;a doua jumătate a lui $date1&#039;,&lt;br /&gt;
		ru={&#039;вторая половина $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		sk={&#039;2. polovica $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		sl={&#039;druga polovica {{IfNum | $date0 | leta}} $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		sv=&#039;andra halvan av $date1&#039;,&lt;br /&gt;
		uk={&#039;друга половина $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		ur=&#039;نصف آخر $date1&#039;,&lt;br /&gt;
		vi=&#039;nửa cuối năm $date1&#039;,&lt;br /&gt;
		[&#039;zh-hans&#039;]=&#039;$date1下半期&#039;,&lt;br /&gt;
		[&#039;zh-hant&#039;]=&#039;$date1下半期&#039;,&lt;br /&gt;
		--default=&#039;{{Please translate|second half of $date1|Module:I18n/complex date}}&#039;,&lt;br /&gt;
		default=&#039;&amp;lt;span style=&amp;quot;color:red&amp;quot;&amp;gt;second half of $date1&amp;lt;/span&amp;gt;&#039;,&lt;br /&gt;
	},&lt;br /&gt;
&lt;br /&gt;
	[&#039;1quarter&#039;]= {&lt;br /&gt;
		nDates = 1,&lt;br /&gt;
		bn=&#039;$date1-এর প্রথম ত্রৈমাসিক&#039;,&lt;br /&gt;
		[&#039;be-tarask&#039;]={&#039;першая чвэрць $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		cs={&#039;1. čtvrtina $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		de=&#039;erstes Viertel $date1&#039;,&lt;br /&gt;
		en=&#039;first quarter of $date1&#039;,&lt;br /&gt;
		[&#039;en-gb&#039;]=&#039;first quarter of $date1&#039;,&lt;br /&gt;
		[&#039;en-ca&#039;]=&#039;first quarter of $date1&#039;,&lt;br /&gt;
		eo=&#039;unua kvarono de $date1&#039;,&lt;br /&gt;
		es=&#039;primer cuarto del $date1&#039;,&lt;br /&gt;
		fa=&#039;ربع نخست $date1&#039;,&lt;br /&gt;
		fi={function(date1, state) return decYear(state,&#039;fi&#039;,&#039;gen&#039;) .. &#039;$date1 ensimmäinen neljännes&#039; end, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		fr= function(date1, state) return &#039;premier quart &#039;.. frOf[state.precision] ..&#039; $date1&#039; end, &lt;br /&gt;
		he=&#039;רבעון ראשון של $date1&#039;,&lt;br /&gt;
		hsb={&#039;prěnja štwórćina $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		hr=&#039;prva četvrtina $date1&#039;,&lt;br /&gt;
		it=&#039;primo quarto del $date1&#039;,&lt;br /&gt;
		ja=&#039;$date1第1四半期&#039;,&lt;br /&gt;
		nb=&#039;første kvartal av $date1&#039;,&lt;br /&gt;
		nl=&#039;eerste kwart $date1&#039;,&lt;br /&gt;
		nn=&#039;fyrste kvartalet av $date1&#039;,&lt;br /&gt;
		no=&#039;første kvartal av $date1&#039;,&lt;br /&gt;
		pl={&#039;pierwsza ćwiartka $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		qu=&#039;$date1 ñawpaq ñiqin tawa phatmanpi&#039;,&lt;br /&gt;
		ru={&#039;первая четверть $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		sk={&#039;1. štvrtina $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		sl={&#039;prva četrtina {{IfNum | $date0 | leta}} $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		sl={function(date1, state) return &#039;prva četrtina &#039; .. decYear(state,&#039;sl&#039;,&#039;gen&#039;) .. &#039; $date1&#039; end, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		sv=&#039;första kvartalet av $date1&#039;,&lt;br /&gt;
		uk={&#039;1-ша чверть $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		ur=&#039;پہلی سہ ماہی $date1&#039;,&lt;br /&gt;
		vi=&#039;quý 1 năm $date1&#039;,&lt;br /&gt;
		[&#039;zh-hans&#039;]=&#039;$date1第一季度&#039;,&lt;br /&gt;
		[&#039;zh-hant&#039;]=&#039;$date1第一季度&#039;,&lt;br /&gt;
		--default=&#039;{{Please translate|first quarter of $date1|Module:I18n/complex date}}&#039;,&lt;br /&gt;
		default=&#039;&amp;lt;span style=&amp;quot;color:red&amp;quot;&amp;gt;first quarter of $date1&amp;lt;/span&amp;gt;&#039;,&lt;br /&gt;
	},&lt;br /&gt;
&lt;br /&gt;
	[&#039;2quarter&#039;]= {&lt;br /&gt;
		nDates = 1,&lt;br /&gt;
		[&#039;be-tarask&#039;]={&#039;другая чвэрць $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		bn=&#039;$date1-এর দ্বিতীয় ত্রৈমাসিক&#039;,&lt;br /&gt;
		cs={&#039;2. čtvrtina $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		de=&#039;zweites Viertel $date1&#039;,&lt;br /&gt;
		en=&#039;second quarter of $date1&#039;,&lt;br /&gt;
		[&#039;en-gb&#039;]=&#039;second quarter of $date1&#039;,&lt;br /&gt;
		[&#039;en-ca&#039;]=&#039;second quarter of $date1&#039;,&lt;br /&gt;
		eo=&#039;dua kvarono de $date1&#039;,&lt;br /&gt;
		es=&#039;segundo cuarto del $date1&#039;,&lt;br /&gt;
		fa=&#039;ربع دوم $date1&#039;,&lt;br /&gt;
		fi={function(date1, state) return decYear(state,&#039;fi&#039;,&#039;gen&#039;) .. &#039;$date1 toinen neljännes&#039; end, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		fr= function(date1, state) return &#039;deuxième quart &#039;.. frOf[state.precision] ..&#039; $date1&#039; end, &lt;br /&gt;
		he=&#039;רבעון שני של $date1&#039;,&lt;br /&gt;
		hsb={&#039;druha štwórćina $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		hr=&#039;druga četvrtina $date1&#039;,&lt;br /&gt;
		it=&#039;secondo quarto del $date1&#039;,&lt;br /&gt;
		ja=&#039;$date1第2四半期&#039;,&lt;br /&gt;
		nb=&#039;andre kvartal av $date1&#039;,&lt;br /&gt;
		nl=&#039;tweede kwart $date1&#039;,&lt;br /&gt;
		nn=&#039;andre kvartalet av $date1&#039;,&lt;br /&gt;
		no=&#039;andre kvartal av $date1&#039;,&lt;br /&gt;
		pl={&#039;druga ćwiartka $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		qu=&#039;$date1 iskay ñiqin tawa phatmanpi&#039;,&lt;br /&gt;
		ru={&#039;вторая четверть $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		sk={&#039;2. štvrtina $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		sl={function(date1, state) return &#039;druga četrtina &#039; .. decYear(state,&#039;sl&#039;,&#039;gen&#039;) .. &#039; $date1&#039; end, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		sv=&#039;andra kvartalet av $date1&#039;,&lt;br /&gt;
		uk={&#039;2-га чверть $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		ur=&#039;دوسری سہ ماہی $date1&#039;,&lt;br /&gt;
		vi=&#039;quý 2 năm $date1&#039;,&lt;br /&gt;
		[&#039;zh-hans&#039;]=&#039;$date1第二季度&#039;,&lt;br /&gt;
		[&#039;zh-hant&#039;]=&#039;$date1第二季度&#039;,&lt;br /&gt;
		--default=&#039;{{Please translate|second quarter of $date1|Module:I18n/complex date}}&#039;,&lt;br /&gt;
		default=&#039;&amp;lt;span style=&amp;quot;color:red&amp;quot;&amp;gt;second quarter of $date1&amp;lt;/span&amp;gt;&#039;,&lt;br /&gt;
	},&lt;br /&gt;
&lt;br /&gt;
	[&#039;3quarter&#039;]= {&lt;br /&gt;
		nDates = 1,&lt;br /&gt;
		[&#039;be-tarask&#039;]={&#039;трэцяя чвэрць $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		bn=&#039;$date1-এর তৃতীয় ত্রৈমাসিক&#039;,&lt;br /&gt;
		cs={&#039;3. čtvrtina $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		de=&#039;drittes Viertel $date1&#039;,&lt;br /&gt;
		en=&#039;third quarter of $date1&#039;,&lt;br /&gt;
		[&#039;en-gb&#039;]=&#039;third quarter of $date1&#039;,&lt;br /&gt;
		[&#039;en-ca&#039;]=&#039;third quarter of $date1&#039;,&lt;br /&gt;
		eo=&#039;tria kvarono de $date1&#039;,&lt;br /&gt;
		es=&#039;tercer cuarto del $date1&#039;,&lt;br /&gt;
		fa=&#039;ربع سوم $date1&#039;,&lt;br /&gt;
		fi={function(date1, state) return decYear(state,&#039;fi&#039;,&#039;gen&#039;) .. &#039;$date1 kolmas neljännes&#039; end, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		fr= function(date1, state) return &#039;troisième quart &#039;.. frOf[state.precision] ..&#039; $date1&#039; end, &lt;br /&gt;
		he=&#039;רבעון שלישי של $date1&#039;,&lt;br /&gt;
		hsb={&#039;třeća štwórćina $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		hr=&#039;treća četvrtina $date1&#039;,&lt;br /&gt;
		it=&#039;terzo quarto del $date1&#039;,&lt;br /&gt;
		ja=&#039;$date1第3四半期&#039;,&lt;br /&gt;
		nb=&#039;tredje kvartal av $date1&#039;,&lt;br /&gt;
		nl=&#039;derde kwart $date1&#039;,&lt;br /&gt;
		nn=&#039;tredje kvartalet av $date1&#039;,&lt;br /&gt;
		no=&#039;tredje kvartal av $date1&#039;,&lt;br /&gt;
		pl={&#039;trzecia ćwiartka $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		qu=&#039;$date1 kimsa ñiqin tawa phatmanpi&#039;,&lt;br /&gt;
		sk={&#039;3. štvrtina $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		sl={function(date1, state) return &#039;tretja četrtina &#039; .. decYear(state,&#039;sl&#039;,&#039;gen&#039;) .. &#039; $date1&#039; end, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		ru={&#039;третья четверть $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		sv=&#039;tredje kvartalet av $date1&#039;,&lt;br /&gt;
		uk={&#039;3-тя чверть $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		ur=&#039;تیسری سہ ماہی $date1&#039;,&lt;br /&gt;
		vi=&#039;quý 3 năm $date1&#039;,&lt;br /&gt;
		[&#039;zh-hans&#039;]=&#039;$date1第三季度&#039;,&lt;br /&gt;
		[&#039;zh-hant&#039;]=&#039;$date1第三季度&#039;,&lt;br /&gt;
		--default=&#039;{{Please translate|third quarter of $date1|Module:I18n/complex date}}&#039;,&lt;br /&gt;
		default=&#039;&amp;lt;span style=&amp;quot;color:red&amp;quot;&amp;gt;third quarter of $date1&amp;lt;/span&amp;gt;&#039;,&lt;br /&gt;
	},&lt;br /&gt;
&lt;br /&gt;
	[&#039;4quarter&#039;]= {&lt;br /&gt;
		nDates = 1,&lt;br /&gt;
		[&#039;be-tarask&#039;]={&#039;чацьвёртая чвэрць $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		bn=&#039;$date1-এর চতুর্থ ত্রৈমাসিক&#039;,&lt;br /&gt;
		cs={&#039;4. čtvrtina $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		de=&#039;letztes Viertel $date1&#039;,&lt;br /&gt;
		en=&#039;fourth quarter of $date1&#039;,&lt;br /&gt;
		[&#039;en-gb&#039;]=&#039;fourth quarter of $date1&#039;,&lt;br /&gt;
		[&#039;en-ca&#039;]=&#039;fourth quarter of $date1&#039;,&lt;br /&gt;
		eo=&#039;kvara kvarono de $date1&#039;,&lt;br /&gt;
		es=&#039;último cuarto del $date1&#039;,&lt;br /&gt;
		fa=&#039;ربع چهارم $date1&#039;,&lt;br /&gt;
		fi={function(date1, state) return decYear(state,&#039;fi&#039;,&#039;gen&#039;) .. &#039;$date1 viimeinen neljännes&#039; end, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		fr= function(date1, state) return &#039;quatrième quart &#039;.. frOf[state.precision] ..&#039; $date1&#039; end, &lt;br /&gt;
		he=&#039;רבעון רביעי של $date1&#039;,&lt;br /&gt;
		hsb={&#039;poslednja štwórćina $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		hr=&#039;četvrta četvrtina $date1&#039;,&lt;br /&gt;
		it=&#039;quarto quarto del $date1&#039;,&lt;br /&gt;
		ja=&#039;$date1第4四半期&#039;,&lt;br /&gt;
		nb=&#039;fjerde kvartal av $date1&#039;,&lt;br /&gt;
		nl=&#039;vierde kwart $date1&#039;,&lt;br /&gt;
		nn=&#039;tredje kvartalet av $date1&#039;,&lt;br /&gt;
		no=&#039;fjerde kvartal av $date1&#039;,&lt;br /&gt;
		pl={&#039;czwarta ćwiartka $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		qu=&#039;$date1 qhipaq ñiqin tawa phatmanpi&#039;,&lt;br /&gt;
		ru={&#039;последняя четверть $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		sk={&#039;4. štvrtina $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		sl={function(date1, state) return &#039;zadnja četrtina &#039; .. decYear(state,&#039;sl&#039;,&#039;gen&#039;) .. &#039; $date1&#039; end, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		sv=&#039;fjärde kvartalet av $date1&#039;,&lt;br /&gt;
		uk={&#039;4-та чверть $date1&#039;, case={&#039;gen&#039;,&#039;&#039;}},&lt;br /&gt;
		ur=&#039;چوتھی سہ ماہی $date1&#039;,&lt;br /&gt;
		vi=&#039;quý 4 năm $date1&#039;,&lt;br /&gt;
		[&#039;zh-hans&#039;]=&#039;$date1第四季度&#039;,&lt;br /&gt;
		[&#039;zh-hant&#039;]=&#039;$date1第四季度&#039;,&lt;br /&gt;
		--default=&#039;{{Please translate|forth quarter of $date1|Module:I18n/complex date}}&#039;,&lt;br /&gt;
		default=&#039;&amp;lt;span style=&amp;quot;color:red&amp;quot;&amp;gt;forth quarter of $date1&amp;lt;/span&amp;gt;&#039;,&lt;br /&gt;
	},&lt;br /&gt;
&lt;br /&gt;
	-- ==========================================&lt;br /&gt;
	-- === Seasons ==============================&lt;br /&gt;
	-- ==========================================&lt;br /&gt;
 	[&#039;spring&#039;] = {&lt;br /&gt;
		nDates = 1,&lt;br /&gt;
		ar=&#039;ربيع $date1&#039;,&lt;br /&gt;
		[&#039;be-tarask&#039;]=&#039;вясна $date1&#039;,&lt;br /&gt;
		bn=&#039;বসন্তকাল $date1&#039;,&lt;br /&gt;
		ca=&#039;primavera $date1&#039;,&lt;br /&gt;
		cs={&#039;jaro $date1&#039;, case={&#039;gen&#039;, &#039;&#039;}},&lt;br /&gt;
		da=&#039;Forår $date1&#039;,&lt;br /&gt;
		de=&#039;Frühling $date1&#039;,&lt;br /&gt;
		en=&#039;Spring $date1&#039;,&lt;br /&gt;
		[&#039;en-gb&#039;]=&#039;Spring $date1&#039;,&lt;br /&gt;
		[&#039;en-ca&#039;]=&#039;Spring $date1&#039;,&lt;br /&gt;
		eo=&#039;printempo $date1&#039;,&lt;br /&gt;
		es=&#039;primavera de $date1&#039;,&lt;br /&gt;
		et=&#039;$date1 kevad&#039;,&lt;br /&gt;
		fa=&#039;بهار $date1&#039;,&lt;br /&gt;
		fi=&#039;Kevät $date1&#039;,&lt;br /&gt;
		fr=&#039;printemps $date1&#039;,&lt;br /&gt;
		gl=&#039;primavera $date1&#039;,&lt;br /&gt;
		he=&#039;אביב $date1&#039;,&lt;br /&gt;
		hr=&#039;proljeće $date1&#039;,&lt;br /&gt;
		hsb=&#039;nalěćo $date1&#039;,&lt;br /&gt;
		hu=&#039;$date1 tavasza&#039;,&lt;br /&gt;
		it=&#039;primavera $date1&#039;,&lt;br /&gt;
		ja=&#039;{{#if:$date1|$date1年}}春&#039;,&lt;br /&gt;
		mk=&#039;пролет $date1&#039;,&lt;br /&gt;
		ml=&#039;$date1 വസന്തം&#039;,&lt;br /&gt;
		nb=&#039;våren $date1&#039;,&lt;br /&gt;
		nds=&#039;Vörjohr $date1&#039;,&lt;br /&gt;
		nn=&#039;våren $date1&#039;,&lt;br /&gt;
		nl=&#039;voorjaar $date1&#039;,&lt;br /&gt;
		no=&#039;våren $date1&#039;,&lt;br /&gt;
		pl=&#039;wiosna $date1&#039;,&lt;br /&gt;
		pt=&#039;primavera de $date1&#039;,&lt;br /&gt;
		ro=&#039;primăvara lui $date1&#039;,&lt;br /&gt;
		ru=&#039;весна $date1&#039;,&lt;br /&gt;
		sk={&#039;jar $date1&#039;, case={&#039;gen&#039;, &#039;&#039;}},&lt;br /&gt;
		sl=&#039;pomlad $date1&#039;,&lt;br /&gt;
		sv=&#039;våren $date1&#039;,&lt;br /&gt;
		uk=&#039;весна $date1&#039;,&lt;br /&gt;
		ur=&#039;بہار $date1&#039;,&lt;br /&gt;
		vi=&#039;mùa đông năm $date1&#039;,&lt;br /&gt;
		[&#039;zh-hans&#039;]=&#039;{{#if:$date1|$date1年}}春季&#039;,&lt;br /&gt;
		[&#039;zh-hant&#039;]=&#039;{{#if:$date1|$date1年}}春季&#039;,&lt;br /&gt;
		--default=&#039;{{Please translate|Spring $date1|Module:I18n/complex date}}&#039;,&lt;br /&gt;
		default=&#039;&amp;lt;span style=&amp;quot;color:red&amp;quot;&amp;gt;Spring $date1&amp;lt;/span&amp;gt;&#039;,&lt;br /&gt;
	},&lt;br /&gt;
&lt;br /&gt;
	[&#039;summer&#039;] = {&lt;br /&gt;
		nDates = 1,&lt;br /&gt;
		ar=&#039;صيف $date1&#039;,&lt;br /&gt;
		[&#039;be-tarask&#039;]=&#039;лета $date1&#039;,&lt;br /&gt;
		bn=&#039;গ্রীষ্মকাল $date1&#039;,&lt;br /&gt;
		ca=&#039;estiu $date1&#039;,&lt;br /&gt;
		cs={&#039;léto $date1&#039;, case={&#039;gen&#039;, &#039;&#039;}},&lt;br /&gt;
		da=&#039;Sommer $date1&#039;,&lt;br /&gt;
		de=&#039;Sommer $date1&#039;,&lt;br /&gt;
		en=&#039;Summer $date1&#039;,&lt;br /&gt;
		[&#039;en-gb&#039;]=&#039;Summer $date1&#039;,&lt;br /&gt;
		[&#039;en-ca&#039;]=&#039;Summer $date1&#039;,&lt;br /&gt;
		eo=&#039;somero $date1&#039;,&lt;br /&gt;
		es=&#039;verano de $date1&#039;,&lt;br /&gt;
		et=&#039;$date1 suvi&#039;,&lt;br /&gt;
		fa=&#039;تابستان $date1&#039;,&lt;br /&gt;
		fi=&#039;Kesä $date1&#039;,&lt;br /&gt;
		fr=&#039;été $date1&#039;,&lt;br /&gt;
		gl=&#039;verán $date1&#039;,&lt;br /&gt;
		he=&#039;קיץ $date1&#039;,&lt;br /&gt;
		hr=&#039;ljeto $date1&#039;,&lt;br /&gt;
		hsb=&#039;lěćo $date1&#039;,&lt;br /&gt;
		hu=&#039;$date1 nyara&#039;,&lt;br /&gt;
		it=&#039;estate $date1&#039;,&lt;br /&gt;
		ja=&#039;{{#if:$date1|$date1年}}夏&#039;,&lt;br /&gt;
		mk=&#039;лето $date1&#039;,&lt;br /&gt;
		ml=&#039;$date1 വേനൽ&#039;,&lt;br /&gt;
		nb=&#039;sommeren $date1&#039;,&lt;br /&gt;
		nds=&#039;Sommer $date1&#039;,&lt;br /&gt;
		nn=&#039;sumaren $date1&#039;,&lt;br /&gt;
		nl=&#039;zomer $date1&#039;,&lt;br /&gt;
		no=&#039;sommeren $date1&#039;,&lt;br /&gt;
		pl=&#039;lato $date1&#039;,&lt;br /&gt;
		pt=&#039;verão de $date1&#039;,&lt;br /&gt;
		ro=&#039;vara lui $date1&#039;,&lt;br /&gt;
		ru=&#039;лето $date1&#039;,&lt;br /&gt;
		sk={&#039;leto $date1&#039;, case={&#039;gen&#039;, &#039;&#039;}},&lt;br /&gt;
		sl=&#039;poletje $date1&#039;,&lt;br /&gt;
		sv=&#039;sommaren $date1&#039;,&lt;br /&gt;
		uk=&#039;літо $date1&#039;,&lt;br /&gt;
		ur=&#039;گرما $date1&#039;,&lt;br /&gt;
		vi=&#039;mùa hè năm $date1&#039;,&lt;br /&gt;
		[&#039;zh-hans&#039;]=&#039;{{#if:$date1|$date1年}}夏季&#039;,&lt;br /&gt;
		[&#039;zh-hant&#039;]=&#039;{{#if:$date1|$date1年}}夏季&#039;,&lt;br /&gt;
		--default=&#039;{{Please translate|SAutumn $date1|Module:I18n/complex date}}&#039;,&lt;br /&gt;
		default=&#039;&amp;lt;span style=&amp;quot;color:red&amp;quot;&amp;gt;Summer $date1&amp;lt;/span&amp;gt;&#039;,&lt;br /&gt;
	},&lt;br /&gt;
&lt;br /&gt;
	[&#039;autumn&#039;] = {&lt;br /&gt;
		nDates = 1,&lt;br /&gt;
		ar=&#039;خريف $date1&#039;,&lt;br /&gt;
		[&#039;be-tarask&#039;]=&#039;восень $date1&#039;,&lt;br /&gt;
		bn=&#039;শরত্কাল $date1&#039;,&lt;br /&gt;
		ca=&#039;tardor $date1&#039;,&lt;br /&gt;
		cs={&#039;podzim $date1&#039;, case={&#039;gen&#039;, &#039;&#039;}},&lt;br /&gt;
		da=&#039;Efterår $date1&#039;,&lt;br /&gt;
		de=&#039;Herbst $date1&#039;,&lt;br /&gt;
		en=&#039;Autumn $date1&#039;,&lt;br /&gt;
		[&#039;en-gb&#039;]=&#039;Autumn $date1&#039;,&lt;br /&gt;
		[&#039;en-ca&#039;]=&#039;Autumn $date1&#039;,&lt;br /&gt;
		eo=&#039;aŭtuno $date1&#039;,&lt;br /&gt;
		es=&#039;otoño de $date1&#039;,&lt;br /&gt;
		et=&#039;$date1 sügis&#039;,&lt;br /&gt;
		fa=&#039;پاییز $date1&#039;,&lt;br /&gt;
		fi=&#039;Syksy $date1&#039;,&lt;br /&gt;
		fr=&#039;automne $date1&#039;,&lt;br /&gt;
		gl=&#039;outono $date1&#039;,&lt;br /&gt;
		he=&#039;סתיו $date1&#039;,&lt;br /&gt;
		hr=&#039;jesen $date1&#039;,&lt;br /&gt;
		hsb=&#039;nazyma $date1&#039;,&lt;br /&gt;
		hu=&#039;$date1 ősze&#039;,&lt;br /&gt;
		it=&#039;autunno $date1&#039;,&lt;br /&gt;
		ja=&#039;{{#if:$date1|$date1年}}秋&#039;,&lt;br /&gt;
		mk=&#039;есен $date1&#039;,&lt;br /&gt;
		ml=&#039;$date1 ശരത്കാലം&#039;,&lt;br /&gt;
		nb=&#039;høsten $date1&#039;,&lt;br /&gt;
		nds=&#039;Harvst $date1&#039;,&lt;br /&gt;
		nn=&#039;hausten $date1&#039;,&lt;br /&gt;
		nl=&#039;herfst $date1&#039;,&lt;br /&gt;
		no=&#039;høsten $date1&#039;,&lt;br /&gt;
		pl=&#039;jesień $date1&#039;,&lt;br /&gt;
		pt=&#039;outono de $date1&#039;,&lt;br /&gt;
		ro=&#039;toamna lui $date1&#039;,&lt;br /&gt;
		ru=&#039;осень $date1&#039;,&lt;br /&gt;
		sk={&#039;jeseň $date1&#039;, case={&#039;gen&#039;, &#039;&#039;}},&lt;br /&gt;
		sl=&#039;jesen $date1&#039;,&lt;br /&gt;
		sv=&#039;hösten $date1&#039;,&lt;br /&gt;
		uk=&#039;осінь $date1&#039;,&lt;br /&gt;
		ur=&#039;خزاں $date1&#039;,&lt;br /&gt;
		vi=&#039;mùa thu năm $date1&#039;,&lt;br /&gt;
		[&#039;zh-hans&#039;]=&#039;{{#if:$date1|$date1年}}秋季&#039;,&lt;br /&gt;
		[&#039;zh-hant&#039;]=&#039;{{#if:$date1|$date1年}}秋季&#039;,&lt;br /&gt;
		--default=&#039;{{Please translate|Autumn $date1|Module:I18n/complex date}}&#039;,&lt;br /&gt;
		default=&#039;&amp;lt;span style=&amp;quot;color:red&amp;quot;&amp;gt;Autumn $date1&amp;lt;/span&amp;gt;&#039;,&lt;br /&gt;
	},&lt;br /&gt;
&lt;br /&gt;
	[&#039;winter&#039;] = {&lt;br /&gt;
		nDates = 1,&lt;br /&gt;
		ar=&#039;شتاء $date1&#039;,&lt;br /&gt;
		[&#039;be-tarask&#039;]=&#039;зіма $date1&#039;,&lt;br /&gt;
		bn=&#039;শীতকাল $date1&#039;,&lt;br /&gt;
		ca=&#039;hivern $date1&#039;,&lt;br /&gt;
		cs={&#039;zima $date1&#039;, case={&#039;gen&#039;, &#039;&#039;}},&lt;br /&gt;
		da=&#039;Vinter $date1&#039;,&lt;br /&gt;
		de=&#039;Winter $date1&#039;,&lt;br /&gt;
		en=&#039;Winter $date1&#039;,&lt;br /&gt;
		[&#039;en-gb&#039;]=&#039;Winter $date1&#039;,&lt;br /&gt;
		[&#039;en-ca&#039;]=&#039;Winter $date1&#039;,&lt;br /&gt;
		eo=&#039;vintro $date1&#039;,&lt;br /&gt;
		es=&#039;invierno de $date1&#039;,&lt;br /&gt;
		et=&#039;$date1 talv&#039;,&lt;br /&gt;
		fa=&#039;زمستان $date1&#039;,&lt;br /&gt;
		fi=&#039;Talvi $date1&#039;,&lt;br /&gt;
		fr=&#039;hiver $date1&#039;,&lt;br /&gt;
		gl=&#039;inverno $date1&#039;,&lt;br /&gt;
		he=&#039;חורף $date1&#039;,&lt;br /&gt;
		hr=&#039;zima $date1&#039;,&lt;br /&gt;
		hsb=&#039;zyma $date1&#039;,&lt;br /&gt;
		hu=&#039;$date1 tele&#039;,&lt;br /&gt;
		it=&#039;inverno $date1&#039;,&lt;br /&gt;
		ja=&#039;{{#if:$date1|$date1年}}冬&#039;,&lt;br /&gt;
		mk=&#039;зима $date1&#039;,&lt;br /&gt;
		ml=&#039;$date1 ശൈത്യകാലം&#039;,&lt;br /&gt;
		nds=&#039;Winter $date1&#039;,&lt;br /&gt;
		nl=&#039;winter $date1&#039;,&lt;br /&gt;
		nb=&#039;vinteren $date1&#039;,&lt;br /&gt;
		nn=&#039;vinteren $date1&#039;,&lt;br /&gt;
		no=&#039;vinteren $date1&#039;,&lt;br /&gt;
		pl=&#039;zima $date1&#039;,&lt;br /&gt;
		pt=&#039;inverno de $date1&#039;,&lt;br /&gt;
		ro=&#039;iarna lui $date1&#039;,&lt;br /&gt;
		ru=&#039;зима $date1&#039;,&lt;br /&gt;
		sk={&#039;zima $date1&#039;, case={&#039;gen&#039;, &#039;&#039;}},&lt;br /&gt;
		sl=&#039;zima $date1&#039;,&lt;br /&gt;
		sv=&#039;vintern $date1&#039;,&lt;br /&gt;
		uk=&#039;зима $date1&#039;,&lt;br /&gt;
		ur=&#039;سرما $date1&#039;,&lt;br /&gt;
		vi=&#039;mùa đông năm $date1&#039;,&lt;br /&gt;
		[&#039;zh-hans&#039;]=&#039;{{#if:$date1|$date1年}}冬季&#039;,&lt;br /&gt;
		[&#039;zh-hant&#039;]=&#039;{{#if:$date1|$date1年}}冬季&#039;,&lt;br /&gt;
		--default=&#039;{{Please translate|Winter $date1|Module:I18n/complex date}}&#039;,&lt;br /&gt;
		default=&#039;&amp;lt;span style=&amp;quot;color:red&amp;quot;&amp;gt;Winter $date1&amp;lt;/span&amp;gt;&#039;,&lt;br /&gt;
	},&lt;br /&gt;
&lt;br /&gt;
	-- ==========================================&lt;br /&gt;
	-- === Decade/Century/Millennium ============&lt;br /&gt;
	-- ==========================================&lt;br /&gt;
	[&#039;decade&#039;] = {&lt;br /&gt;
		nDates = 1,&lt;br /&gt;
		ar=&#039;أعوام $date1&#039;,&lt;br /&gt;
		[&#039;be-tarask&#039;]=&#039;$date1-я гады&#039;,&lt;br /&gt;
		bn=&#039;$date1-এর দশক&#039;,&lt;br /&gt;
		ca=&#039;dècada del $date1&#039;,&lt;br /&gt;
		cs=function(date1, state) return ((date1 % 100 == 0) and &#039;první dekáda&#039; or ((date1 % 100) .. &#039;. léta&#039;)) .. &#039; &#039; .. (math.floor(date1 / 100) + 1) .. &#039;. století&#039; end,&lt;br /&gt;
		da=&amp;quot;$date1&#039;erne&amp;quot;,&lt;br /&gt;
		de=&#039;$date1er-Jahre&#039;,&lt;br /&gt;
		el=&#039;δεκαετία του $date1&#039;,&lt;br /&gt;
		en=&#039;$date1s&#039;,&lt;br /&gt;
		[&#039;en-gb&#039;]=&#039;$date1s&#039;,&lt;br /&gt;
		[&#039;en-ca&#039;]=&#039;$date1s&#039;,&lt;br /&gt;
		eo=&#039;$date1-aj jaroj&#039;,&lt;br /&gt;
		es=&#039;años $date1&#039;,&lt;br /&gt;
		et=&#039;$date1ndad&#039;,&lt;br /&gt;
		fa=&#039;دههٔ $date1&#039;,&lt;br /&gt;
		fi=&#039;$date1-luvulla&#039;,&lt;br /&gt;
		fr=&#039;années $date1&#039;,&lt;br /&gt;
		gl=&#039;anos $date1&#039;,&lt;br /&gt;
		he=&#039;שנות ה-$date1&#039;,&lt;br /&gt;
		hr=&#039;$date1-ih&#039;,&lt;br /&gt;
		hsb=&#039;$date1te lěta&#039;,&lt;br /&gt;
		hu=&#039;$date1-s évek&#039;,&lt;br /&gt;
		it=&amp;quot;{{#ifexpr: $date1 mod 100 = 0 | primo decennio del {{Roman|{{#expr: ($date1 / 100) + 1}}}} sec. | anni &#039;{{#expr: $date1 mod 100 }} del {{Roman|{{#expr: floor($date1 / 100) + 1}}}} sec.}}&amp;quot;,&lt;br /&gt;
		ja=&#039;$date1年代&#039;,&lt;br /&gt;
		mk=&#039;$date1-ти&#039;,&lt;br /&gt;
		ml=&#039;ദശകം $date1-ൽ&#039;,&lt;br /&gt;
		nb=&#039;$date1-årene&#039;,&lt;br /&gt;
		nn=&#039;$date1-åra&#039;,&lt;br /&gt;
		nds=&#039;Johren $date1&#039;,&lt;br /&gt;
		nl=&#039;jaren $date1&#039;,&lt;br /&gt;
		no=&#039;$date1-årene&#039;,&lt;br /&gt;
		pl=function(date1, state) &lt;br /&gt;
			local str = &#039;lata &#039;..(date1 % 100)..&#039;. &#039;&lt;br /&gt;
			if (date1 % 100 == 0) then&lt;br /&gt;
				str = &#039;pierwsza dekada &#039;&lt;br /&gt;
			elseif (date1 % 100 == 10) then&lt;br /&gt;
				str = &#039;druga dekada &#039;&lt;br /&gt;
			end&lt;br /&gt;
			return str .. Roman(math.floor(date1 / 100) + 1) .. &#039; wieku&#039; &lt;br /&gt;
		end,&lt;br /&gt;
		pt=&#039;década de $date1&#039;,&lt;br /&gt;
		qu=&#039;$date1 watakuna&#039;,&lt;br /&gt;
		ro=&#039;anii $date1&#039;,&lt;br /&gt;
		ru=&#039;$date1-е годы&#039;,&lt;br /&gt;
		sk=function(date1, state) return ((date1 % 100 == 0) and &#039;prvé desaťročie&#039; or ((date1 % 100) .. &#039;. roky&#039;)) .. &#039; &#039; .. (math.floor(date1 / 100) + 1) .. &#039;. storočia&#039; end,&lt;br /&gt;
		sl=&#039;$date1-ta leta&#039;,&lt;br /&gt;
		sv=&#039;$date1-talet{{#switch:$date1|1300|1400|1500|1600|1700|1800|1900|2000|2100=&amp;amp;nbsp;(decennium)}}&#039;,&lt;br /&gt;
		uk=&#039;$date1-ті роки&#039;,&lt;br /&gt;
		ur=&#039;دہائی $date1&#039;,&lt;br /&gt;
		vi=&#039;thập niên $date1&#039;,&lt;br /&gt;
		[&#039;zh-hans&#039;]=&#039;$date1年代&#039;,&lt;br /&gt;
		[&#039;zh-hant&#039;]=&#039;$date1年代&#039;,&lt;br /&gt;
		--default=&#039;{{Please translate|$date1s|Module:I18n/complex date}}&#039;,&lt;br /&gt;
		default=&#039;&amp;lt;span style=&amp;quot;color:red&amp;quot;&amp;gt;$date1s&amp;lt;/span&amp;gt;&#039;,&lt;br /&gt;
	},&lt;br /&gt;
&lt;br /&gt;
	[&#039;century&#039;] = {&lt;br /&gt;
		nDates = 1,&lt;br /&gt;
		ar=&#039;القرن $date1&#039;,&lt;br /&gt;
		[&#039;be-tarask&#039;]=function(date1, state) return Ordinal(date1, &#039;be-tarask&#039;) .. &#039; стагодзьдзе&#039; end,&lt;br /&gt;
		bn=function(date1, state) return Ordinal(date1, &#039;bn&#039;) .. &#039; শতাব্দী&#039; end,&lt;br /&gt;
		ca=&#039;segle {{small-caps|{{lc:{{Roman year|$date1}}}}}}&#039;,&lt;br /&gt;
		cs=&#039;$date1. století&#039;,&lt;br /&gt;
		da=&#039;$date1. århundrede&#039;,&lt;br /&gt;
		de=&#039;$date1. Jahrhundert&#039;,&lt;br /&gt;
		el=&#039;$date1ος αιώνας&#039;,&lt;br /&gt;
		en=function(date1, state) return Ordinal(date1, &#039;en&#039;) .. &#039; century&#039; end,&lt;br /&gt;
		[&#039;en-gb&#039;]=function(date1, state) return Ordinal(date1, &#039;en-gb&#039;) .. &#039; century&#039; end,&lt;br /&gt;
		[&#039;en-ca&#039;]=function(date1, state) return Ordinal(date1, &#039;en-ca&#039;) .. &#039; century&#039; end,&lt;br /&gt;
		eo=&#039;$date1-a jarcento&#039;,&lt;br /&gt;
		es=function(date1, state) return &#039;siglo &#039; .. Roman(date1) end,&lt;br /&gt;
		et=&#039;$date1. sajand&#039;,&lt;br /&gt;
		fa=&#039;سدهٔ $date1&#039;,&lt;br /&gt;
		fi=&#039;{{#expr: ($date1 - 1) * 100}}-luvulla&#039;,&lt;br /&gt;
		fr=function(date1, state) return Ordinal(date1, &#039;fr&#039;, &#039;roman&#039;, &#039;m&#039;) .. &#039; siècle&#039; end,&lt;br /&gt;
		gl=function(date1, state) return &#039;século &#039; .. Roman(date1) end,&lt;br /&gt;
		he=&#039;המאה ה-$date1&#039;,&lt;br /&gt;
		hr=&#039;$date1. stoljeće&#039;,&lt;br /&gt;
		hsb=&#039;$date1. lětstotk&#039;,&lt;br /&gt;
		hu=&#039;$date1. évszázad&#039;,&lt;br /&gt;
		it=function(date1, state) return Roman(date1) .. &#039; sec.&#039; end,&lt;br /&gt;
		ja=&#039;$date1世紀&#039;,&lt;br /&gt;
		la=&#039;saeculum $date1&#039;,&lt;br /&gt;
		mk=function(date1, state) return Roman(date1) .. &#039; век&#039; end,&lt;br /&gt;
		ml=&#039;$date1-ആം നൂറ്റാണ്ട്&#039;,&lt;br /&gt;
		nb=function(date1, state) return Ordinal(date1, &#039;nb&#039;) .. &#039; århundre&#039; end,&lt;br /&gt;
		nn=function(date1, state) return &#039;det &#039; .. Ordinal(date1, &#039;no&#039;) .. &#039; århundre&#039; end,&lt;br /&gt;
		nds=&#039;$date1. Johrhunnert&#039;,&lt;br /&gt;
		nl=&#039;$date1e eeuw&#039;,&lt;br /&gt;
		no=function(date1, state) return Ordinal(date1, &#039;no&#039;) .. &#039; århundre&#039; end,&lt;br /&gt;
		pl=function(date1, state) return Roman(date1) .. &#039; &#039; .. decCentury(&#039;pl&#039;,state.case) end,&lt;br /&gt;
		pt=function(date1, state) return &#039;século &#039; .. Roman(date1) end,&lt;br /&gt;
		qu=&#039;$date1 ñiqin pachakwata&#039;,&lt;br /&gt;
		ro=&#039;secolul al $date1-lea&#039;,&lt;br /&gt;
		ru=function(date1, state) return Roman(date1) .. &#039; век&#039; end,&lt;br /&gt;
		sk=&#039;$date1. storočie&#039;,&lt;br /&gt;
		sl=function(date1, state) return Ordinal(date1, &#039;sl&#039;) .. &#039;. stoletje&#039; end,&lt;br /&gt;
		sv=&#039;{{#expr:$date1 - 1}}00-talet&#039;,&lt;br /&gt;
		tt=function(date1, state) return Roman(date1) .. &#039; гасыр&#039; end,&lt;br /&gt;
		uk=function(date1, state) return Roman(date1) .. &#039; ст.&#039; end,&lt;br /&gt;
		ur=&#039;صدی $date1&#039;,&lt;br /&gt;
		vi=&#039;thế kỷ $date1&#039;,&lt;br /&gt;
		[&#039;zh-hans&#039;]=&#039;$date1世纪&#039;,&lt;br /&gt;
		[&#039;zh-hant&#039;]=&#039;$date1世紀&#039;,&lt;br /&gt;
		default=&#039;&amp;lt;span style=&amp;quot;color:red&amp;quot;&amp;gt;$date1 century&amp;lt;/span&amp;gt;&#039;,&lt;br /&gt;
	},&lt;br /&gt;
&lt;br /&gt;
	[&#039;millennium&#039;] = {&lt;br /&gt;
		nDates = 1,&lt;br /&gt;
		[&#039;be-tarask&#039;]=function(date1, state) return Ordinal(date1, &#039;be-tarask&#039;) .. &#039; тысячагодзьдзе&#039; end,&lt;br /&gt;
		bn=function(date1, state) return Ordinal(date1, &#039;bn&#039;) .. &#039; সহস্রাব্দ&#039; end,&lt;br /&gt;
		cs=&#039;$date1. tisíciletí&#039;,&lt;br /&gt;
		de=&#039;$date1. Jahrtausend&#039;,&lt;br /&gt;
		en=function(date1, state) return Ordinal(date1, &#039;en&#039;) .. &#039; millennium&#039; end,&lt;br /&gt;
		[&#039;en-gb&#039;]=function(date1, state) return Ordinal(date1, &#039;en-gb&#039;) .. &#039; millennium&#039; end,&lt;br /&gt;
		[&#039;en-ca&#039;]=function(date1, state) return Ordinal(date1, &#039;en-ca&#039;) .. &#039; millennium&#039; end,&lt;br /&gt;
		eo=&#039;$date1-a jarmilo&#039;,&lt;br /&gt;
		es=function(date1, state) return Roman(date1) .. &#039; milenio&#039; end,&lt;br /&gt;
		fa=function(date1, state) return &#039;هزارهٔ &#039; .. Ordinal(date1, &#039;fa&#039;) end,&lt;br /&gt;
		fr=function(date1, state) return Ordinal(date1, &#039;fr&#039;, &#039;roman&#039;, &#039;m&#039;) .. &#039; millénaire&#039; end,&lt;br /&gt;
		hr=&#039;$date1. tisućljeće&#039;,&lt;br /&gt;
		hsb=&#039;$date1. lěttysac&#039;,&lt;br /&gt;
		it=function(date1, state) return Roman(date1) .. &#039; millennio&#039; end,&lt;br /&gt;
		ja=&#039;$date1千年紀&#039;,&lt;br /&gt;
		la=&#039;millennium $date1&#039;,&lt;br /&gt;
		nb=function(date1, state) return Ordinal(date1, &#039;nb&#039;) .. &#039; årtusen&#039; end,&lt;br /&gt;
		nn=function(date1, state) return Ordinal(date1, &#039;no&#039;) .. &#039; tusenår&#039; end,&lt;br /&gt;
		nl=&#039;$date1e millennium&#039;,&lt;br /&gt;
		no=function(date1, state) return Ordinal(date1, &#039;no&#039;) .. &#039; årtusen&#039; end,&lt;br /&gt;
		pl=function(date1, state) return Roman(date1) .. &#039; &#039; .. decMillennium(&#039;pl&#039;,state.case) end,&lt;br /&gt;
		pt=function(date1, state) return Roman(date1) .. &#039; milénio&#039; end,&lt;br /&gt;
		qu=&#039;$date1 ñiqin waranqawata&#039;,&lt;br /&gt;
		ru=function(date1, state) return Roman(date1) .. &#039; тысячелетие&#039; end,&lt;br /&gt;
		sk=&#039;$date1. tisícročie&#039;,&lt;br /&gt;
		sl=function(date1, state) return Ordinal(date1, &#039;sl&#039;) .. &#039;. tisočletje&#039; end,&lt;br /&gt;
		sv=function(date1, state) return Ordinal(date1, &#039;sv&#039;) .. &#039; årtusendet&#039; end,&lt;br /&gt;
		uk=function(date1, state) return Roman(date1) .. &#039; тис.&#039; end,&lt;br /&gt;
		ur=function(date1, state) return &#039;ہزارہ &#039; .. Ordinal(date1, &#039;ur&#039;) end,&lt;br /&gt;
		vi=&#039;thiên niên kỷ $date1&#039;,&lt;br /&gt;
		[&#039;zh-hans&#039;]=function(date1, state) return Ordinal(date1, &#039;zh-hans&#039;) .. &#039;千年&#039; end,&lt;br /&gt;
		[&#039;zh-hant&#039;]=function(date1, state) return Ordinal(date1, &#039;zh-hant&#039;) .. &#039;千年&#039; end,&lt;br /&gt;
		--default=&#039;{{Please translate|$date1 millennium|Module:I18n/complex date}}&#039;,&lt;br /&gt;
		default=&#039;&amp;lt;span style=&amp;quot;color:red&amp;quot;&amp;gt;$date1 millennium&amp;lt;/span&amp;gt;&#039;,&lt;br /&gt;
	},&lt;br /&gt;
&lt;br /&gt;
	[&#039;million&#039;] = {&lt;br /&gt;
		de = &#039;$date1 Millionen Jahre&#039;,&lt;br /&gt;
		en = &#039;$date1 million years&#039;,&lt;br /&gt;
		[&#039;en-gb&#039;] = &#039;$date1 million years&#039;,&lt;br /&gt;
		[&#039;en-ca&#039;] = &#039;$date1 million years&#039;,&lt;br /&gt;
		eo = &#039;$date1 milionoj da jaroj&#039;,&lt;br /&gt;
		es = &#039;$date1 millones de años&#039;,&lt;br /&gt;
		nl = &#039;$date1e miljoen jaar&#039;,&lt;br /&gt;
		fr = &#039;$date1 millions d’années&#039;,&lt;br /&gt;
		it = &#039;$date1 milioni di anni&#039;,&lt;br /&gt;
		nb = &#039;$date1 millioner år&#039;,&lt;br /&gt;
		nl = &#039;$date1 miljoen jaar&#039;,&lt;br /&gt;
		nn = &#039;$date1 millionar år&#039;,&lt;br /&gt;
		pl = &#039;$date1 milionów lat&#039;,&lt;br /&gt;
		pt = &#039;$date1 milhões de anos&#039;,&lt;br /&gt;
		ru = &#039;$date1 миллиона лет&#039;,&lt;br /&gt;
		uk = &#039;$date1 мільйони років&#039;,&lt;br /&gt;
		ur = &#039;$date1 ملین سال&#039;,&lt;br /&gt;
		[&#039;zh-hans&#039;] = &#039;$date1百万年&#039;,&lt;br /&gt;
		[&#039;zh-hant&#039;] = &#039;$date1百万年&#039;,&lt;br /&gt;
		default=&#039;&amp;lt;span style=&amp;quot;color:red&amp;quot;&amp;gt;$date1 million years&amp;lt;/span&amp;gt;&#039;,&lt;br /&gt;
		nDates = 1,&lt;br /&gt;
	},&lt;br /&gt;
	&lt;br /&gt;
	[&#039;billion&#039;] = {&lt;br /&gt;
		de = &#039;$date1 Milliarden Jahre&#039;,&lt;br /&gt;
		en = &#039;$date1 billion years&#039;,&lt;br /&gt;
		[&#039;en-gb&#039;] = &#039;$date1 billion years&#039;,&lt;br /&gt;
		[&#039;en-ca&#039;] = &#039;$date1 billion years&#039;,&lt;br /&gt;
		es = &#039;$date1 mil millones de años&#039;,&lt;br /&gt;
		nl = &#039;$date1e miljard jaar&#039;,&lt;br /&gt;
		fr = &#039;$date1 milliard d’années&#039;,&lt;br /&gt;
		it = &#039;$date1 miliardi di anni&#039;,&lt;br /&gt;
		nb = &#039;$date1 milliarder år&#039;,&lt;br /&gt;
		nl = &#039;$date1 miljard jaar&#039;,&lt;br /&gt;
		nn = &#039;$date1 milliardar år&#039;,&lt;br /&gt;
		pl = &#039;$date1 miliardów lat&#039;,&lt;br /&gt;
		pt = &#039;$date1 mil milhões de anos&#039;,&lt;br /&gt;
		ru = &#039;$date1 миллиардов лет&#039;,&lt;br /&gt;
		uk = &#039;$date1 мільярдів років&#039;,&lt;br /&gt;
		ur = &#039;$date1 بلین سال&#039;,&lt;br /&gt;
		[&#039;zh-hans&#039;] = &#039;$date1十亿年&#039;,&lt;br /&gt;
		[&#039;zh-hant&#039;] = &#039;$date1十億年&#039;,&lt;br /&gt;
		default=&#039;&amp;lt;span style=&amp;quot;color:red$date1 billion years&amp;lt;/span&amp;gt;&#039;,&lt;br /&gt;
		nDates = 1,&lt;br /&gt;
	},&lt;br /&gt;
&lt;br /&gt;
	-- ==========================================&lt;br /&gt;
	-- === Complex phrases ======================&lt;br /&gt;
	-- ==========================================&lt;br /&gt;
	-- Phrases which for some languages can be build out of simpler phrases&lt;br /&gt;
	-- Their &amp;quot;default&amp;quot; state, used when no translation in the requested language was found, returns a &amp;quot;state&amp;quot; like &lt;br /&gt;
	-- table which is used to call the function again and built the phrase out of simple phrases&lt;br /&gt;
&lt;br /&gt;
	-- $date1 - original date - 1&lt;br /&gt;
	-- $date2 - original date &lt;br /&gt;
	-- if era is BC than $date1 and $date2 are swapped&lt;br /&gt;
	[&#039;turn of the century&#039;] = { &lt;br /&gt;
		nDates = 2,&lt;br /&gt;
		[&#039;be-tarask&#039;]=function(date1, date2, state) return &#039;канец &#039; .. Roman(date1) ..&#039; — пачатак &#039; .. Roman(date2) ..&#039; стагодзьдзя&#039; end,&lt;br /&gt;
		bn=function(date1, date2, state) return &#039;$date1/&#039; .. Ordinal(date2, &#039;bn&#039;) .. &#039; শতাব্দীর পালাবদলে&#039; end,&lt;br /&gt;
		cs=&#039;přelom $date1. a $date2. století&#039;,&lt;br /&gt;
		de=function(date1, date2, state) return &#039;Jahrhundertwende $date1/&#039; .. Ordinal(date2, &#039;de&#039;) end,&lt;br /&gt;
		en=function(date1, date2, state) return &#039;turn of the $date1/&#039; .. Ordinal(date2, &#039;en&#039;) .. &#039; century&#039; end,&lt;br /&gt;
		[&#039;en-gb&#039;]=function(date1, date2, state) return &#039;turn of the $date1/&#039; .. Ordinal(date2, &#039;en-gb&#039;) .. &#039; century&#039; end,&lt;br /&gt;
		[&#039;en-ca&#039;]=function(date1, date2, state) return &#039;turn of the $date1/&#039; .. Ordinal(date2, &#039;en-ca&#039;) .. &#039; century&#039; end,&lt;br /&gt;
		eo=&#039;ŝanĝo de la $date1-a al la $date2-a jarcentoj&#039;,&lt;br /&gt;
		es=function(date1, date2, state) return &#039;hacia finales del siglo &#039; .. Roman(date1) .. &#039; y principios del siglo &#039; .. Roman(date2) .. &#039;&#039; end,&lt;br /&gt;
		fi=&#039;{{#expr: $date1 * 100-100}}-luvun loppu ja {{#expr: $date2 * 100-100}}-luvun alku&#039;,&lt;br /&gt;
		fr=function(date1, date2, state) return &#039;fin du &#039; .. Ordinal(date1, &#039;fr&#039;, &#039;roman&#039;, &#039;m&#039;) .. &#039; siècle / début du &#039; .. Ordinal(date2, &#039;fr&#039;, &#039;roman&#039;, &#039;m&#039;) end,&lt;br /&gt;
		hr=&#039;kraj $date1. i početak $date2. stoljeća&#039;,&lt;br /&gt;
		hsb=function(date1, date2, state) return &#039;přechod &#039; .. Roman(date1) ..&#039; do &#039; .. Roman(date2) ..&#039; lětstotka&#039; end,&lt;br /&gt;
		it=function(date1, date2, state) return &#039;fine del &#039; .. Roman(date1) .. &#039; sec. e inizio del &#039; .. Roman(date2) .. &#039; sec.&#039; end,&lt;br /&gt;
		ja=&#039;$date1世紀から$date2世紀への変わり目&#039;,&lt;br /&gt;
		nb=function(date1, date2, state) return &#039;slutten av det &#039; .. Ordinal(date1, &#039;nb&#039;) .. &#039; århundre/begynnelsen av det &#039; .. Ordinal(date2, &#039;nb&#039;) .. &#039; århundre&#039; end,&lt;br /&gt;
		nl=function(date1, date2, state) return &#039;eind $date1e/begin $date2e eeuw&#039; end,&lt;br /&gt;
		nn=function(date1, date2, state) return &#039;slutten av det &#039; .. Ordinal(date1, &#039;nn&#039;) .. &#039; hundreåret/byrjinga av det &#039; .. Ordinal(date2, &#039;nn&#039;) .. &#039; hundreåret&#039; end,&lt;br /&gt;
		pl=function(date1, date2, state) return &#039;przełom &#039; .. Roman(date1) ..&#039; i &#039; .. Roman(date2) ..&#039; wieku&#039; end,&lt;br /&gt;
		qu=&amp;quot;$date1 ñiqin waranqawatamanta $date2 ñiqin waranqawataman t&#039;ikrasqanpi&amp;quot;,&lt;br /&gt;
		ru=function(date1, date2, state) return &#039;конец &#039; .. Roman(date1) ..&#039; — начало &#039; .. Roman(date2) ..&#039; века&#039; end,&lt;br /&gt;
		sk=&#039;prelom $date1. a $date2. storočia&#039;,&lt;br /&gt;
		sl=function(date1, date2, state) return &#039;pozno &#039; .. Ordinal(date1, &#039;sl&#039;) .. &#039;. in zgodnje &#039; .. Ordinal(date2, &#039;sl&#039;) .. &#039;. stoletje&#039; end,&lt;br /&gt;
		sv=function(date1, date2, state) return &#039;$date1/&#039; .. Ordinal(date2, &#039;sv&#039;) .. &#039; årtusendets sekelskifte&#039; end,&lt;br /&gt;
		uk=function(date1, date2, state) return &#039;кін. &#039; .. Roman(date1) ..&#039; ст. — поч. &#039; .. Roman(date2) ..&#039; ст.&#039; end,&lt;br /&gt;
		vi=&#039;bước sang thế kỷ $date2&#039;,&lt;br /&gt;
		[&#039;zh-hans&#039;]=function(date1, date2, state) return &#039;$date1世纪末&#039; .. Ordinal(date2, &#039;zh-hans&#039;) .. &#039;世纪初&#039; end,&lt;br /&gt;
		[&#039;zh-hant&#039;]=function(date1, date2, state) return &#039;$date1世紀末&#039; .. Ordinal(date2, &#039;zh-hant&#039;) .. &#039;世紀初&#039; end,&lt;br /&gt;
		default=function(date1, date2, state) return {conj=&#039;and&#039;, adj1 = &#039;late&#039;, unit1=&#039;century&#039;, era1=state.era1, adj2 = &#039;early&#039;,  unit2=&#039;century&#039;, era2=state.era2} end,&lt;br /&gt;
	},&lt;br /&gt;
&lt;br /&gt;
	-- $date1 - original date - 10&lt;br /&gt;
	-- $date2 - original date &lt;br /&gt;
	-- if era is BC than $date1 and $date2 are swapped&lt;br /&gt;
	[&#039;turn of the decade&#039;]={&lt;br /&gt;
		nDates = 2,&lt;br /&gt;
		[&#039;be-tarask&#039;]=&#039;канец $date1-х — пачатак $date2-х гг.&#039;,&lt;br /&gt;
		bn=&#039;$date1-এর দশকের শেষে এবং $date2-এর দশকের শুরুতে&#039;,&lt;br /&gt;
		cs=function(date1, date2, state)&lt;br /&gt;
			local decade1  = math.floor((date1 % 100) / 10)&lt;br /&gt;
			local decade2  = math.floor((date2 % 100) / 10)&lt;br /&gt;
			local century1 = math.floor( date1 / 100) + 1&lt;br /&gt;
			local century2 = math.floor( date2 / 100) + 1&lt;br /&gt;
			if decade1 == 0 and date1 &amp;lt; date2 then&lt;br /&gt;
				return &amp;quot;přelom 1. a 2. dekády &amp;quot; .. century1 .. &amp;quot;. století&amp;quot;&lt;br /&gt;
			elseif decade2 == 0 and date2 &amp;lt; date1 then&lt;br /&gt;
				return &amp;quot;přelom 9. a 10. dekády &amp;quot; .. century1 .. &amp;quot;. století&amp;quot;&lt;br /&gt;
			elseif (decade1 == 9 and date1 &amp;lt; date2) or (decade2 == 9 and date2 &amp;lt; date1) then&lt;br /&gt;
				return &amp;quot;přelom &amp;quot; .. century1 .. &amp;quot;. a &amp;quot; .. century2 .. &amp;quot;. století&amp;quot;&lt;br /&gt;
			else&lt;br /&gt;
				return &amp;quot;přelom &amp;quot; .. decade1 .. &amp;quot;0. a &amp;quot; .. decade2 .. &amp;quot;0. let &amp;quot; .. century1 .. &amp;quot;. století&amp;quot;&lt;br /&gt;
			end&lt;br /&gt;
		end,&lt;br /&gt;
		de=&#039;späte $date1er und frühe $date2er&#039;,&lt;br /&gt;
		en=&#039;late $date1s and early $date2s&#039;,&lt;br /&gt;
		[&#039;en-gb&#039;]=&#039;late $date1s and early $date2s&#039;,&lt;br /&gt;
		[&#039;en-ca&#039;]=&#039;late $date1s and early $date2s&#039;,&lt;br /&gt;
		eo=&#039;ŝanĝo de la $date1-a al la $date2-a jardekoj&#039;,&lt;br /&gt;
		es=&#039;finales de los años $date1 y principios de los años $date2&#039;,&lt;br /&gt;
		fa=&#039;اواخر دههٔ $date1 و اوایل دههٔ $date2&#039;,&lt;br /&gt;
		fi=&#039;$date1-luvun loppu ja $date2-luvun alku&#039;,&lt;br /&gt;
		fr=&#039;fin des années $date1 / début des années $date2&#039;,&lt;br /&gt;
		hr=&#039;kraj $date1-ih i početak $date2-ih&#039;,&lt;br /&gt;
		hsb=&#039;pózdnje $date1te a zažne $date2te lěta&#039;,&lt;br /&gt;
		it=&#039;fine degli anni $date1 / inizio degli anni $date2&#039;,&lt;br /&gt;
		ja=&#039;$date1年代末から$date2年代初頭&#039;,&lt;br /&gt;
		nb = &#039;sent på $date1-tallet og tidlig på $date2-tallet&#039;,&lt;br /&gt;
		nl = &#039;eind $date1e/begin $date2e decennium&#039;,&lt;br /&gt;
		nn = &#039;seint på $date1-talet og tidleg på $date2-talet&#039;,&lt;br /&gt;
		pl=function(date1, date2, state)&lt;br /&gt;
			local decade1  = math.floor(date1 % 100)&lt;br /&gt;
			local decade2  = math.floor(date2 % 100)&lt;br /&gt;
			local century1 = Roman(math.floor( date1 / 100) + 1)&lt;br /&gt;
			local century2 = Roman(math.floor( date2 / 100) + 1)&lt;br /&gt;
			if decade1 == 0 and date1 &amp;lt; date2  then&lt;br /&gt;
				return &amp;quot;przełom pierwszej i drugiej dekady &amp;quot; .. century1 .. &amp;quot; wieku&amp;quot;&lt;br /&gt;
			elseif decade1 == 10 and date1 &amp;lt; date2  then&lt;br /&gt;
				return &amp;quot;przełom drugiej dekady i lat 20. &amp;quot; .. century1 .. &amp;quot; wieku&amp;quot;&lt;br /&gt;
			elseif decade1 == 90 and decade2 == 0 then&lt;br /&gt;
				return &amp;quot;przełom ostatniej dekady &amp;quot; .. century1 .. &amp;quot; i pierwszej dekady &amp;quot; .. century2 .. &amp;quot; wieku&amp;quot;&lt;br /&gt;
			else&lt;br /&gt;
				return &amp;quot;przełom lat &amp;quot; .. decade1 .. &amp;quot;. i &amp;quot; .. decade2 .. &amp;quot;. &amp;quot; .. century1 .. &amp;quot; wieku&amp;quot;&lt;br /&gt;
			end&lt;br /&gt;
		end,&lt;br /&gt;
		qu=&#039;qhipaq $date1 watakuna ñawpaq $date2 watakunapas&#039;,&lt;br /&gt;
		ru=&#039;конец $date1-х — начало $date2-х гг.&#039;,&lt;br /&gt;
		sv=&#039;sena $date1-talet och tidiga $date2-talet&#039;,&lt;br /&gt;
		sk=function(date1, date2, state)&lt;br /&gt;
			local decade1  = math.floor((date1 % 100) / 10)&lt;br /&gt;
			local decade2  = math.floor((date2 % 100) / 10)&lt;br /&gt;
			local century1 = math.floor( date1 / 100) + 1&lt;br /&gt;
			local century2 = math.floor( date2 / 100) + 1&lt;br /&gt;
			if decade1 == 0 and date1 &amp;lt; date2 then&lt;br /&gt;
				return &amp;quot;prelom 1. a 2. desaťročia &amp;quot; .. century1 .. &amp;quot;. storočia&amp;quot;&lt;br /&gt;
			elseif decade2 == 0 and date2 &amp;lt; date1 then&lt;br /&gt;
				return &amp;quot;prelom 9. a 10. desaťročia &amp;quot; .. century1 .. &amp;quot;. storočia&amp;quot;&lt;br /&gt;
			elseif (decade1 == 9 and date1 &amp;lt; date2) or (decade2 == 9 and date2 &amp;lt; date1) then&lt;br /&gt;
				return &amp;quot;prelom &amp;quot; .. century1 .. &amp;quot;. a &amp;quot; .. century2 .. &amp;quot;. storočia&amp;quot;&lt;br /&gt;
			else&lt;br /&gt;
				return &amp;quot;prelom &amp;quot; .. decade1 .. &amp;quot;0. a &amp;quot; .. decade2 .. &amp;quot;0. rokov &amp;quot; .. century1 .. &amp;quot;. storočia&amp;quot;&lt;br /&gt;
			end&lt;br /&gt;
		end,&lt;br /&gt;
		sl=&#039;pozna $date1-ta in zgodnja $date2-ta leta&#039;,&lt;br /&gt;
		uk=&#039;кінець $date1-х — початок $date2-х рр.&#039;,&lt;br /&gt;
		ur=&#039;اخیر دہائی $date1 و ابتدا دہائی $date2&#039;,&lt;br /&gt;
		vi=&#039;bước sang thập niên $date2&#039;,&lt;br /&gt;
		[&#039;zh-hans&#039;]=&#039;$date1年代末$date2年代初&#039;,&lt;br /&gt;
		[&#039;zh-hant&#039;]=&#039;$date1年代末$date2年代初&#039;,&lt;br /&gt;
		default=function(date1, date2, state) return {conj=&#039;and&#039;, adj1 = &#039;late&#039;, unit1=&#039;decade&#039;, era1=state.era1, adj2 = &#039;early&#039;,  unit2=&#039;decade&#039;, era2=state.era2} end,&lt;br /&gt;
	},&lt;br /&gt;
&lt;br /&gt;
	-- $date1 - original date - 1&lt;br /&gt;
	-- $date2 - original date&lt;br /&gt;
	-- if era is BC than $date1 and $date2 are swapped&lt;br /&gt;
	[&#039;turn of the year&#039;]={&lt;br /&gt;
		nDates = 2,&lt;br /&gt;
		[&#039;be-tarask&#039;]=&#039;канец $date1 — пачатак $date2 г.&#039;,&lt;br /&gt;
		bn=&#039;$date1-এর শেষে এবং $date2-এর শুরুতে&#039;,&lt;br /&gt;
		cs=&#039;přelom roku $date1/$date2&#039;,&lt;br /&gt;
		de=&#039;Jahreswechsel $date1/$date2&#039;,&lt;br /&gt;
		en=&#039;late $date1 and early $date2&#039;,&lt;br /&gt;
		[&#039;en-gb&#039;]=&#039;late $date1 and early $date2&#039;,&lt;br /&gt;
		[&#039;en-ca&#039;]=&#039;late $date1 and early $date2&#039;,&lt;br /&gt;
		eo=&#039;jarŝanĝo $date1 / $date2&#039;,&lt;br /&gt;
		es=&#039;finales de $date1 y principios de $date2&#039;,&lt;br /&gt;
		fa=&#039;اواخر $date1 و اوایل $date2&#039;,&lt;br /&gt;
		fi=&#039;vuoden $date1 loppu ja vuoden $date2 alku&#039;,&lt;br /&gt;
		fr=&#039;fin $date1 / début $date2&#039;,&lt;br /&gt;
		hsb=&#039;kónc $date1/spočatk $date2&#039;,&lt;br /&gt;
		ja=&#039;$date1年末から$date2年初め&#039;,&lt;br /&gt;
		nb=&#039;årsskiftet $date1/$date2&#039;,&lt;br /&gt;
		nl=&#039;eind $date1 en begin $date2&#039;,&lt;br /&gt;
		nn=&#039;årsskiftet $date1/$date2&#039;,&lt;br /&gt;
		pl=&#039;koniec $date1 i początek $date2 roku&#039;,&lt;br /&gt;
		qu=&amp;quot;$date1 qhipaq p&#039;unchawkuna $date2 ñawpaq p&#039;unchawkunapas&amp;quot;,&lt;br /&gt;
		ru=&#039;конец $date1 — начало $date2 г.&#039;,&lt;br /&gt;
		sk=&#039;prelom rokov $date1/$date2&#039;,&lt;br /&gt;
		sl=&#039;konec leta $date1 in začetek $date2&#039;,&lt;br /&gt;
		sv=&#039;sena $date1 och tidiga $date2&#039;,&lt;br /&gt;
		uk=&#039;кінець $date1 — початок $date2 р.&#039;,&lt;br /&gt;
		ur=&#039;اخیر $date1 و ابتدا $date2&#039;,&lt;br /&gt;
		vi=&#039;bước sang năm $date2&#039;,&lt;br /&gt;
		[&#039;zh-hans&#039;]=&#039;$date1年末$date2年初&#039;,&lt;br /&gt;
		[&#039;zh-hant&#039;]=&#039;$date1年末$date2年初&#039;,&lt;br /&gt;
		default=function(date1, date2, state) return {conj=&#039;and&#039;, adj1 = &#039;late&#039;, unit1=&#039;year&#039;, era1=state.era1, adj2 = &#039;early&#039;,  unit2=&#039;year&#039;, era2=state.era2} end,&lt;br /&gt;
	},&lt;br /&gt;
&lt;br /&gt;
	[&#039;circa2&#039;] = {&lt;br /&gt;
		nDates = 2,&lt;br /&gt;
		ar=&#039;حوالي $date1 – $date2&#039;,&lt;br /&gt;
		[&#039;be-tarask&#039;]={&#039;прыкладна з $date1 да прыкладна $date2&#039;, case={&#039;gen&#039;,&#039;gen&#039;}},&lt;br /&gt;
		bn=&#039;প্রায় $date1 এবং প্রায় $date2-এর মাঝামাঝি&#039;,&lt;br /&gt;
		ca=&#039;cap a $date1 o $date2&#039;,&lt;br /&gt;
		cs=&#039;cca $date1 až $date2&#039;,&lt;br /&gt;
		da=&#039;ca. mellem $date1 og $date2&#039;,&lt;br /&gt;
		de=&#039;etwa $date1 bis $date2&#039;,&lt;br /&gt;
		el=&#039;περίπου μεταξύ $date1 και $date2&#039;,&lt;br /&gt;
		en=&#039;between circa $date1 and circa $date2&#039;,&lt;br /&gt;
		[&#039;en-gb&#039;]=&#039;between circa $date1 and circa $date2&#039;,&lt;br /&gt;
		[&#039;en-ca&#039;]=&#039;between circa $date1 and circa $date2&#039;,&lt;br /&gt;
		eo=&#039;proksimume de $date1 ĝis $date2&#039;,&lt;br /&gt;
		es=&#039;hacia $date1 o $date2&#039;,&lt;br /&gt;
		et=&#039;ca. $date1 ja $date2 vahel&#039;,&lt;br /&gt;
		fa=&#039;حدوداً بین $date1 و $date2&#039;, &lt;br /&gt;
		fi={function(date1, date2, state) return &#039;suunnilleen &#039; .. decYear(state,&#039;fi&#039;,&#039;xxx&#039;) .. &#039;$date1 ja $date2 välisenä aikana&#039; end, case={&#039;gen&#039;,&#039;gen&#039;}},&lt;br /&gt;
		fr=&#039;vers $date1-$date2&#039;,&lt;br /&gt;
		gl=&#039;entre $date1 e $date2&#039;,&lt;br /&gt;
		he=&#039;בסביבות ה- $date1 עד $date2&#039;,&lt;br /&gt;
		hr=&#039;oko između $date1 i $date2&#039;,&lt;br /&gt;
		hsb={&#039;wot něhdźe $date1 do něhdźe $date2&#039;, case={&#039;gen&#039;,&#039;gen&#039;}},&lt;br /&gt;
		hu=&#039;$date1 és $date2 között&#039;,&lt;br /&gt;
		it=&#039;tra il $date1 e il $date2 circa&#039;,&lt;br /&gt;
		ja=&#039;$date1頃と$date2頃の間&#039;,&lt;br /&gt;
		mk=&#039;~ помеѓу $date1 и $date2&#039;,&lt;br /&gt;
		nb=&#039;ca. mellom $date1 og $date2&#039;,&lt;br /&gt;
		nn=&#039;ca. mellom $date1 og $date2&#039;,&lt;br /&gt;
		nds=&#039;üm un bi $date1 bet $date2&#039;,&lt;br /&gt;
		nl=&#039;ca. $date1 tot $date2&#039;,&lt;br /&gt;
		no=&#039;ca. mellom $date1 og $date2&#039;,&lt;br /&gt;
		pl={&#039;od około $date1 do około $date2&#039;, case={&#039;gen&#039;,&#039;gen&#039;}},&lt;br /&gt;
		pt=&#039;cerca de $date1 a $date2&#039;,&lt;br /&gt;
		qu=&amp;quot;$date1 p&#039;unchawmantachá $date2 p&#039;unchawkamachá&amp;quot;,&lt;br /&gt;
		ro=&#039;circa $date1 – $date2&#039;,&lt;br /&gt;
		ru={&#039;с около $date1 до, примерно, $date2&#039;, case={&#039;gen&#039;,&#039;gen&#039;}},&lt;br /&gt;
		sk=&#039;cca $date1 až $date2&#039;,&lt;br /&gt;
		sl={function(date1, date2, state) return &#039;ok. &#039; .. decYear(state,&#039;sl&#039;,&#039;gen&#039;) .. &#039; $date1 do $date2&#039; end, case={&#039;gen&#039;,&#039;gen&#039;}},&lt;br /&gt;
		sv=&#039;c:a $date1 till $date2&#039;,&lt;br /&gt;
		uk={&#039;з близько $date1 до, приблизно, $date2&#039;, case={&#039;gen&#039;,&#039;gen&#039;}},&lt;br /&gt;
		ur=&#039;قریباً بین $date1 و $date2&#039;, &lt;br /&gt;
		vi=&#039;giữa vào khoảng $date1 và vào khoảng $date2&#039;,&lt;br /&gt;
		[&#039;zh-hans&#039;]=&#039;约$date1~$date2间&#039;,&lt;br /&gt;
		[&#039;zh-hant&#039;]=&#039;約$date1~$date2間&#039;,&lt;br /&gt;
		default=function(date1, date2, state) return {conj=&#039;between&#039;, adj1 = &#039;circa&#039;, unit1=state.unit1, era1=state.era1, adj2 = &#039;circa&#039;,  unit2=state.unit2, era2=state.era2} end,&lt;br /&gt;
	},&lt;br /&gt;
&lt;br /&gt;
	-- ==========================================&lt;br /&gt;
	-- === Eras and calendars ===================&lt;br /&gt;
	-- ==========================================&lt;br /&gt;
	[&#039;julian&#039;] = {&lt;br /&gt;
		nDates = 2,&lt;br /&gt;
		ar=&#039;$date1 ($date2 حسب [[w:ar:التقويم اليولياني|تقويم يولياني]])&#039;,&lt;br /&gt;
		[&#039;be-tarask&#039;]=&#039;$date1 ($date2 паводле [[w:be-tarask:Юліянскі каляндар|ст. ст.]]&#039;,&lt;br /&gt;
		bn=&#039;$date1 (জুলিয়ান ক্যালেন্ডারে $date2)&#039;,&lt;br /&gt;
		ca=&#039;$date1 ($date2 segons el [[w:ca:Calendari julià|calendari julià]])&#039;,&lt;br /&gt;
		cs=&#039;$date1 ($date2 podle [[w:cs:Juliánský kalendář|juliánského kalendáře]])&#039;,&lt;br /&gt;
		da=&#039;$date1 ($date2 [[w:da:Julianske kalender|Julianske kalender]])&#039;,&lt;br /&gt;
		de=&#039;$date1 ($date2 [[w:de:Julianischer Kalender|Julianischer Kalender]])&#039;,&lt;br /&gt;
		el=&#039;$date1 ($date2 με το [[w:el:Ιουλιανό ημερολόγιο|Ιουλιανό ημερολόγιο]])&#039;,&lt;br /&gt;
		en=&#039;$date1 ($date2 in [[w:Old Style and New Style dates|Julian calendar]])&#039;,&lt;br /&gt;
		[&#039;en-gb&#039;]=&#039;$date1 ($date2 in [[w:Old Style and New Style dates|Julian calendar]])&#039;,&lt;br /&gt;
		[&#039;en-ca&#039;]=&#039;$date1 ($date2 in [[w:Old Style and New Style dates|Julian calendar]])&#039;,&lt;br /&gt;
		fa=&#039;$date1 ($date2 در [[w:fa:Old Style and New Style dates|تقویم جولیان]])&#039;,&lt;br /&gt;
		eo=&#039;$date1 ($date2 laŭ la [[w:eo:Julia kalendaro|Julia Kalendaro]])&#039;,&lt;br /&gt;
		es=&#039;$date1 ($date2 según el [[w:es:Calendario juliano|calendario juliano]])&#039;,&lt;br /&gt;
		et=&#039;$date1 ($date2 [[w:et:Juliuse kalender|Juliuse kalendris]])&#039;,&lt;br /&gt;
		fi=&#039;$date1 ($date2 [[w:fi:juliaaninen kalenteri|juliaanisen kalenterin]] mukaan)&#039;,&lt;br /&gt;
		fr=&#039;$date1 ($date2 dans le [[w:fr:calendrier julien|calendrier julien]])&#039;,&lt;br /&gt;
		gl=&#039;$date1 ($date2 segundo o [[w:gl:Calendario xuliano|calendario xuliano]])&#039;,&lt;br /&gt;
		hu=&#039;$date1 ($date2 a [[w:hu:Julianus-naptár|Julián naptárban]])&#039;,&lt;br /&gt;
		hr=&#039;$date1 ($date2 prema [[w:hr:Julijanski kalendar|julijanskom kalendaru]])&#039;,&lt;br /&gt;
		he=&#039;$date1 ($date2 ב[[w:he:לוח היוליאני|הלוח היוליאני]])&#039;,&lt;br /&gt;
		hsb=&#039;$date1 ($date2 po julianiskej protyce)&#039;,&lt;br /&gt;
		it=&#039;$date1 ($date2 secondo il [[w:it:Calendario giuliano|calendario giuliano]])&#039;,&lt;br /&gt;
		ja=&#039;$date1（[[w:ja:ユリウス暦|ユリウス暦]] $date2）&#039;,&lt;br /&gt;
		mk=&#039;$date1 ($date2 по [[w:mk:Јулијански календар|Јулијанскиот календар]])&#039;,&lt;br /&gt;
		ml=&#039;$date1 ([[w:Old Style and New Style dates|ജൂലിയൻ കാലഗണനാരീതിയിൽ]] $date2)&#039;,&lt;br /&gt;
		nds=&#039;$date1 ($date2 na’n [[w:nds:Juliaansch Klenner|Juliaanschen Klenner]])&#039;,&lt;br /&gt;
		nb=&#039;$date1 ($date2 etter [[w:no:Juliansk kalender|den julianske kalenderen]])&#039;,&lt;br /&gt;
		nn=&#039;$date1 ($date2 etter [[w:no:Juliansk kalender|den julianske kalenderen]])&#039;,&lt;br /&gt;
		nl=&#039;$date1 ($date2 volgens de [[w:nl:Juliaanse kalender|Juliaanse kalender]])&#039;,&lt;br /&gt;
		no=&#039;$date1 ($date2 etter [[w:no:Juliansk kalender|den julianske kalender]])&#039;,&lt;br /&gt;
		pl=&#039;$date1 ($date2 wedle [[w:pl:Daty nowego i starego porządku|kalendarza juliańskiego]])&#039;,&lt;br /&gt;
		pt=&#039;$date1 ($date2 no [[w:pt:Mudança para o calendário gregoriano|calendário juliano]])&#039;,&lt;br /&gt;
		qu=&#039;$date1 ($date2 [[w:qu:Hulyanu kalindaryu|Hulyanu kalindaryupi]])&#039;,&lt;br /&gt;
		ro=&#039;$date1 ($date2 în [[w:ro:calendarul iulian|calendarul iulian]])&#039;,&lt;br /&gt;
		ru=&#039;$date1 ($date2 [[w:ru:Юлианский календарь|по ст. ст.]])&#039;,&lt;br /&gt;
		sk=&#039;$date1 ($date2 podľa [[w:sk:Juliánsky kalendár|juliánskeho kalendára]])&#039;,&lt;br /&gt;
		sl=&#039;$date1 ($date2 po [[w:sl:Julijanski koledar|julijanskem koledarju]])&#039;,&lt;br /&gt;
		sv=&#039;$date1 ($date2 [[w:sv:Gamla stilen|gamla stilen]])&#039;,&lt;br /&gt;
		uk=&#039;$date1 ($date2 [[w:uk:Юліанський календар|Юліанський календар]])&#039;,&lt;br /&gt;
		ur=&#039;$date1 ($date2 حسب [[w:ur:نئے اور پانے انداز کی تاریخ|جولین تقویم]])&#039;,&lt;br /&gt;
		vi=&#039;$date1 ($date2 trong [[w:vi:Lịch Julius|lịch Juliêng]])&#039;,&lt;br /&gt;
		[&#039;zh-hans&#039;]=&#039;$date1（[[w:Old Style and New Style dates|格里历]]$date2）&#039;,&lt;br /&gt;
		[&#039;zh-hant&#039;]=&#039;$date1（[[w:Old Style and New Style dates|格里曆]]$date2）&#039;,&lt;br /&gt;
		--default=&#039;{{Please translate|$date1 ($date2 in [[w:Old Style and New Style dates|Julian calendar]])|Module:I18n/complex date}}&#039;,&lt;br /&gt;
		default=&#039;&amp;lt;span style=&amp;quot;color:red&amp;quot;&amp;gt;$date1 ($date2 in [[w:Old Style and New Style dates|Julian calendar]])&amp;lt;/span&amp;gt;&#039;,&lt;br /&gt;
	},&lt;br /&gt;
	&lt;br /&gt;
	[&#039;ad&#039;] = {&lt;br /&gt;
		nDates = 1,&lt;br /&gt;
		[&#039;be-tarask&#039;]=&#039;$date1 [[w:be-tarask:ад Нараджэньня Хрыста|пасьля Н. Х.]]&#039;,&lt;br /&gt;
		bn =&#039;$date1 খ্রিস্টাব্দ&#039;,&lt;br /&gt;
		ca =&#039;$date1 dC&#039;,&lt;br /&gt;
		cs =&#039;$date1 n. l.&#039;,&lt;br /&gt;
		de =&#039;$date1 n. Chr.&#039;,&lt;br /&gt;
		el =&#039;$date1 μ.Χ.&#039;,&lt;br /&gt;
		en =&#039;$date1 [[w:en:Anno Domini|AD]]&#039;,&lt;br /&gt;
		[&#039;en-gb&#039;] =&#039;$date1 [[w:en:Anno Domini|AD]]&#039;,&lt;br /&gt;
		[&#039;en-ca&#039;] =&#039;$date1 [[w:en:Anno Domini|AD]]&#039;,&lt;br /&gt;
		eo =&#039;$date1 pK&#039;,&lt;br /&gt;
		es =&#039;$date1 [[w:es:Anno Dómini|d. C.]]&#039;,&lt;br /&gt;
		fa =&#039;$date1 م.&#039;,&lt;br /&gt;
		fi =&#039;$date1 jaa.&#039;,&lt;br /&gt;
		fr =&#039;$date1 ap. J.-C.&#039;,&lt;br /&gt;
		gl =&#039;$date1 d.C.&#039;,&lt;br /&gt;
		he =&#039;$date1 לספירה&#039;,&lt;br /&gt;
		hu =&#039;i. sz. $date1&#039;,&lt;br /&gt;
		hr =&#039;$date1 p. Kr.&#039;,&lt;br /&gt;
		hsb=&#039;$date1 po Chr.&#039;,&lt;br /&gt;
		it =&#039;$date1 d.C.&#039;,&lt;br /&gt;
		ja =&#039;西暦$date1&#039;,&lt;br /&gt;
		mk =&#039;$date1 н.е.&#039;,&lt;br /&gt;
		ml =&#039;ക്രി.വ. $date1&#039;,&lt;br /&gt;
		nb =&#039;$date1 e.Kr.&#039;,&lt;br /&gt;
		nl =&#039;$date1 n.Chr.&#039;,&lt;br /&gt;
		nn =&#039;$date1 e.Kr.&#039;,&lt;br /&gt;
		no =&#039;$date1 e.Kr.&#039;,&lt;br /&gt;
		pl =&#039;$date1 [[w:pl:naszej ery|n.e.]]&#039;,&lt;br /&gt;
		ro =&#039;$date1 d.Hr.&#039;,&lt;br /&gt;
		ru =&#039;$date1 н. э.&#039;,&lt;br /&gt;
		sk =&#039;$date1 po Kr.&#039;,&lt;br /&gt;
		sl =&#039;$date1 n. št.&#039;,&lt;br /&gt;
		sv =&#039;$date1 [[w:sv:Efter Kristus|e.Kr.]]&#039;,&lt;br /&gt;
		uk =&#039;$date1 н. е.&#039;,&lt;br /&gt;
		ur =&#039;$date1 ء&#039;,&lt;br /&gt;
		vi =&#039;$date1 [[w:vi:Công Nguyên|CN]]&#039;,&lt;br /&gt;
		[&#039;zh-hans&#039;] =&#039;[[w:zh:基督纪年|公元]]$date1&#039;,&lt;br /&gt;
		[&#039;zh-hant&#039;] =&#039;[[w:zh:基督纪年|公元]]$date1&#039;,&lt;br /&gt;
		default=&#039;&amp;lt;span style=&amp;quot;color:red&amp;quot;&amp;gt;$date1 [[w:en:Anno Domini|AD]]&amp;lt;/span&amp;gt;&#039;,&lt;br /&gt;
	}, &lt;br /&gt;
	&lt;br /&gt;
	[&#039;ah&#039;] = {&lt;br /&gt;
		nDates = 1,&lt;br /&gt;
		[&#039;be-tarask&#039;]=&#039;$date1 [[w:be-tarask:Ісламскі каляндар|хіджры]]&#039;,&lt;br /&gt;
		bn =&#039;$date1 [[w:bn:ইসলামি বর্ষপঞ্জি|হিজরী]]&#039;,&lt;br /&gt;
		cs =&#039;$date1 [[w:cs:Anno Hegirae|AH]]&#039;,&lt;br /&gt;
		en =&#039;$date1 [[w:en:Hijri year|AH]]&#039;,&lt;br /&gt;
		[&#039;en-gb&#039;] =&#039;$date1 [[w:en:Hijri year|AH]]&#039;,&lt;br /&gt;
		[&#039;en-ca&#039;] =&#039;$date1 [[w:en:Hijri year|AH]]&#039;,&lt;br /&gt;
		eo =&#039;$date1 post la [[w:eo:Heĝiro|Heĝiro]]&#039;,&lt;br /&gt;
		fa =&#039;$date1 ه.ق.&#039;,&lt;br /&gt;
		fr =&#039;$date1 [[w:fr:Calendrier musulman|A.H.]]&#039;,&lt;br /&gt;
		he =&amp;quot;$date1 [[w:he:הלוח המוסלמי|להג&#039;רה]]&amp;quot;,&lt;br /&gt;
		hr =&#039;$date1 god. hidžre&#039;,&lt;br /&gt;
		ja =&#039;[[w:ja:ヒジュラ暦|ヒジュラ暦]]$date1&#039;,&lt;br /&gt;
		nb =&#039;$date1 [[w:no:Den muslimske kalenderen|A.H.]]&#039;,&lt;br /&gt;
		nn =&#039;$date1 [[w:nn:Den muslimske kalenderen|A.H.]]&#039;,&lt;br /&gt;
		pl =&#039;$date1 [[w:pl:Kalendarz muzułmański|A.H.]]&#039;,&lt;br /&gt;
		ru =&#039;$date1 [[w:ru:Исламский календарь|хиджры]]&#039;,&lt;br /&gt;
		sk =&#039;$date1 [[w:sk:A. H.|A. H.]]&#039;,&lt;br /&gt;
		sv =&#039;$date1 [[w:sv:Muslimska kalendern|A.H.]]&#039;,&lt;br /&gt;
		uk =&#039;$date1 [[w:uk:Мусульманський календар|хіджри]]&#039;,&lt;br /&gt;
		ur =&#039;$date1 ھ&#039;,&lt;br /&gt;
		vi =&#039;$date1 [[w:vi:Lịch Hồi giáo|AH]]&#039;,&lt;br /&gt;
		[&#039;zh-hans&#039;] =&#039;[[w:en:Hijri year|Hijri历]]$date1&#039;,&lt;br /&gt;
		[&#039;zh-hant&#039;] =&#039;[[w:en:Hijri year|Hijri曆]]$date1&#039;,&lt;br /&gt;
		default=&#039;&amp;lt;span style=&amp;quot;color:red&amp;quot;&amp;gt;$date1 [[w:en:Hijri year|AH]]&amp;lt;/span&amp;gt;&#039;,&lt;br /&gt;
	},&lt;br /&gt;
	&lt;br /&gt;
 	[&#039;bc&#039;] = {&lt;br /&gt;
		nDates = 1,&lt;br /&gt;
		ar =&#039;$date1 ق.م.&#039;,&lt;br /&gt;
		[&#039;be-tarask&#039;]=&#039;$date1 [[w:be-tarask:да Нараджэньня Хрыста|да Н. Х.]]&#039;,&lt;br /&gt;
		bn =&#039;খ্রিস্টপূর্ব $date1&#039;,&lt;br /&gt;
		ca =&#039;$date1 [[w:ca:Abans de Crist|aC]]&#039;,&lt;br /&gt;
		cs =&#039;$date1 [[w:cs:Př. n. l.|př. n. l.]]&#039;,&lt;br /&gt;
		de =&#039;$date1 [[w:de:v. Chr.|v. Chr.]]&#039;,&lt;br /&gt;
		el =&#039;$date1 π.Χ.&#039;,&lt;br /&gt;
		en =&#039;$date1 [[w:en:Ante Christum Natum|BC]]&#039;,&lt;br /&gt;
		[&#039;en-gb&#039;] =&#039;$date1 [[w:en:Ante Christum Natum|BC]]&#039;,&lt;br /&gt;
		[&#039;en-ca&#039;] =&#039;$date1 [[w:en:Ante Christum Natum|BC]]&#039;,&lt;br /&gt;
		eo =&#039;$date1 aK&#039;,&lt;br /&gt;
		es =&#039;$date1 [[w:es:Antes de Cristo|a. C.]]&#039;,&lt;br /&gt;
		fa =&#039;$date1 پ.م.&#039;,&lt;br /&gt;
		fi =&#039;$date1 eaa.&#039;,&lt;br /&gt;
		fr =&#039;$date1 av. J.-C.&#039;,&lt;br /&gt;
		gl =&#039;$date1 [[w:gl:Antes de Cristo|a.C.]]&#039;,&lt;br /&gt;
		he =&#039;$date1 לפני הספירה&#039;,&lt;br /&gt;
		hr =&#039;$date1 [[w:hr:Pr. Kr.|pr. Kr.]]&#039;,&lt;br /&gt;
		hsb=&#039;$date1 do Chr.&#039;,&lt;br /&gt;
		hu =&#039;i. e. $date1&#039;,&lt;br /&gt;
		it =&#039;$date1 [[w:it:Avanti Cristo|a.C.]]&#039;,&lt;br /&gt;
		ja =&#039;[[w:ja:紀元前|紀元前]]$date1&#039;,&lt;br /&gt;
		mk =&#039;$date1 п.н.е.&#039;,&lt;br /&gt;
		ml =&#039;ക്രി.മു. $date1&#039;,&lt;br /&gt;
		nds=&#039;$date1 vör uns Tied&#039;,&lt;br /&gt;
		nb =&#039;$date1 f.Kr.&#039;,&lt;br /&gt;
		nl =&#039;$date1 v.Chr.&#039;,&lt;br /&gt;
		nn =&#039;$date1 f.Kr.&#039;,&lt;br /&gt;
		no =&#039;$date1 f.Kr.&#039;,&lt;br /&gt;
		pl =&#039;$date1 [[w:pl:przed naszą erą|p.n.e.]]&#039;,&lt;br /&gt;
		ro =&#039;$date1 î.Hr.&#039;,&lt;br /&gt;
		ru =&#039;$date1 до н. э.&#039;,&lt;br /&gt;
		sk =&#039;$date1 [[w:sk:Pred Kristom|pred Kr.]]&#039;,&lt;br /&gt;
		sl =&#039;$date1 pr. n. št.&#039;,&lt;br /&gt;
		sv =&#039;$date1 [[w:sv:Före Kristus|f.Kr.]]&#039;,&lt;br /&gt;
		uk =&#039;$date1 до н. е.&#039;,&lt;br /&gt;
		ur =&#039;$date1 ق م&#039;,&lt;br /&gt;
		vi =&#039;$date1 [[w:vi:Trước Công Nguyên|TCN]]&#039;,&lt;br /&gt;
		[&#039;zh-hans&#039;] =&#039;[[w:zh:基督纪年|公元前]]$date1&#039;,&lt;br /&gt;
		[&#039;zh-hant&#039;] =&#039;[[w:zh:基督纪年|公元前]]$date1&#039;,&lt;br /&gt;
		default=&#039;&amp;lt;span style=&amp;quot;color:red&amp;quot;&amp;gt;$date1 [[w:en:Ante Christum Natum|BC]]&amp;lt;/span&amp;gt;&#039;,&lt;br /&gt;
	}, &lt;br /&gt;
	&lt;br /&gt;
	[&#039;bp&#039;] = {&lt;br /&gt;
		nDates = 1,&lt;br /&gt;
		ar =&#039;$date1 [[w:ar:قبل الحاضر|قبل الحاضر]]&#039;,&lt;br /&gt;
		be =&#039;$date1 [[w:be-tarask:Да нашых дзён|Да нашых дзён]]&#039;,&lt;br /&gt;
		[&#039;be-tarask&#039;]=&#039;$date1 [[w:be-tarask:Да нашых дзён|Да нашых дзён]]&#039;,&lt;br /&gt;
		bn =&#039;বর্তমানের আগে $date1&#039;,&lt;br /&gt;
		ca =&#039;$date1 [[w:ca:BP (unitat de temps)|BP]]&#039;,&lt;br /&gt;
		cs =&#039;$date1 [[w:cs:B. P.|B. P.]]&#039;,&lt;br /&gt;
		de =&#039;$date1 [[w:de:Before Present|BP]]&#039;,&lt;br /&gt;
		el =&#039;$date1 [[w:en:Before Present|BP]]&#039;,&lt;br /&gt;
		en =&#039;$date1 [[w:en:Before Present|BP]]&#039;,&lt;br /&gt;
		[&#039;en-gb&#039;] =&#039;$date1 [[w:en:Before Present|BP]]&#039;,&lt;br /&gt;
		[&#039;en-ca&#039;] =&#039;$date1 [[w:en:Before Present|BP]]&#039;,&lt;br /&gt;
		eo=&#039;$date1 [[w:eo:Before Present|BP]]&#039;,&lt;br /&gt;
		es =&#039;$date1 [[w:es:Before Present|BP]]&#039;,&lt;br /&gt;
		et =&#039;$date1 [[w:et:Before Present|BP]]&#039;,&lt;br /&gt;
		fa =&#039;$date1 پیش از اکنون&#039;,&lt;br /&gt;
		fi =&#039;$date1 [[w:fi:BP (ajanlasku)|BP]]&#039;,&lt;br /&gt;
		fr =&#039;$date1 [[w:fr:Avant le présent|avant le présent]]&#039;,&lt;br /&gt;
		hr =&#039;$date1 [[w:hr:BP|prije današnjice]]&#039;,&lt;br /&gt;
		it =&#039;$date1 [[w:it:Before Present|BP]]&#039;,&lt;br /&gt;
		ja =&#039;$date1 [[w:ja:BP (年代測定)|BP]]&#039;,&lt;br /&gt;
		lv =&#039;$date1 [[w:lv:Pirms mūsdienām|Pirms mūsdienām]]&#039;,&lt;br /&gt;
		mk =&#039;$date1 [[w:mk:Пред сегашноста|п.с.]]&#039;,&lt;br /&gt;
		ml =&#039;[[w:en:Before Present|ഇന്നത്തെ കാലത്തിനു മുമ്പ്]] $date1&#039;,&lt;br /&gt;
		nb =&#039;$date1 [[w:no:Before Present|BP]]&#039;,&lt;br /&gt;
		nn =&#039;$date1 [[w:nn:Before Present|BP]]&#039;,&lt;br /&gt;
		nl =&#039;$date1 [[w:nl:Before Present|BP]]&#039;,&lt;br /&gt;
		no =&#039;$date1 [[w:no:Before Present|BP]]&#039;,&lt;br /&gt;
		pl =&#039;$date1 [[w:pl:Before Present|BP]]&#039;,&lt;br /&gt;
		pt =&#039;$date1 [[w:pt:Antes do Presente|Antes do Presente]]&#039;,&lt;br /&gt;
		ru =&#039;$date1 [[w:ru:До настоящего времени|до н. в.]]&#039;,&lt;br /&gt;
		sk =&#039;$date1 [[w:sk:BP (čas)|BP]]&#039;,&lt;br /&gt;
		sl =&#039;$date1 [[w:sl:pred sedanjostjo|p. s.]]&#039;,&lt;br /&gt;
		sr =&#039;$date1 [[w:sr:Прије садашњости|Прије садашњости]]&#039;,&lt;br /&gt;
		sv =&#039;$date1 [[w:sv:B.P.|B.P.]]&#039;,&lt;br /&gt;
		uk =&#039;$date1 [[w:uk:Років тому|Років тому]]&#039;,&lt;br /&gt;
		ur =&#039;$date1 قبل حاضر&#039;,&lt;br /&gt;
		vi =&#039;$date1 [[w:en:Before Present|trước ngày nay]]&#039;,&lt;br /&gt;
		[&#039;zh-hans&#039;] =&#039;[[w:zh:距今|距今]]$date1&#039;,&lt;br /&gt;
		[&#039;zh-hant&#039;] =&#039;[[w:zh:距今|距今]]$date1&#039;,&lt;br /&gt;
		default=&#039;&amp;lt;span style=&amp;quot;color:red&amp;quot;&amp;gt;$date1 [[w:en:Before Present|BP]]&amp;lt;/span&amp;gt;&#039;,&lt;br /&gt;
	},&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
-- List of possible string inputs to &amp;quot;adj&amp;quot;, &amp;quot;junction&amp;quot;, &amp;quot;era&amp;quot;, and &amp;quot;precision&amp;quot; fields&lt;br /&gt;
-- Each term is matched to its synonym and the role: a - adjective, e - era&lt;br /&gt;
-- p - precision, c - calendar and combos, and j - conjunction&lt;br /&gt;
p.Synonyms = {&lt;br /&gt;
	-- adjectives and prepositions&lt;br /&gt;
	[&#039;quarter1&#039;]={&#039;1quarter&#039;,&#039;a&#039;},&lt;br /&gt;
	[&#039;1stquarter&#039;]={&#039;1quarter&#039;,&#039;a&#039;},&lt;br /&gt;
	[&#039;1st quarter&#039;]={&#039;1quarter&#039;,&#039;a&#039;},&lt;br /&gt;
	[&#039;1quarter&#039;]={&#039;1quarter&#039;,&#039;a&#039;},&lt;br /&gt;
	[&#039;quarter2&#039;]={&#039;2quarter&#039;,&#039;a&#039;},&lt;br /&gt;
	[&#039;2ndquarter&#039;]={&#039;2quarter&#039;,&#039;a&#039;},&lt;br /&gt;
	[&#039;2nd quarter&#039;]={&#039;2quarter&#039;,&#039;a&#039;},&lt;br /&gt;
	[&#039;2quarter&#039;]={&#039;2quarter&#039;,&#039;a&#039;},&lt;br /&gt;
	[&#039;quarter3&#039;]={&#039;3quarter&#039;,&#039;a&#039;},&lt;br /&gt;
	[&#039;3rdquarter&#039;]={&#039;3quarter&#039;,&#039;a&#039;},&lt;br /&gt;
	[&#039;3rd quarter&#039;]={&#039;3quarter&#039;,&#039;a&#039;},&lt;br /&gt;
	[&#039;3quarter&#039;]={&#039;3quarter&#039;,&#039;a&#039;},&lt;br /&gt;
	[&#039;quarter4&#039;]={&#039;4quarter&#039;,&#039;a&#039;},&lt;br /&gt;
	[&#039;4thquarter&#039;]={&#039;4quarter&#039;,&#039;a&#039;},&lt;br /&gt;
	[&#039;4th quarter&#039;]={&#039;4quarter&#039;,&#039;a&#039;},&lt;br /&gt;
	[&#039;4quarter&#039;]={&#039;4quarter&#039;,&#039;a&#039;},&lt;br /&gt;
	[&#039;spring&#039;]={&#039;spring&#039;,&#039;a&#039;},&lt;br /&gt;
	[&#039;summer&#039;]={&#039;summer&#039;,&#039;a&#039;},&lt;br /&gt;
	[&#039;fall&#039;]={&#039;autumn&#039;,&#039;a&#039;},&lt;br /&gt;
	[&#039;autumn&#039;]={&#039;autumn&#039;,&#039;a&#039;},&lt;br /&gt;
	[&#039;winter&#039;]={&#039;winter&#039;,&#039;a&#039;},&lt;br /&gt;
	[&#039;beginning&#039;]={&#039;early&#039;,&#039;a&#039;},&lt;br /&gt;
	[&#039;early&#039;]={&#039;early&#039;,&#039;a&#039;},&lt;br /&gt;
	[&#039;1half&#039;]={&#039;firsthalf&#039;,&#039;a&#039;},&lt;br /&gt;
	[&#039;1sthalf&#039;]={&#039;firsthalf&#039;,&#039;a&#039;},&lt;br /&gt;
	[&#039;1st half&#039;]={&#039;firsthalf&#039;,&#039;a&#039;},&lt;br /&gt;
	[&#039;firsthalf&#039;]={&#039;firsthalf&#039;,&#039;a&#039;},&lt;br /&gt;
	[&#039;first half&#039;]={&#039;firsthalf&#039;,&#039;a&#039;},&lt;br /&gt;
	[&#039;end&#039;]={&#039;late&#039;,&#039;a&#039;},&lt;br /&gt;
	[&#039;late&#039;]={&#039;late&#039;,&#039;a&#039;},&lt;br /&gt;
	[&#039;middle&#039;]={&#039;mid&#039;,&#039;a&#039;},&lt;br /&gt;
	[&#039;mid&#039;]={&#039;mid&#039;,&#039;a&#039;},&lt;br /&gt;
	[&#039;2half&#039;]={&#039;secondhalf&#039;,&#039;a&#039;},&lt;br /&gt;
	[&#039;2ndhalf&#039;]={&#039;secondhalf&#039;,&#039;a&#039;},&lt;br /&gt;
	[&#039;2nd half&#039;]={&#039;secondhalf&#039;,&#039;a&#039;},&lt;br /&gt;
	[&#039;secondhalf&#039;]={&#039;secondhalf&#039;,&#039;a&#039;},&lt;br /&gt;
	[&#039;second half&#039;]={&#039;secondhalf&#039;,&#039;a&#039;},&lt;br /&gt;
	[&#039;&amp;lt;&#039;]={&#039;before&#039;,&#039;a&#039;},&lt;br /&gt;
	[&#039;b&#039;]={&#039;before&#039;,&#039;a&#039;},&lt;br /&gt;
	[&#039;before&#039;]={&#039;before&#039;,&#039;a&#039;},&lt;br /&gt;
	[&#039;&amp;gt;&#039;]={&#039;after&#039;,&#039;a&#039;},&lt;br /&gt;
	[&#039;a&#039;]={&#039;after&#039;,&#039;a&#039;},&lt;br /&gt;
	[&#039;after&#039;]={&#039;after&#039;,&#039;a&#039;},&lt;br /&gt;
	[&#039;~&#039;]={&#039;circa&#039;,&#039;a&#039;},&lt;br /&gt;
	[&#039;c&#039;]={&#039;circa&#039;,&#039;a&#039;},&lt;br /&gt;
	[&#039;ca&#039;]={&#039;circa&#039;,&#039;a&#039;},&lt;br /&gt;
	[&#039;circa&#039;]={&#039;circa&#039;,&#039;a&#039;},&lt;br /&gt;
	[&#039;by&#039;]={&#039;by&#039;,&#039;a&#039;},&lt;br /&gt;
	[&#039;from&#039;]={&#039;from&#039;,&#039;a&#039;},&lt;br /&gt;
	[&#039;until&#039;]={&#039;until&#039;,&#039;a&#039;},&lt;br /&gt;
	[&#039;uncertain&#039;]={&#039;uncertain&#039;,&#039;a&#039;},&lt;br /&gt;
&lt;br /&gt;
	-- eras&lt;br /&gt;
	[&#039;bc&#039;]={&#039;bc&#039;,&#039;e&#039;},&lt;br /&gt;
	[&#039;bce&#039;]={&#039;bc&#039;,&#039;e&#039;},&lt;br /&gt;
	[&#039;before present&#039;]={&#039;bp&#039;,&#039;e&#039;},&lt;br /&gt;
	[&#039;bp&#039;]={&#039;bp&#039;,&#039;e&#039;},&lt;br /&gt;
	[&#039;ce&#039;]={&#039;ad&#039;,&#039;e&#039;},&lt;br /&gt;
	[&#039;ad&#039;]={&#039;ad&#039;,&#039;e&#039;},&lt;br /&gt;
	[&#039;ah&#039;]={&#039;ah&#039;,&#039;e&#039;},&lt;br /&gt;
&lt;br /&gt;
	-- conjunctions&lt;br /&gt;
	[&#039;&amp;amp;&#039;]={&#039;and&#039;,&#039;j&#039;},&lt;br /&gt;
	[&#039;and&#039;]={&#039;and&#039;,&#039;j&#039;},&lt;br /&gt;
	[&#039;or&#039;]={&#039;or&#039;,&#039;j&#039;},&lt;br /&gt;
	[&#039;-&#039;]={&#039;from-until&#039;,&#039;j&#039;},&lt;br /&gt;
	[&#039;–&#039;]={&#039;from-until&#039;,&#039;j&#039;},&lt;br /&gt;
	[&#039;from-until&#039;]={&#039;from-until&#039;,&#039;j&#039;},&lt;br /&gt;
	[&#039;between&#039;]={&#039;between&#039;,&#039;j&#039;},&lt;br /&gt;
	[&#039;circa2&#039;]={&#039;circa2&#039;,&#039;a&#039;},&lt;br /&gt;
	&lt;br /&gt;
	-- precision&lt;br /&gt;
	[&#039;day&#039;]={&#039;day&#039;,&#039;p&#039;},&lt;br /&gt;
	[&#039;month&#039;]={&#039;month&#039;,&#039;p&#039;},&lt;br /&gt;
	[&#039;year&#039;]={&#039;year&#039;,&#039;p&#039;},&lt;br /&gt;
	[&#039;s&#039;]={&#039;decade&#039;,&#039;p&#039;},&lt;br /&gt;
	[&#039;decade&#039;]={&#039;decade&#039;,&#039;p&#039;},&lt;br /&gt;
	[&#039;century&#039;]={&#039;century&#039;,&#039;p&#039;},&lt;br /&gt;
	[&#039;millennium&#039;]={&#039;millennium&#039;,&#039;p&#039;},&lt;br /&gt;
	[&#039;million&#039;]={&#039;million&#039;,&#039;p&#039;},&lt;br /&gt;
	[&#039;billion&#039;]={&#039;billion&#039;,&#039;p&#039;},&lt;br /&gt;
&lt;br /&gt;
	-- calendar&lt;br /&gt;
	[&#039;julian&#039;]={&#039;julian&#039;,&#039;c&#039;},&lt;br /&gt;
	[&#039;islamic&#039;]={&#039;islamic&#039;,&#039;c&#039;},&lt;br /&gt;
	[&#039;hijri&#039;]={&#039;islamic&#039;,&#039;c&#039;},&lt;br /&gt;
	&lt;br /&gt;
	-- &amp;quot;Turn of the ...&amp;quot; options are a combos which will be handled in similar way as calendars&lt;br /&gt;
	[&#039;turn of the century&#039;]={&#039;turn of the century&#039;,&#039;c&#039;},&lt;br /&gt;
	[&#039;century turn&#039;]={&#039;turn of the century&#039;,&#039;c&#039;},&lt;br /&gt;
	[&#039;turn of the decade&#039;]={&#039;turn of the decade&#039;,&#039;c&#039;},&lt;br /&gt;
	[&#039;decade turn&#039;]={&#039;turn of the decade&#039;,&#039;c&#039;},&lt;br /&gt;
	[&#039;turn of the year&#039;]={&#039;turn of the year&#039;,&#039;c&#039;},&lt;br /&gt;
	[&#039;year turn&#039;]={&#039;turn of the year&#039;,&#039;c&#039;},&lt;br /&gt;
&lt;br /&gt;
	-- other dates which will be handled in similar way as calendars&lt;br /&gt;
	[&#039;?&#039;]={&#039;unknown&#039;,&#039;c&#039;},&lt;br /&gt;
	[&#039;unknown&#039;]={&#039;unknown&#039;,&#039;c&#039;},&lt;br /&gt;
	[&#039;unknown year&#039;]={&#039;year unknown&#039;,&#039;c&#039;},&lt;br /&gt;
	[&#039;year unknown&#039;]={&#039;year unknown&#039;,&#039;c&#039;},&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
return p&lt;/div&gt;</summary>
		<author><name>Aron.hives@edubase.net</name></author>
	</entry>
	<entry>
		<id>https://edubase.wiki/index.php?title=Module:I18n&amp;diff=27346</id>
		<title>Module:I18n</title>
		<link rel="alternate" type="text/html" href="https://edubase.wiki/index.php?title=Module:I18n&amp;diff=27346"/>
		<updated>2018-11-12T22:47:31Z</updated>

		<summary type="html">&lt;p&gt;Aron.hives@edubase.net: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;local p = {}&lt;br /&gt;
&lt;br /&gt;
-- Credit to http://stackoverflow.com/a/1283608/2644759&lt;br /&gt;
-- cc-by-sa 3.0&lt;br /&gt;
local function tableMerge(t1, t2, overwrite)&lt;br /&gt;
	for k,v in pairs(t2) do&lt;br /&gt;
		if type(v) == &amp;quot;table&amp;quot; and type(t1[k]) == &amp;quot;table&amp;quot; then&lt;br /&gt;
			-- since type(t1[k]) == type(v) == &amp;quot;table&amp;quot;, so t1[k] and v is true&lt;br /&gt;
			tableMerge(t1[k], v, overwrite) -- t2[k] == v&lt;br /&gt;
		else&lt;br /&gt;
			if overwrite or t1[k] == nil then t1[k] = v end&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	return t1&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.loadI18n(name, i18n_arg)&lt;br /&gt;
	local exist, res = pcall(require, name)&lt;br /&gt;
	if exist and next(res) ~= nil then&lt;br /&gt;
		if i18n_arg then&lt;br /&gt;
			tableMerge(i18n_arg, res.i18n, true)&lt;br /&gt;
		elseif type(i18n) == &amp;quot;table&amp;quot; then&lt;br /&gt;
			-- merge to global i18n&lt;br /&gt;
			tableMerge(i18n, res.i18n, true)&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.loadI18nFrame(frame, i18n_arg)&lt;br /&gt;
	p.loadI18n(frame:getTitle()..&amp;quot;/i18n&amp;quot;, i18n_arg)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
return p&lt;/div&gt;</summary>
		<author><name>Aron.hives@edubase.net</name></author>
	</entry>
	<entry>
		<id>https://edubase.wiki/index.php?title=Module:DateI18n&amp;diff=27344</id>
		<title>Module:DateI18n</title>
		<link rel="alternate" type="text/html" href="https://edubase.wiki/index.php?title=Module:DateI18n&amp;diff=27344"/>
		<updated>2018-11-12T22:47:30Z</updated>

		<summary type="html">&lt;p&gt;Aron.hives@edubase.net: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;--[[  &lt;br /&gt;
 &lt;br /&gt;
This module is intended for processing of date strings.&lt;br /&gt;
&lt;br /&gt;
Copied from https://commons.wikimedia.org/w/index.php?title=Module:Date&amp;amp;oldid=224728211&lt;br /&gt;
Used by Module:ISOdate, Module:Complex date, Module:WikidataIB&lt;br /&gt;
&lt;br /&gt;
Authors and maintainers:&lt;br /&gt;
* User:Parent5446 - original version of the function mimicking template:ISOdate&lt;br /&gt;
* User:Jarekt - original version of the functions mimicking template:Date and template:ISOyear&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
local p = {}&lt;br /&gt;
&lt;br /&gt;
-- =======================================&lt;br /&gt;
-- === Dependencies ======================&lt;br /&gt;
-- =======================================&lt;br /&gt;
local i18n  = require(&#039;Module:I18n/date&#039;)		-- get localized translations of date formats&lt;br /&gt;
local yesno = require(&#039;Module:Yesno&#039;)&lt;br /&gt;
&lt;br /&gt;
local function langSwitch(list,lang)&lt;br /&gt;
	local langList = mw.language.getFallbacksFor(lang)&lt;br /&gt;
	table.insert(langList,1,lang)&lt;br /&gt;
	for i,language in ipairs(langList) do&lt;br /&gt;
		if list[language] then&lt;br /&gt;
			return list[language]&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
Date&lt;br /&gt;
 &lt;br /&gt;
This function can be used to provide an ISOdate template. &lt;br /&gt;
 &lt;br /&gt;
Usage:&lt;br /&gt;
{{#invoke:Date|Date|year=|month=|day=|hour=|minute=|second=|tzhour=|tzmin=|lang=en}}&lt;br /&gt;
&lt;br /&gt;
Parameters:&lt;br /&gt;
  year,month,day,hour,minute,second: broken down date-time component strings&lt;br /&gt;
  tzhour, tzmin: timezone offset from UTC, hours and minutes&lt;br /&gt;
  lang: The language to display it in&lt;br /&gt;
  case: Language format (genitive, etc.) for some languages&lt;br /&gt;
 class: CSS class for the &amp;lt;time&amp;gt; node, use &amp;quot;&amp;quot; for no metadata at all&lt;br /&gt;
&lt;br /&gt;
 Error Handling:&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
function p.Date(frame)&lt;br /&gt;
	local args = frame.args&lt;br /&gt;
	if not (args.lang and mw.language.isSupportedLanguage(args.lang)) then &lt;br /&gt;
		args.lang = frame:callParserFunction( &amp;quot;int&amp;quot;, &amp;quot;lang&amp;quot; ) -- get user&#039;s chosen language &lt;br /&gt;
	end&lt;br /&gt;
	return p._Date(	&lt;br /&gt;
		{ &lt;br /&gt;
			args.year   or &#039;&#039;, &lt;br /&gt;
			args.month  or &#039;&#039;,&lt;br /&gt;
			args.day    or &#039;&#039;, &lt;br /&gt;
			args.hour   or &#039;&#039;, &lt;br /&gt;
			args.minute or &#039;&#039;, &lt;br /&gt;
			args.second or &#039;&#039;,&lt;br /&gt;
			args.tzhour or &#039;&#039;,&lt;br /&gt;
			args.tzmin  or &#039;&#039;&lt;br /&gt;
		},&lt;br /&gt;
		args.lang,                  -- language&lt;br /&gt;
		args.case  or &#039;&#039;,           -- allows to specify grammatical case for the month for languages that use them&lt;br /&gt;
		args.class or &#039;dtstart&#039;,    -- allows to set the html class of the time node where the date is included. This is useful for microformats.&lt;br /&gt;
		args.trim_year or &#039;100-999&#039; -- by default pad one and 2 digit years to be 4 digit long, while keeping 3 digit years as is&lt;br /&gt;
	)	&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
function p._Date(datevec, lang, case, class, trim_year)	&lt;br /&gt;
	-- make sure inputs are in the right format&lt;br /&gt;
	for i = #datevec + 1, 8 do&lt;br /&gt;
		datevec[i] = &#039;&#039;&lt;br /&gt;
	end&lt;br /&gt;
	if  not case  then case  = &#039;&#039; end&lt;br /&gt;
	if  not class then class = &#039;&#039; end&lt;br /&gt;
	if  not trim_year then trim_year = &#039;100-999&#039; end&lt;br /&gt;
&lt;br /&gt;
	-- if language is not provided than look up users language&lt;br /&gt;
	-- WARNING: This step should be done by the template as it does not seem to work as well here (cache issues?)&lt;br /&gt;
	if not lang or not mw.language.isValidCode( lang ) then&lt;br /&gt;
		lang = &#039;en&#039;&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	-- Just in case someone broke the internationalization code than fix the english defaults&lt;br /&gt;
	if i18n.DateLang[&#039;en&#039;] == nil then&lt;br /&gt;
		i18n.DateLang[&#039;en&#039;] = &#039;en-form&#039;&lt;br /&gt;
	end	&lt;br /&gt;
	if i18n.DateFormat[&#039;en-form&#039;] == nil then&lt;br /&gt;
		i18n.DateFormat[&#039;en-form&#039;] = {YMDHMS=&#039;j F Y, H:i:s&#039;, YMDHM=&#039;j F Y, H:i&#039;, YMD=&#039;j F Y&#039;, YM=&#039;F Y&#039;, MD=&#039;j F&#039;, Y=&#039;Y&#039;}&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- create datecode based on which variables are provided and check for out of bound values&lt;br /&gt;
	local maxval = {9999, 12, 31, 23, 59, 60, 23, 59} -- max values for year, month, ...&lt;br /&gt;
	local c = {&#039;Y&#039;, &#039;M&#039;, &#039;D&#039;, &#039;H&#039;, &#039;M&#039;, &#039;S&#039;, &#039;&#039;, &#039;&#039;}&lt;br /&gt;
	local datecode = &#039;&#039; -- a string signifying which combination of variables was provided&lt;br /&gt;
	local datenum = {}  -- date-time encoded as a vector = [year, month, ... , second]&lt;br /&gt;
	for i, v in ipairs( datevec ) do&lt;br /&gt;
		if v~=nil and v~=&#039;&#039; then&lt;br /&gt;
			datecode = datecode .. c[i]&lt;br /&gt;
			datenum[i] = tonumber(v)&lt;br /&gt;
			if datenum[i]==nil and i==2 then&lt;br /&gt;
				-- month is not a number -&amp;gt; check if it is a month name in English&lt;br /&gt;
				v = mw.language.new(&#039;en&#039;):formatDate( &amp;quot;n&amp;quot;, v)&lt;br /&gt;
				datenum[i] = tonumber(v)&lt;br /&gt;
			end&lt;br /&gt;
			if datenum[i]==nil or datenum[i]&amp;gt;maxval[i] then&lt;br /&gt;
				-- Some numbers are out of range -&amp;gt; abort and return the empty string&lt;br /&gt;
				return &#039;&#039;&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	-- create time stamp string (for example 2000-02-20 02:20:20) based on which variables were provided&lt;br /&gt;
	local timeStamp&lt;br /&gt;
	if datecode == &#039;YMDHMS&#039; then&lt;br /&gt;
		timeStamp = string.format(&#039;%04i-%02i-%02i %02i:%02i:%02i&#039;, datenum[1], datenum[2], datenum[3], datenum[4], datenum[5], datenum[6] )&lt;br /&gt;
	elseif datecode == &#039;YMDHM&#039; then&lt;br /&gt;
		timeStamp = string.format(&#039;%04i-%02i-%02i %02i:%02i&#039;, datenum[1], datenum[2], datenum[3], datenum[4], datenum[5] )&lt;br /&gt;
	elseif datecode:sub(1,3)==&#039;YMD&#039; then&lt;br /&gt;
		timeStamp = string.format(&#039;%04i-%02i-%02i&#039;, datenum[1], datenum[2], datenum[3] )&lt;br /&gt;
		datecode = &#039;YMD&#039; -- &#039;YMD&#039;, &#039;YMDHMS&#039; and &#039;YMDHM&#039; are the only supported format starting with &#039;YMD&#039;. All others will be converted to &#039;YMD&#039;&lt;br /&gt;
	elseif datecode == &#039;YM&#039; then&lt;br /&gt;
		timeStamp = string.format(&#039;%04i-%02i&#039;, datenum[1], datenum[2] )&lt;br /&gt;
	elseif datecode:sub(1,1)==&#039;Y&#039; then&lt;br /&gt;
		timeStamp = string.format(&#039;%04i&#039;, datenum[1] )&lt;br /&gt;
		datecode = &#039;Y&#039; &lt;br /&gt;
	elseif datecode == &#039;M&#039; then&lt;br /&gt;
		timeStamp = string.format(&#039;%04i-%02i-%02i&#039;, 2000, datenum[2], 1 )&lt;br /&gt;
		class = &#039;&#039; -- date not complete -&amp;gt; no html formating or micro-tagging of date string&lt;br /&gt;
	elseif datecode == &#039;MD&#039; then&lt;br /&gt;
		timeStamp = string.format(&#039;%04i-%02i-%02i&#039;, 2000, datenum[2], datenum[3] )&lt;br /&gt;
		class = &#039;&#039; -- date not complete -&amp;gt; no html formating or micro-tagging of date string&lt;br /&gt;
	else&lt;br /&gt;
		return &#039;&#039;  -- format not supported&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- ==========================================================&lt;br /&gt;
	-- === Create Date String using in chosen language&lt;br /&gt;
	-- ==========================================================&lt;br /&gt;
	&lt;br /&gt;
	-- which form should the date take? &lt;br /&gt;
	-- Use langSwitch to pick formating for each language&lt;br /&gt;
	local langDateForm = langSwitch(i18n.DateLang, lang)&lt;br /&gt;
	&lt;br /&gt;
	-- special case of French and Gallic dates, which require different date format for the 1st day of the month&lt;br /&gt;
	if datenum[3]==1 and (langDateForm==&#039;fr-form&#039; or langDateForm==&#039;ga-form&#039;) then&lt;br /&gt;
		langDateForm = langDateForm .. &#039;1&#039; -- ordinal form for the first day of the month&lt;br /&gt;
	end&lt;br /&gt;
	-- special case of Basque dates, which require different date format for the 1st, 11th, 21st and 31st day of the month&lt;br /&gt;
	if langDateForm==&#039;eu-form&#039; then&lt;br /&gt;
		if (datenum[3]==1 or datenum[3]==21) then&lt;br /&gt;
			langDateForm = &#039;eu-form01&#039;&lt;br /&gt;
		elseif (datenum[3]==11 or datenum[3]==31) then&lt;br /&gt;
			langDateForm = &#039;eu-form11&#039;&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- Look up country specific format input to {{#time}} function&lt;br /&gt;
	local dFormat = i18n.DateFormat[langDateForm][datecode]&lt;br /&gt;
	&lt;br /&gt;
	-- overwrite default grammatical case of the month (applies mostly to Slavic languages)&lt;br /&gt;
	if (case==&#039;gen&#039;) then&lt;br /&gt;
		-- CAUTION: at the moment i18n.DateFormat uses &amp;quot;F&amp;quot; only as month name, but this might change and this operation does not check if &#039;F&#039; is in &amp;quot;&amp;quot; brackets or not, so if some language starts using &#039;F&#039;  in &amp;quot;&amp;quot; than this will not work for that language&lt;br /&gt;
		dFormat = dFormat:gsub(&amp;quot;F&amp;quot;, &amp;quot;xg&amp;quot;); &lt;br /&gt;
	end&lt;br /&gt;
	if (case==&#039;nom&#039;) then&lt;br /&gt;
		-- CAUTION: at the moment i18n.DateFormat uses &amp;quot;xg&amp;quot; only as month name, but this might change and this operation does not check if &#039;xg&#039; is in &amp;quot;&amp;quot; brackets or not, so if some language starts using &#039;xg&#039;  in &amp;quot;&amp;quot; than this will not work for that language&lt;br /&gt;
		dFormat = dFormat:gsub(&amp;quot;xg&amp;quot;, &amp;quot;F&amp;quot;);&lt;br /&gt;
	end&lt;br /&gt;
	if ((lang==&#039;ru&#039; or lang==&#039;pl&#039; or lang==&#039;cs&#039; or lang==&#039;sl&#039; or lang==&#039;sk&#039;) and (case==&#039;loc&#039; or case==&#039;ins&#039;)) or&lt;br /&gt;
		(lang==&#039;fi&#039; and (case==&#039;ptv&#039; or case==&#039;ine&#039;or case==&#039;ela&#039;or case==&#039;ill&#039;) ) then&lt;br /&gt;
		local monthEn =  mw.language.new(&#039;en&#039;):formatDate( &amp;quot;F&amp;quot;, timeStamp) -- month name in English&lt;br /&gt;
		-- month name using proper case and language. It relies on messages stored in MediaWiki namespace for some cases and languages&lt;br /&gt;
		-- That is why this IF statement uses &amp;quot;lang&amp;quot; not &amp;quot;langDateForm&amp;quot; variable to decide&lt;br /&gt;
		local monthMsg =  mw.message.new( string.format(&#039;%s-%s&#039;, monthEn, case ) ):inLanguage( lang )&lt;br /&gt;
		if not monthMsg:isDisabled() then -- make sure it exists&lt;br /&gt;
			local month=monthMsg:plain()&lt;br /&gt;
			dFormat = dFormat:gsub(&#039;F&#039;, &#039;&amp;quot;&#039;..month..&#039;&amp;quot;&#039;); -- replace default month with month name we already looked up&lt;br /&gt;
			dFormat = dFormat:gsub(&#039;xg&#039;, &#039;&amp;quot;&#039;..month..&#039;&amp;quot;&#039;);&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	-- Special case related to Quechua and Kichwa languages&lt;br /&gt;
	-- see https://commons.wikimedia.org/wiki/Template_talk:Date#Quechua from 2014&lt;br /&gt;
	if (lang==&#039;qu&#039; or lang==&#039;qug&#039;) and case==&#039;nom&#039; then&lt;br /&gt;
		dFormat = dFormat:gsub(&#039;F&amp;quot;pi&amp;quot;&#039;, &#039;F&#039;);&lt;br /&gt;
	end	&lt;br /&gt;
&lt;br /&gt;
	-- Lua only date formating using {{#time}} parser function (new)&lt;br /&gt;
		-- prefered call which gives &amp;quot;Lua error: too many language codes requested.&amp;quot; on the [[Module talk:Date/sandbox/testcases]] page&lt;br /&gt;
		--local datestr = mw.language.new(lang):formatDate( dFormat, timeStamp) &lt;br /&gt;
	local datestr = mw.getCurrentFrame():callParserFunction( &amp;quot;#time&amp;quot;, { dFormat, timeStamp, lang } )&lt;br /&gt;
	&lt;br /&gt;
	-- Another special case related to Thai solar calendar&lt;br /&gt;
	if lang==&#039;th&#039; and datenum[1]~= nil and datenum[1]&amp;lt;=1940 then&lt;br /&gt;
		-- As of 2014 {{#time}} parser function did not resolve those cases properly&lt;br /&gt;
		-- See https://en.wikipedia.org/wiki/Thai_solar_calendar#New_year for reference&lt;br /&gt;
		-- Disable once https://bugzilla.wikimedia.org/show_bug.cgi?id=66648 is fixed&lt;br /&gt;
		if datecode==&#039;Y&#039; then -- date is ambiguous&lt;br /&gt;
			datestr = string.format(&#039;%04i หรือ %04i&#039;, datenum[1]+542, datenum[1]+543 ) &lt;br /&gt;
		elseif datenum[2]&amp;lt;=3 then -- year is wrong (one too many)&lt;br /&gt;
			datestr = datestr:gsub( string.format(&#039;%04i&#039;, datenum[1]+543), string.format(&#039;%04i&#039;, datenum[1]+542 ) )&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	-- If year&amp;lt;1000 than either keep it padded to the length of 4 digits or trim it&lt;br /&gt;
	-- decide if the year will stay padded with zeros (for years in 0-999 range)&lt;br /&gt;
	if datenum[1]~= nil and datenum[1]&amp;lt;1000 then&lt;br /&gt;
		local trim = yesno(trim_year,nil)&lt;br /&gt;
		if trim == nil then&lt;br /&gt;
			local YMin, YMax = trim_year:match( &#039;(%d+)-(%d+)&#039; )&lt;br /&gt;
			trim = (YMin~=nil and datenum[1]&amp;gt;=tonumber(YMin) and datenum[1]&amp;lt;=tonumber(YMax)) &lt;br /&gt;
		end&lt;br /&gt;
	&lt;br /&gt;
		-- If the date form isn&#039;t the Thai solar calendar, don&#039;t zero pad years in the range of 100-999.  &lt;br /&gt;
		-- If at some point support for Islamic/Hebrew/Japanese years is added, they may need to be skipped as well. &lt;br /&gt;
		if trim then&lt;br /&gt;
			--local yearStr1 = mw.language.new(lang):formatDate( &#039;Y&#039;, timeStamp)&lt;br /&gt;
			local yearStr1 = mw.getCurrentFrame():callParserFunction( &amp;quot;#time&amp;quot;, { &#039;Y&#039;, timeStamp, lang } )&lt;br /&gt;
			--local yearStr1 = datestr:match( &#039;%d%d%d%d&#039; ) -- 4 digits in a row (in any language) - that must be a year&lt;br /&gt;
			local yearStr2 = yearStr1&lt;br /&gt;
			local zeroStr = mw.ustring.sub(yearStr1,1,1)&lt;br /&gt;
			for i=1,3 do -- trim leading zeros&lt;br /&gt;
				if mw.ustring.sub(yearStr2,1,1)==zeroStr then&lt;br /&gt;
					yearStr2 = mw.ustring.sub(yearStr2, 2, 5-i)&lt;br /&gt;
				else&lt;br /&gt;
					break&lt;br /&gt;
				end&lt;br /&gt;
			end&lt;br /&gt;
			datestr = datestr:gsub( yearStr1, yearStr2 )&lt;br /&gt;
			--datestr = string.format(&#039;%s (%s, %s)&#039;, datestr, yearStr1, yearStr2 )&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- append timezone if present&lt;br /&gt;
	if datevec[7] ~= &#039;&#039; and (datecode == &#039;YMDHMS&#039; or datecode == &#039;YMDHM&#039;) then&lt;br /&gt;
		local tzstr, tzhournum = &#039;&#039;, tonumber(datevec[7])&lt;br /&gt;
		if tzhournum &amp;lt; 0 then tzstr = &#039;−&#039; else tzstr = &#039;+&#039; end&lt;br /&gt;
		tzstr = tzstr..string.format(&amp;quot;%02d&amp;quot;, math.abs(tzhournum))..&#039;:&#039;&lt;br /&gt;
		if datevec[8] ~= &#039;&#039; then tzstr = tzstr..datevec[8] else tzstr = tzstr..&#039;00&#039; end&lt;br /&gt;
		datestr = datestr..&#039; &#039;..tzstr&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- html formating and tagging of date string&lt;br /&gt;
	if class ~= &#039;&#039; then&lt;br /&gt;
		local DateHtmlTags = &#039;&amp;lt;span style=&amp;quot;white-space:nowrap&amp;quot;&amp;gt;&amp;lt;time class=&amp;quot;%s&amp;quot; datetime=&amp;quot;%s&amp;quot;&amp;gt;%s&amp;lt;/time&amp;gt;&amp;lt;/span&amp;gt;&#039;&lt;br /&gt;
		datestr = DateHtmlTags:format(class, timeStamp, datestr)&lt;br /&gt;
	end&lt;br /&gt;
	return datestr&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
return p&lt;/div&gt;</summary>
		<author><name>Aron.hives@edubase.net</name></author>
	</entry>
	<entry>
		<id>https://edubase.wiki/index.php?title=Module:Complex_date&amp;diff=27342</id>
		<title>Module:Complex date</title>
		<link rel="alternate" type="text/html" href="https://edubase.wiki/index.php?title=Module:Complex_date&amp;diff=27342"/>
		<updated>2018-11-12T22:47:30Z</updated>

		<summary type="html">&lt;p&gt;Aron.hives@edubase.net: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;--[[ &lt;br /&gt;
  __  __           _       _         ____                      _                 _       _       &lt;br /&gt;
 |  \/  | ___   __| |_   _| | ___ _ / ___|___  _ __ ___  _ __ | | _____  __   __| | __ _| |_ ___ &lt;br /&gt;
 | |\/| |/ _ \ / _` | | | | |/ _ (_) |   / _ \| &#039;_ ` _ \| &#039;_ \| |/ _ \ \/ /  / _` |/ _` | __/ _ \&lt;br /&gt;
 | |  | | (_) | (_| | |_| | |  __/_| |__| (_) | | | | | | |_) | |  __/&amp;gt;  &amp;lt;  | (_| | (_| | ||  __/&lt;br /&gt;
 |_|  |_|\___/ \__,_|\__,_|_|\___(_)\____\___/|_| |_| |_| .__/|_|\___/_/\_\  \__,_|\__,_|\__\___|&lt;br /&gt;
                                                        |_|                                      &lt;br /&gt;
 &lt;br /&gt;
This module is intended for creation of complex date phrases in variety of languages.&lt;br /&gt;
 &lt;br /&gt;
Once deployed, please do not modify this code without applying the changes first at Module:Complex date/sandbox and testing &lt;br /&gt;
at Module:Complex date/sandbox/testcases.&lt;br /&gt;
 &lt;br /&gt;
Authors and maintainers:&lt;br /&gt;
* User:Sn1per - first draft of the original version &lt;br /&gt;
* User:Jarekt - corrections and expansion of the original version &lt;br /&gt;
 &lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
-- List of external modules and functions&lt;br /&gt;
local p = {Error = nil}&lt;br /&gt;
local i18n       = require(&#039;Module:i18n/complex date&#039;)&lt;br /&gt;
local ISOdate    = require(&#039;Module:ISOdate&#039;)._ISOdate&lt;br /&gt;
local Calendar   = require(&#039;Module:Calendar&#039;)&lt;br /&gt;
&lt;br /&gt;
-- ==================================================&lt;br /&gt;
-- === Internal functions ===========================&lt;br /&gt;
-- ==================================================&lt;br /&gt;
&lt;br /&gt;
local function langSwitch(list,lang)&lt;br /&gt;
	local langList = mw.language.getFallbacksFor(lang)&lt;br /&gt;
	table.insert(langList,1,lang)&lt;br /&gt;
	table.insert(langList,math.max(#langList,2),&#039;default&#039;)&lt;br /&gt;
	for i,language in ipairs(langList) do&lt;br /&gt;
		if list[language] then&lt;br /&gt;
			return list[language]&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function formatnum1(numStr, lang)&lt;br /&gt;
-- mostly require(&#039;Module:Formatnum&#039;).formatNum function used to translate a number to use different numeral characters, &lt;br /&gt;
-- except that it it does not call  that function unless the language is on the list &amp;quot;LList&amp;quot;&lt;br /&gt;
	local LList = {bn=1,bpy=1,kn=1,hi=1,mr=1,new=1,pa=1,gu=1,fa=1,glk=1,mzn=1,ur=1,ar=1,ckb=1,ks=1,lo=1,[&#039;or&#039;]=1,bo=1,[&#039;ml-old&#039;]=1,mn=1,te=1,th=1}&lt;br /&gt;
	if LList[lang] then -- call only when the language is on the list&lt;br /&gt;
		numStr = require(&#039;Module:Formatnum&#039;).formatNum(numStr, lang, 1)&lt;br /&gt;
	end&lt;br /&gt;
	return numStr&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function getISODate(datestr, datetype, lang, num, case)&lt;br /&gt;
-- translate dates in the format YYYY, YYYY-MM, and YYYY-MM-DD&lt;br /&gt;
	if  not case and i18n.Translations[datetype] then&lt;br /&gt;
		-- look up the grammatical case needed and call ISOdate module&lt;br /&gt;
		local rec = langSwitch(i18n.Translations[datetype], lang)&lt;br /&gt;
		if type(rec)==&#039;table&#039; then&lt;br /&gt;
			case = rec.case[num]&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	return ISOdate(datestr, lang, case, &#039;&#039;, 1)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function translatePhrase(date1, date2, operation, lang, state)&lt;br /&gt;
-- use tables in Module:i18n/complex date to translate a phrase&lt;br /&gt;
	if not i18n.Translations[operation] then&lt;br /&gt;
		p.Error = string.format(&#039;&amp;lt;span style=&amp;quot;background-color:red;&amp;quot;&amp;gt;Error in [[Module:Complex date]]: input parameter &amp;quot;%s&amp;quot; is not recognized.&amp;lt;/span&amp;gt;&#039;, operation or &#039;nil&#039;)&lt;br /&gt;
		return &#039;&#039;&lt;br /&gt;
	end&lt;br /&gt;
	local dateStr = langSwitch(i18n.Translations[operation], lang)&lt;br /&gt;
	if type(dateStr)==&#039;table&#039; then&lt;br /&gt;
		dateStr = dateStr[1]&lt;br /&gt;
	end&lt;br /&gt;
	if type(dateStr)==&#039;function&#039; then&lt;br /&gt;
		local success&lt;br /&gt;
		local nDates = i18n.Translations[operation][&#039;nDates&#039;]&lt;br /&gt;
		if nDates==2 then -- 2 date phrase&lt;br /&gt;
			success, dateStr = pcall(dateStr, date1, date2, state)&lt;br /&gt;
		else  -- 1 date phrase&lt;br /&gt;
			success, dateStr = pcall(dateStr, date1, state)&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	if type(dateStr)==&#039;string&#039; then&lt;br /&gt;
		-- replace parts of the string &#039;$date1&#039; and &#039;$date2&#039; with date1 and date2 strings&lt;br /&gt;
		dateStr = mw.ustring.gsub(dateStr, &#039;$date1&#039;, date1)&lt;br /&gt;
		dateStr = mw.ustring.gsub(dateStr, &#039;$date2&#039;, date2)&lt;br /&gt;
	else&lt;br /&gt;
		-- Special case of more complex phrases that can be build out of simple phrases&lt;br /&gt;
		-- If complex case is not translated to &amp;quot;lang&amp;quot; than build it out of simpler ones&lt;br /&gt;
		local x = dateStr&lt;br /&gt;
		dateStr = p._complex_date(x.conj, x.adj1, date1, x.units1, x.era1, x.adj2, date2, x.units2, x.era2, lang, 2)&lt;br /&gt;
	end&lt;br /&gt;
	return dateStr&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function oneDatePhrase(dateStr, adj, era, units, lang, num, case, state)&lt;br /&gt;
-- translate a single date phrase&lt;br /&gt;
	if num==2 then&lt;br /&gt;
		state.adj, state.era, state.units, state.precision = state.adj2, state.era2, state.units2, state.precision2 &lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	-- dateStr can have many forms: ISO date, year or a number for &lt;br /&gt;
	-- decade, century or millennium&lt;br /&gt;
	if units == &#039;&#039; then -- unit is &amp;quot;year&amp;quot;, &amp;quot;month&amp;quot;, &amp;quot;day&amp;quot;&lt;br /&gt;
		dateStr = getISODate(dateStr, adj, lang, num, case)&lt;br /&gt;
	else -- units is &amp;quot;decade&amp;quot;, &amp;quot;century&amp;quot;, &amp;quot;millennium&#039;&#039;&lt;br /&gt;
		dateStr = translatePhrase(dateStr, &#039;&#039;, units, lang, state)&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	-- add adjective (&amp;quot;early&amp;quot;, &amp;quot;mid&amp;quot;, etc.) or preposition (&amp;quot;before&amp;quot;, &amp;quot;after&amp;quot;, &lt;br /&gt;
	-- &amp;quot;circa&amp;quot;, etc.) to the date&lt;br /&gt;
	if adj ~= &#039;&#039; then&lt;br /&gt;
		dateStr = translatePhrase(dateStr, &#039;&#039;, adj, lang, state)&lt;br /&gt;
	else -- only era?&lt;br /&gt;
		dateStr = formatnum1(dateStr, lang)&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	-- add era&lt;br /&gt;
	if era ~= &#039;&#039; then&lt;br /&gt;
		dateStr = translatePhrase(dateStr, &#039;&#039;, era, lang, state)&lt;br /&gt;
	end&lt;br /&gt;
	return dateStr&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function twoDatePhrase(date1, date2, state, lang)&lt;br /&gt;
-- translate a double date phrase&lt;br /&gt;
	local dateStr, case&lt;br /&gt;
	local era=&#039;&#039;&lt;br /&gt;
	if state.era1 == state.era2 then&lt;br /&gt;
		-- if both eras are the same than add it only once&lt;br /&gt;
		era = state.era1&lt;br /&gt;
		state.era1 = &#039;&#039;&lt;br /&gt;
		state.era2 = &#039;&#039;&lt;br /&gt;
	end&lt;br /&gt;
	case = {nil, nil}&lt;br /&gt;
	if i18n.Translations[state.conj] then&lt;br /&gt;
		local rec = langSwitch(i18n.Translations[state.conj], lang)&lt;br /&gt;
		if type(rec)==&#039;table&#039; then&lt;br /&gt;
			case = rec.case&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	date1   = oneDatePhrase(date1, state.adj1, state.era1, state.units1, lang, 1, case[1], state)&lt;br /&gt;
	date2   = oneDatePhrase(date2, state.adj2, state.era2, state.units2, lang, 2, case[2], state)&lt;br /&gt;
	dateStr = translatePhrase(date1, date2, state.conj, lang, state)&lt;br /&gt;
	if era ~= &#039;&#039; then&lt;br /&gt;
		dateStr = translatePhrase(dateStr, &#039;&#039;, era, lang, state)&lt;br /&gt;
	end&lt;br /&gt;
	return dateStr&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function otherPhrases(date1, date2, operation, era, lang, state)&lt;br /&gt;
-- translate specialized phrases&lt;br /&gt;
	local dateStr = &#039;&#039;&lt;br /&gt;
		&lt;br /&gt;
	if operation == &#039;islamic&#039; then&lt;br /&gt;
		if date2==&#039;&#039; then date2 = mw.getCurrentFrame():callParserFunction(&#039;#time&#039;, &#039;xmY&#039;, date1) end&lt;br /&gt;
		date1 = getISODate(date1, operation, lang, 1, nil)&lt;br /&gt;
		date2 = getISODate(date2, operation, lang, 2, nil)&lt;br /&gt;
		if era == &#039;&#039; then era = &#039;ad&#039; end&lt;br /&gt;
		dateStr = translatePhrase(date1, &#039;&#039;, era, lang, state) .. &#039; (&#039; .. translatePhrase(date2, &#039;&#039;, &#039;ah&#039;, lang, state) .. &#039;)&#039;&lt;br /&gt;
		era = &#039;&#039;&lt;br /&gt;
	elseif operation == &#039;julian&#039; then&lt;br /&gt;
		if not date2 and date1 then -- Convert from Julian to Gregorian calendar date&lt;br /&gt;
			local JDN = Calendar._date2jdn(date1, 0)&lt;br /&gt;
			if JDN then&lt;br /&gt;
				date2 = date1 -- first date is assumed to be Julian&lt;br /&gt;
				date1 = Calendar._jdn2date(JDN, 1)&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
		date1 = getISODate(date1, operation, lang, 1, nil)&lt;br /&gt;
		date2 = getISODate(date2, operation, lang, 2, nil)&lt;br /&gt;
		dateStr = translatePhrase(date1, date2, operation, lang, state)&lt;br /&gt;
		dateStr = mw.ustring.gsub(mw.ustring.gsub(dateStr, &#039;%( &#039;, &#039;(&#039;), &#039; %)&#039;, &#039;)&#039;) -- in case date2 is empty&lt;br /&gt;
	elseif operation == &#039;turn of the year&#039; or operation == &#039;turn of the decade&#039; or operation == &#039;turn of the century&#039; then &lt;br /&gt;
		if operation == &#039;turn of the decade&#039; then dt=10 else dt=1 end&lt;br /&gt;
		if not date2 or date2==&#039;&#039; then date2=tostring(tonumber(date1)-dt) end&lt;br /&gt;
		if era~=&#039;bp&#039; and era~=&#039;bc&#039; then date1, date2 = date2, date1 end&lt;br /&gt;
		if operation == &#039;turn of the year&#039; then&lt;br /&gt;
			date1 = ISOdate(date1, lang, &#039;&#039;, &#039;&#039;, 1)&lt;br /&gt;
			date2 = ISOdate(date2, lang, &#039;&#039;, &#039;&#039;, 1)&lt;br /&gt;
		else&lt;br /&gt;
			date1 = formatnum1(date1, lang)&lt;br /&gt;
			date2 = formatnum1(date2, lang)&lt;br /&gt;
		end&lt;br /&gt;
		dateStr = translatePhrase(date1, date2, operation, lang, state)&lt;br /&gt;
	elseif operation == &#039;year unknown&#039; then&lt;br /&gt;
		dateStr = translatePhrase(&#039;&#039;, &#039;&#039;, operation, lang, state)&lt;br /&gt;
	elseif operation == &#039;unknown&#039; then&lt;br /&gt;
		dateStr = tostring(mw.message.new( &amp;quot;exif-unknowndate&amp;quot; ):inLanguage( lang ))&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	-- add era&lt;br /&gt;
	if era ~= &#039;&#039; then&lt;br /&gt;
		dateStr = translatePhrase(dateStr, &#039;&#039;, era, lang, state)&lt;br /&gt;
	end&lt;br /&gt;
	return dateStr&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function checkAliases(str1, str2, sType)&lt;br /&gt;
-- some inputs have many aliases - reconcile them and ensure string is playing a proper role	&lt;br /&gt;
local out = &#039;&#039;&lt;br /&gt;
if str1 and str1~=&#039;&#039; then&lt;br /&gt;
	a = i18n.Synonyms[str1] -- look up synonyms of &amp;quot;str1&amp;quot;&lt;br /&gt;
	if a then&lt;br /&gt;
		out = a[1]&lt;br /&gt;
	else&lt;br /&gt;
		p.Error = string.format(&#039;&amp;lt;span style=&amp;quot;background-color:red;&amp;quot;&amp;gt;Error in [[Module:Complex date]]: %s is not recognized.&amp;lt;/span&amp;gt;&#039;, str1)&lt;br /&gt;
	end&lt;br /&gt;
elseif str2 and str2~=&#039;&#039; then -- if &amp;quot;str1&amp;quot; of type &amp;quot;sType&amp;quot; is empty than maybe ...&lt;br /&gt;
	a = i18n.Synonyms[str2]   -- ...&amp;quot;str2&amp;quot; is of the same type and is not empty&lt;br /&gt;
	if a and a[2]==sType then&lt;br /&gt;
		out  = a[1]&lt;br /&gt;
		str2 = &#039;&#039;&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
return out, str2&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function datePrecision(dateStr, units)	&lt;br /&gt;
-- &amp;quot;in this module &amp;quot;Units&amp;quot; is a string like millennium, century, or decade&lt;br /&gt;
--	&amp;quot;precision&amp;quot; is wikibase compatible date precision number: 6=millennium, 7=century, 8=decade, 9=year, 10=month, 11=day&lt;br /&gt;
-- based on string or numeric input calculate &amp;quot;Units&amp;quot; and &amp;quot;precision&amp;quot;&lt;br /&gt;
	local dateNum = tonumber(dateStr);&lt;br /&gt;
	if type(units)==&#039;number&#039; then&lt;br /&gt;
		precision = units&lt;br /&gt;
		if precision&amp;gt;11 then precision=11 end -- clip the range of precision values&lt;br /&gt;
		if     precision==6 then units=&#039;millennium&#039; 		&lt;br /&gt;
		elseif precision==7 then units=&#039;century&#039;&lt;br /&gt;
		elseif precision==8 then units=&#039;decade&#039;&lt;br /&gt;
		else units = &#039;&#039;&lt;br /&gt;
		end&lt;br /&gt;
	elseif type(units)==&#039;string&#039; then&lt;br /&gt;
		units = string.lower(units);&lt;br /&gt;
		if     units==&#039;millennium&#039; then precision=6&lt;br /&gt;
		elseif units==&#039;century&#039;    then precision=7&lt;br /&gt;
		elseif units==&#039;decade&#039;     then precision=8&lt;br /&gt;
		else precision=9&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	if units==&#039;&#039; or precision==9 then&lt;br /&gt;
		local sLen = mw.ustring.len(dateStr)&lt;br /&gt;
		if     sLen&amp;lt;= 4 then precision=9&lt;br /&gt;
		elseif sLen== 7 then precision=10&lt;br /&gt;
		elseif sLen&amp;gt;=10 then precision=11&lt;br /&gt;
		end&lt;br /&gt;
		units=&#039;&#039;&lt;br /&gt;
	end&lt;br /&gt;
	if precision==6 and dateStr.match( dateStr, &#039;%d000&#039; )~=nil then &lt;br /&gt;
		dateStr = tostring(math.floor(tonumber(dateStr)/1000) +1)&lt;br /&gt;
	elseif precision==7 and mw.ustring.match( dateStr, &#039;%d%d00&#039; )~=nil then&lt;br /&gt;
		dateStr = tostring(math.floor(tonumber(dateStr)/100) +1)&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	return dateStr, units, precision&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
local function isodate2timestamp(dateStr, precision, era)&lt;br /&gt;
-- convert date string to timestamps used by Quick Statements&lt;br /&gt;
	local tStamp = nil&lt;br /&gt;
	if era == &#039;ah&#039; or precision&amp;lt;6 then&lt;br /&gt;
		return nil&lt;br /&gt;
	elseif era ~= &#039;&#039; then&lt;br /&gt;
		eraLUT = {ad=&#039;+&#039;, bc=&#039;-&#039;, bp=&#039;-&#039; }&lt;br /&gt;
		era = eraLUT[era]&lt;br /&gt;
	else&lt;br /&gt;
		era=&#039;+&#039;&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
-- convert isodate to timestamp used by quick statements&lt;br /&gt;
	if precision&amp;gt;=9 then &lt;br /&gt;
		if string.match(dateStr,&amp;quot;^%d%d%d%d$&amp;quot;) then               -- if YYYY  format &lt;br /&gt;
			tStamp = era .. dateStr .. &#039;-00-00T00:00:00Z/9&#039;&lt;br /&gt;
		elseif string.match(dateStr,&amp;quot;^%d%d%d%d%-%d%d$&amp;quot;) then      -- if YYYY-MM format &lt;br /&gt;
			tStamp = era .. dateStr .. &#039;-00T00:00:00Z/10&#039;&lt;br /&gt;
		elseif string.match(dateStr,&amp;quot;^%d%d%d%d%-%d%d%-%d%d$&amp;quot;) then  -- if YYYY-MM-DD format &lt;br /&gt;
			tStamp = era .. dateStr .. &#039;T00:00:00Z/11&#039;&lt;br /&gt;
		end&lt;br /&gt;
	elseif precision==8 then -- decade&lt;br /&gt;
		tStamp = era .. dateStr .. &#039;-00-00T00:00:00Z/8&#039;&lt;br /&gt;
	elseif precision==7 then -- century&lt;br /&gt;
		local d = tostring(tonumber(dateStr)-1)&lt;br /&gt;
		tStamp = era .. d .. &#039;50-00-00T00:00:00Z/7&#039;&lt;br /&gt;
	elseif precision==6 then&lt;br /&gt;
		local d = tostring(tonumber(dateStr)-1)&lt;br /&gt;
		tStamp = era .. d .. &#039;500-00-00T00:00:00Z/6&#039;&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	return tStamp&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function oneDateQScode(dateStr, adj, era, precision)&lt;br /&gt;
-- create QuickStatements string for &amp;quot;one date&amp;quot; dates&lt;br /&gt;
	local outputStr = &#039;&#039;&lt;br /&gt;
&lt;br /&gt;
	local d = isodate2timestamp(dateStr, precision, era)&lt;br /&gt;
	if not d then&lt;br /&gt;
		return &#039;&#039;&lt;br /&gt;
	end&lt;br /&gt;
	local rLUT = {            early=&#039;Q40719727&#039;     , mid=&#039;Q40719748&#039;,      late=&#039;Q40719766&#039;,&lt;br /&gt;
		[&#039;1quarter&#039;]=&#039;Q40690303&#039; , [&#039;2quarter&#039;]=&#039;Q40719649&#039;  , [&#039;3quarter&#039;]=&#039;Q40719662&#039;, [&#039;4quarter&#039;]=&#039;Q40719674&#039;,&lt;br /&gt;
		spring=&#039;Q40720559&#039;   , summer=&#039;Q40720564&#039;    , autumn=&#039;Q40720568&#039;  , winter=&#039;Q40720553&#039;,&lt;br /&gt;
		firsthalf=&#039;Q40719687&#039;, secondhalf=&#039;Q40719707&#039; }&lt;br /&gt;
	local qLUT = {[&#039;from&#039;]=&#039;P580&#039;, [&#039;until&#039;]=&#039;P582&#039;, [&#039;after&#039;]=&#039;P1319&#039;, [&#039;before&#039;]=&#039;P1326&#039;}&lt;br /&gt;
&lt;br /&gt;
	local refine = rLUT[adj]&lt;br /&gt;
	local qualitier = qLUT[adj]&lt;br /&gt;
&lt;br /&gt;
	if adj==&#039;&#039; then&lt;br /&gt;
		outputStr = d&lt;br /&gt;
	elseif adj==&#039;circa&#039; then&lt;br /&gt;
		outputStr = d..&amp;quot;,P1480,Q5727902&amp;quot;&lt;br /&gt;
	elseif refine then&lt;br /&gt;
		outputStr = d..&amp;quot;,P4241,&amp;quot;..refine&lt;br /&gt;
	elseif precision&amp;gt;7 and qualitier then&lt;br /&gt;
		local century = string.gsub(d, &#039;Z%/%d+&#039;, &#039;Z/7&#039;)&lt;br /&gt;
		outputStr = century ..&amp;quot;,&amp;quot;.. qualitier ..&amp;quot;,&amp;quot;..d&lt;br /&gt;
	end&lt;br /&gt;
	return outputStr &lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function twoDateQScode(date1, date2, state)&lt;br /&gt;
-- create QuickStatements string for &amp;quot;two date&amp;quot; dates&lt;br /&gt;
	if state.adj1~=&#039;&#039; or state.adj2~=&#039;&#039; or state.era1~=state.era2 then&lt;br /&gt;
		return &#039;&#039;&lt;br /&gt;
	end&lt;br /&gt;
	local outputStr = &#039;&#039;&lt;br /&gt;
	local d1 = isodate2timestamp(date1, state.precision1, state.era1)&lt;br /&gt;
	local d2 = isodate2timestamp(date2, state.precision2, state.era2)&lt;br /&gt;
	if (not d1) or (not d2) then&lt;br /&gt;
		return &#039;&#039;&lt;br /&gt;
	end	&lt;br /&gt;
	-- find date with lower precision in common to both dates&lt;br /&gt;
	local cd&lt;br /&gt;
	local year1 = string.sub(d1,2,5)&lt;br /&gt;
	local k = 0&lt;br /&gt;
	for i = 1,10,1 do &lt;br /&gt;
		if string.sub(d1,1,i)==string.sub(d2,1,i) then &lt;br /&gt;
			k = i -- find last matching letter&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	if k&amp;gt;=9 then              -- same month, since &amp;quot;+YYYY-MM-&amp;quot; is in common&lt;br /&gt;
		cd = isodate2timestamp(string.sub(d1,2,8), 10, state.era1)&lt;br /&gt;
	elseif k&amp;gt;=6 and k&amp;lt;9 then  -- same year, since &amp;quot;+YYYY-&amp;quot; is in common&lt;br /&gt;
		cd = isodate2timestamp(year1, 9, state.era1)&lt;br /&gt;
	elseif k==4 then          -- same decade(k=4, precision=8),  since &amp;quot;+YYY&amp;quot; is in common&lt;br /&gt;
		cd = isodate2timestamp(year1, 8, state.era1)&lt;br /&gt;
	elseif k==3 then          -- same century(k=3, precision=7) since &amp;quot;+YY&amp;quot; is in common&lt;br /&gt;
	  local d = tostring(math.floor(tonumber(year1)/100) +1) -- convert 1999 -&amp;gt; 20&lt;br /&gt;
		cd = isodate2timestamp( d, 7, state.era1)&lt;br /&gt;
	elseif k==2 then          -- same millennium (k=2, precision=6),  since &amp;quot;+Y&amp;quot; is in common&lt;br /&gt;
		local d = tostring(math.floor(tonumber(year1)/1000) +1) -- convert 1999 -&amp;gt; 2&lt;br /&gt;
		cd = isodate2timestamp( d, 6, state.era1)&lt;br /&gt;
	else&lt;br /&gt;
		return &#039;&#039;&lt;br /&gt;
	end&lt;br /&gt;
	--if not cd then&lt;br /&gt;
	--	return &#039; &amp;lt;br/&amp;gt;error: &#039; .. d1..&amp;quot; / &amp;quot; .. d2..&amp;quot; / &amp;quot;.. (cd or &#039;&#039;) ..&amp;quot; / &amp;quot;.. string.sub(d1,2,5)..&amp;quot; / &amp;quot; .. string.sub(d2,2,5)..&amp;quot; / &amp;quot; .. tostring(k)&lt;br /&gt;
	--end&lt;br /&gt;
&lt;br /&gt;
	--&lt;br /&gt;
	if state.conj==&#039;from-until&#039; then&lt;br /&gt;
		outputStr = cd ..&amp;quot;,P580,&amp;quot;.. d1 ..&amp;quot;,P582,&amp;quot;.. d2&lt;br /&gt;
	elseif state.conj==&#039;between&#039; then&lt;br /&gt;
		outputStr = cd ..&amp;quot;,P1319,&amp;quot;.. d1 ..&amp;quot;,P1326,&amp;quot;.. d2&lt;br /&gt;
	elseif state.conj==&#039;circa2&#039; then&lt;br /&gt;
		outputStr = cd ..&amp;quot;,P1319,&amp;quot;.. d1 ..&amp;quot;,P1326,&amp;quot;.. d2 ..&amp;quot;,P1480,Q5727902&amp;quot;&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	return outputStr&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- ==================================================&lt;br /&gt;
-- === External functions ===========================&lt;br /&gt;
-- ==================================================&lt;br /&gt;
&lt;br /&gt;
function p.Era(frame)&lt;br /&gt;
    -- process inputs&lt;br /&gt;
	local dateStr&lt;br /&gt;
	local args    = frame.args&lt;br /&gt;
	if not (args.lang and mw.language.isSupportedLanguage(args.lang)) then &lt;br /&gt;
		args.lang = frame:callParserFunction( &amp;quot;int&amp;quot;, &amp;quot;lang&amp;quot; ) -- get user&#039;s chosen language  &lt;br /&gt;
	end&lt;br /&gt;
	local lang    = args[&#039;lang&#039;]&lt;br /&gt;
	local dateStr = args[&#039;date&#039;] or &#039;&#039;&lt;br /&gt;
	local eraType = string.lower(args[&#039;era&#039;]  or &#039;&#039;)&lt;br /&gt;
&lt;br /&gt;
	dateStr = ISOdate(dateStr, lang, &#039;&#039;, &#039;&#039;, 1)&lt;br /&gt;
	if eraType then &lt;br /&gt;
		eraType = checkAliases(eraType ,&#039;&#039;,&#039;e&#039;)&lt;br /&gt;
		dateStr = translatePhrase(dateStr, &#039;&#039;, eraType, lang, {}) &lt;br /&gt;
	end&lt;br /&gt;
	return dateStr&lt;br /&gt;
end&lt;br /&gt;
	&lt;br /&gt;
function p._complex_date(conj, adj1, date1, units1, era1, adj2, date2, units2, era2, lang, passNr)&lt;br /&gt;
	local Output=&#039;&#039;&lt;br /&gt;
&lt;br /&gt;
    -- process inputs and save date in state array&lt;br /&gt;
	local state  = {} &lt;br /&gt;
	state.conj   = string.lower(conj   or &#039;&#039;)&lt;br /&gt;
	state.adj1   = string.lower(adj1   or &#039;&#039;)&lt;br /&gt;
	state.adj2   = string.lower(adj2   or &#039;&#039;)&lt;br /&gt;
	state.era1   = string.lower(era1   or &#039;&#039;)&lt;br /&gt;
	state.era2   = string.lower(era2   or &#039;&#039;)&lt;br /&gt;
	state.units1 = string.lower(units1 or &#039;&#039;)&lt;br /&gt;
	state.units2 = string.lower(units2 or &#039;&#039;)&lt;br /&gt;
		  &lt;br /&gt;
	-- if date 1 is missing but date 2 is provided than swap them&lt;br /&gt;
	if date1 == &#039;&#039; and date2 ~= &#039;&#039; then&lt;br /&gt;
		date1 = date2&lt;br /&gt;
		date2 = &#039;&#039;&lt;br /&gt;
		state = {adj1 = state.adj2, era1 = state.era2, units1 = state.units2, &lt;br /&gt;
		         adj2 = &#039;&#039;,         era2 = &#039;&#039;,         units2 = &#039;&#039;,  conj=state.conj, num=1}&lt;br /&gt;
	end&lt;br /&gt;
	if     date2 ~= &#039;&#039; then state.nDates = 2 &lt;br /&gt;
	elseif date1 ~= &#039;&#039; then state.nDates = 1 &lt;br /&gt;
	else	                  state.nDates = 0&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	-- reconcile alternative names for text inputs&lt;br /&gt;
	local conj         = checkAliases(state.conj ,&#039;&#039;  ,&#039;j&#039;)&lt;br /&gt;
	state.adj1 ,conj   = checkAliases(state.adj1 ,conj,&#039;a&#039;)&lt;br /&gt;
	state.units1,conj  = checkAliases(state.units1,conj,&#039;p&#039;)&lt;br /&gt;
	state.era1 ,conj   = checkAliases(state.era1 ,conj,&#039;e&#039;)&lt;br /&gt;
	state.special,conj = checkAliases(&#039;&#039;,conj,&#039;c&#039;)&lt;br /&gt;
	state.adj2         = checkAliases(state.adj2 ,&#039;&#039;,&#039;a&#039;)&lt;br /&gt;
	state.units2       = checkAliases(state.units2,&#039;&#039;,&#039;p&#039;)&lt;br /&gt;
	state.era2         = checkAliases(state.era2 ,&#039;&#039;,&#039;e&#039;)&lt;br /&gt;
	state.conj         = conj&lt;br /&gt;
	state.lang         = lang&lt;br /&gt;
	if p.Error~=nil then&lt;br /&gt;
		return nil&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	-- calculate date precision value&lt;br /&gt;
	date1, state.units1, state.precision1 = datePrecision(date1, state.units1)&lt;br /&gt;
	date2, state.units2, state.precision2 = datePrecision(date2, state.units2)&lt;br /&gt;
&lt;br /&gt;
	-- Handle special cases &lt;br /&gt;
	-- Some complex phrases can be created out of simpler ones. Therefore on pass # 1 we try to create &lt;br /&gt;
	-- the phrase using complex phrase and if that is not found than on the second pass we try to build&lt;br /&gt;
	-- the phrase out of the simpler ones&lt;br /&gt;
	if passNr==1 then&lt;br /&gt;
		if state.adj1==&#039;circa&#039; and state.nDates == 2 then&lt;br /&gt;
			state.conj = &#039;circa2&#039;&lt;br /&gt;
			state.adj1 = &#039;&#039;&lt;br /&gt;
			state.adj2 = &#039;&#039;&lt;br /&gt;
		end&lt;br /&gt;
		if state.nDates == 2 and state.adj1==&#039;late&#039; and state.adj2==&#039;early&#039; and state.conj==&#039;and&#039; &lt;br /&gt;
		and state.units1==state.units2 and state.era1==state.era2 then&lt;br /&gt;
			if state.units1==&#039;century&#039; then&lt;br /&gt;
				state.conj=&#039;turn of the century&#039;&lt;br /&gt;
			elseif state.units1==&#039;decade&#039; then&lt;br /&gt;
				state.conj=&#039;turn of the decade&#039;&lt;br /&gt;
			elseif state.units1==&#039;&#039; then&lt;br /&gt;
				state.conj=&#039;turn of the year&#039;&lt;br /&gt;
			end&lt;br /&gt;
			state.adj1 = &#039;&#039;&lt;br /&gt;
			state.adj2 = &#039;&#039;&lt;br /&gt;
			state.units1 = &#039;&#039;&lt;br /&gt;
			state.units2 = &#039;&#039;&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	local errorStr = string.format(&lt;br /&gt;
	 &#039;\n*conj=%s, adj1=%s, era1=%s, unit1=%s, prec1=%i, adj2=%s, era2=%s, unit2=%s, prec2=%i, special=%s&#039;, &lt;br /&gt;
	  state.conj, state.adj1, state.era1, state.units1, state.precision1,&lt;br /&gt;
	  state.adj2, state.era2, state.units2, state.precision2, state.special)  &lt;br /&gt;
	state.adj, state.era, state.units, state.precision = state.adj1, state.era1, state.units1, state.precision1 &lt;br /&gt;
&lt;br /&gt;
	-- call specialized functions&lt;br /&gt;
	local QScode = &#039;&#039;&lt;br /&gt;
	if state.special~=&#039;&#039; then&lt;br /&gt;
		Output = otherPhrases(date1, date2, state.special, state.era1, lang, state)	&lt;br /&gt;
	elseif state.conj~=&#039;&#039; then&lt;br /&gt;
		QScode = twoDateQScode(date1, date2, state)&lt;br /&gt;
		Output = twoDatePhrase(date1, date2, state, lang)&lt;br /&gt;
	elseif state.adj1~=&#039;&#039; or state.era1~=&#039;&#039; or state.units1~=&#039;&#039; then&lt;br /&gt;
		Output = oneDatePhrase(date1, state.adj1, state.era1, state.units1, lang, 1, nil, state)&lt;br /&gt;
		QScode = oneDateQScode(date1, state.adj1, state.era1, state.precision1)&lt;br /&gt;
	elseif date1~=&#039;&#039; then&lt;br /&gt;
		Output = ISOdate(date1, lang, &#039;&#039;, &#039;dtstart&#039;, &#039;100-999&#039;)&lt;br /&gt;
	end&lt;br /&gt;
	if p.Error~=nil then&lt;br /&gt;
		return errorStr&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- if there is any wikicode in the string than execute it&lt;br /&gt;
	if mw.ustring.find(Output, &#039;{&#039;) then&lt;br /&gt;
		Output = mw.getCurrentFrame():preprocess(Output)&lt;br /&gt;
	end&lt;br /&gt;
	if QScode and #QScode&amp;gt;0 then&lt;br /&gt;
		QScode = &#039; &amp;lt;div style=&amp;quot;display: none;&amp;quot;&amp;gt;date QS:P,&#039; .. QScode .. &#039;&amp;lt;/div&amp;gt;&#039;&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	return Output .. QScode&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.complex_date(frame)&lt;br /&gt;
    -- process inputs&lt;br /&gt;
	local dateStr, Error&lt;br /&gt;
	local args   = frame.args&lt;br /&gt;
	if not (args.lang and mw.language.isSupportedLanguage(args.lang)) then &lt;br /&gt;
		args.lang = frame:callParserFunction( &amp;quot;int&amp;quot;, &amp;quot;lang&amp;quot; ) -- get user&#039;s chosen language  &lt;br /&gt;
	end&lt;br /&gt;
	local date1  = args[&#039;date1&#039;] or args[&#039;2&#039;] or args[&#039;date&#039;] or &#039;&#039;&lt;br /&gt;
	local date2  = args[&#039;date2&#039;] or args[&#039;3&#039;] or &#039;&#039;&lt;br /&gt;
	local conj   = args[&#039;conj&#039;]  or args[&#039;1&#039;] or &#039;&#039;&lt;br /&gt;
	local adj1   = args[&#039;adj1&#039;]  or args[&#039;adj&#039;] or &#039;&#039;&lt;br /&gt;
	local adj2   = args[&#039;adj2&#039;] or &#039;&#039;&lt;br /&gt;
	local units1 = args[&#039;precision1&#039;] or args[&#039;precision&#039;] or &#039;&#039;&lt;br /&gt;
	local units2 = args[&#039;precision2&#039;] or args[&#039;precision&#039;] or &#039;&#039;&lt;br /&gt;
	local era1   = args[&#039;era1&#039;] or args[&#039;era&#039;] or &#039;&#039;&lt;br /&gt;
	local era2   = args[&#039;era2&#039;] or args[&#039;era&#039;] or &#039;&#039;&lt;br /&gt;
	local lang   = args[&#039;lang&#039;]&lt;br /&gt;
&lt;br /&gt;
	dateStr = p._complex_date(conj, adj1, date1, units1, era1, adj2, date2, units2, era2, lang, 1)&lt;br /&gt;
	if p.Error~=nil then&lt;br /&gt;
		dateStr = p.Error .. &#039;[[Category:Pages using Complex date template with incorrect parameter]]&#039;&lt;br /&gt;
	end&lt;br /&gt;
	return dateStr&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
return p&lt;/div&gt;</summary>
		<author><name>Aron.hives@edubase.net</name></author>
	</entry>
	<entry>
		<id>https://edubase.wiki/index.php?title=Module:Calendar&amp;diff=27340</id>
		<title>Module:Calendar</title>
		<link rel="alternate" type="text/html" href="https://edubase.wiki/index.php?title=Module:Calendar&amp;diff=27340"/>
		<updated>2018-11-12T22:47:30Z</updated>

		<summary type="html">&lt;p&gt;Aron.hives@edubase.net: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;-- This module renders the calendar seen on [[Portal:Current events]].&lt;br /&gt;
&lt;br /&gt;
local p = {}&lt;br /&gt;
&lt;br /&gt;
local function makeWikilink(link, display)&lt;br /&gt;
	if display then&lt;br /&gt;
		return string.format(&#039;[[%s|%s]]&#039;, link, display)&lt;br /&gt;
	else&lt;br /&gt;
		return string.format(&#039;[[%s]]&#039;, link)&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.main()&lt;br /&gt;
	local dateStuff = p.getDateStuff()&lt;br /&gt;
	local dayStrings = p.makeDayStrings(dateStuff)&lt;br /&gt;
	return p.export(dayStrings, dateStuff)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.getDateStuff()&lt;br /&gt;
	-- Gets date data.&lt;br /&gt;
	local dateStuff = {}&lt;br /&gt;
	local lang = mw.language.getContentLanguage()&lt;br /&gt;
	--Year&lt;br /&gt;
	local year = lang:formatDate(&#039;Y&#039;)&lt;br /&gt;
	year = tonumber(year)&lt;br /&gt;
	dateStuff.year = year&lt;br /&gt;
	-- Month&lt;br /&gt;
	local month = lang:formatDate(&#039;F&#039;)&lt;br /&gt;
	dateStuff.month = month&lt;br /&gt;
	-- Month and year&lt;br /&gt;
	local monthAndYear = lang:formatDate(&#039;F Y&#039;)&lt;br /&gt;
	local firstOfMonth = lang:formatDate(&#039;01-m-Y&#039;)&lt;br /&gt;
	dateStuff.monthAndYear = monthAndYear&lt;br /&gt;
	-- Previous month and year&lt;br /&gt;
	dateStuff.previousMonthAndYear = lang:formatDate(&#039;F Y&#039;, firstOfMonth .. &#039; -1 month&#039;)&lt;br /&gt;
	-- Next month and year&lt;br /&gt;
	dateStuff.nextMonthAndYear = lang:formatDate(&#039;F Y&#039;, firstOfMonth .. &#039; +1 month&#039;)&lt;br /&gt;
	-- Day&lt;br /&gt;
	local day = lang:formatDate(&#039;j&#039;)&lt;br /&gt;
	day = tonumber(day)&lt;br /&gt;
	dateStuff.day = day&lt;br /&gt;
	-- Days in month&lt;br /&gt;
	local daysInMonth = lang:formatDate(&#039;j&#039;, firstOfMonth .. &#039; +1 month -1 day&#039;)&lt;br /&gt;
	daysInMonth = tonumber(daysInMonth)&lt;br /&gt;
	dateStuff.daysInMonth = daysInMonth&lt;br /&gt;
	-- Weekday of the first day of the month&lt;br /&gt;
	local firstWeekday = lang:formatDate(&#039;w&#039;, firstOfMonth) -- Sunday = 0, Saturday = 6&lt;br /&gt;
	firstWeekday = tonumber(firstWeekday)&lt;br /&gt;
	firstWeekday = firstWeekday + 1 -- Make compatible with Lua tables. Sunday = 1, Saturday = 7.&lt;br /&gt;
	dateStuff.firstWeekday = firstWeekday&lt;br /&gt;
	return dateStuff&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.makeDayStrings(dateStuff)&lt;br /&gt;
	local calStrings = {}&lt;br /&gt;
	local currentDay = dateStuff.day&lt;br /&gt;
	local isLinkworthy = p.isLinkworthy&lt;br /&gt;
	local currentMonth = dateStuff.month&lt;br /&gt;
	local currentYear = dateStuff.year&lt;br /&gt;
	local makeDayLink = p.makeDayLink&lt;br /&gt;
	for day = 1, dateStuff.daysInMonth do&lt;br /&gt;
		if isLinkworthy(day, currentDay) then&lt;br /&gt;
			calStrings[#calStrings + 1] = makeDayLink(day, currentMonth, currentYear)&lt;br /&gt;
		else&lt;br /&gt;
			calStrings[#calStrings + 1] = tostring(day)&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	return calStrings&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.isLinkworthy(day, currentDay)&lt;br /&gt;
	-- Returns true if the calendar day should be linked, and false if not.&lt;br /&gt;
	-- Days should be linked if they are the current day or if they are within the six&lt;br /&gt;
	-- preceding days, as that is the number of items on the current events page.&lt;br /&gt;
	if currentDay - 6 &amp;lt;= day and day &amp;lt;= currentDay then&lt;br /&gt;
		return true&lt;br /&gt;
	else&lt;br /&gt;
		return false&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.makeDayLink(day, month, year)&lt;br /&gt;
	return string.format(&amp;quot;&#039;&#039;&#039;[[#%d %s %d|&amp;amp;nbsp;&amp;amp;nbsp;%d&amp;amp;nbsp;&amp;amp;nbsp;]]&#039;&#039;&#039;&amp;quot;, year, month, day, day)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.export(dayStrings, dateStuff)&lt;br /&gt;
	-- Generates the calendar HTML.&lt;br /&gt;
	local monthAndYear = dateStuff.monthAndYear&lt;br /&gt;
	local root = mw.html.create(&#039;table&#039;)&lt;br /&gt;
	root&lt;br /&gt;
		:addClass(&#039;infobox&#039;)&lt;br /&gt;
		:css{&lt;br /&gt;
			display = &#039;table&#039;,&lt;br /&gt;
			width = &#039;100%&#039;,&lt;br /&gt;
			float = &#039;initial&#039;, &lt;br /&gt;
			[&#039;max-width&#039;] = &#039;350px&#039;,&lt;br /&gt;
			margin = &#039;auto !important&#039;,&lt;br /&gt;
			[&#039;text-align&#039;] = &#039;center&#039;,&lt;br /&gt;
			[&#039;background-color&#039;] = &#039;#f5faff&#039;,&lt;br /&gt;
			border = &#039;1px solid #cedff2&#039;&lt;br /&gt;
		}&lt;br /&gt;
		-- Headings&lt;br /&gt;
		:tag(&#039;tr&#039;)&lt;br /&gt;
			:css(&#039;background-color&#039;, &#039;#cedff2&#039;)&lt;br /&gt;
			:tag(&#039;th&#039;)&lt;br /&gt;
				:css{[&#039;text-align&#039;] = &#039;center&#039;}&lt;br /&gt;
				:wikitext(makeWikilink(&#039;Portal:Current events/&#039; .. dateStuff.previousMonthAndYear, &#039;◀&#039;))&lt;br /&gt;
				:done()&lt;br /&gt;
			:tag(&#039;th&#039;)&lt;br /&gt;
				:attr(&#039;colspan&#039;, &#039;5&#039;)&lt;br /&gt;
				:css{[&#039;text-align&#039;] = &#039;center&#039;}&lt;br /&gt;
				:wikitext(makeWikilink(&#039;Portal:Current events/&#039; .. monthAndYear, monthAndYear))&lt;br /&gt;
				:done()&lt;br /&gt;
			:tag(&#039;th&#039;)&lt;br /&gt;
				:css{[&#039;text-align&#039;] = &#039;center&#039;}&lt;br /&gt;
				:wikitext(makeWikilink(&#039;Portal:Current events/&#039; .. dateStuff.nextMonthAndYear, &#039;▶&#039;))&lt;br /&gt;
&lt;br /&gt;
	-- Day of week headings&lt;br /&gt;
	local dayHeadingRow = root:tag(&#039;tr&#039;)&lt;br /&gt;
	local weekdays = {&#039;S&#039;, &#039;M&#039;, &#039;T&#039;, &#039;W&#039;, &#039;T&#039;, &#039;F&#039;, &#039;S&#039;}&lt;br /&gt;
	for i, weekday in ipairs(weekdays) do&lt;br /&gt;
		dayHeadingRow:tag(&#039;th&#039;)&lt;br /&gt;
			:css{[&#039;width&#039;] = &#039;14%&#039;, [&#039;text-align&#039;] = &#039;center&#039;}&lt;br /&gt;
			:wikitext(weekday)&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	-- Days&lt;br /&gt;
	local colspan = dateStuff.firstWeekday - 1&lt;br /&gt;
	local cellCount = 0 -- Tracks the number of day cells.&lt;br /&gt;
	local firstDayRow = root:tag(&#039;tr&#039;)&lt;br /&gt;
	if colspan &amp;gt; 1 then&lt;br /&gt;
		firstDayRow:tag(&#039;td&#039;)&lt;br /&gt;
			:attr(&#039;colspan&#039;, tostring(colspan))&lt;br /&gt;
	elseif colspan == 1 then&lt;br /&gt;
		firstDayRow:tag(&#039;td&#039;)&lt;br /&gt;
	end&lt;br /&gt;
	for i = colspan + 1, 7 do -- Finish the first row&lt;br /&gt;
		cellCount = cellCount + 1&lt;br /&gt;
		firstDayRow:tag(&#039;td&#039;)&lt;br /&gt;
			:css{[&#039;text-align&#039;] = &#039;center&#039;}&lt;br /&gt;
			:wikitext(dayStrings[cellCount])&lt;br /&gt;
	end&lt;br /&gt;
	while cellCount &amp;lt; #dayStrings do -- Second day row onwards&lt;br /&gt;
		local otherDayRow = root:tag(&#039;tr&#039;)&lt;br /&gt;
		for i = 1, 7 do&lt;br /&gt;
			cellCount = cellCount + 1&lt;br /&gt;
			local dayString = dayStrings[cellCount]&lt;br /&gt;
			if not dayString then&lt;br /&gt;
				dayString = &amp;quot; &amp;quot;&lt;br /&gt;
			end&lt;br /&gt;
			otherDayRow:tag(&#039;td&#039;)&lt;br /&gt;
				:css{[&#039;text-align&#039;] = &#039;center&#039;}&lt;br /&gt;
				:wikitext(dayString)&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- Footer&lt;br /&gt;
	root:tag(&#039;tr&#039;)&lt;br /&gt;
		:tag(&#039;td&#039;)&lt;br /&gt;
			:attr(&#039;colspan&#039;, &#039;7&#039;)&lt;br /&gt;
			:css{[&#039;padding-top&#039;] = &#039;3px&#039;, [&#039;padding-bottom&#039;] = &#039;5px&#039;, [&#039;font-size&#039;] = &#039;78%&#039;, [&#039;text-align&#039;] = &#039;right&#039;}&lt;br /&gt;
			:wikitext(&#039;&amp;amp;nbsp;&amp;amp;nbsp; &#039; .. makeWikilink(&#039;Portal:Current events/&#039; .. monthAndYear, &#039;More &#039; .. monthAndYear .. &#039; events... &amp;amp;nbsp;&amp;amp;nbsp;&#039;))&lt;br /&gt;
	&lt;br /&gt;
	return tostring(root)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
return p&lt;/div&gt;</summary>
		<author><name>Aron.hives@edubase.net</name></author>
	</entry>
	<entry>
		<id>https://edubase.wiki/index.php?title=Template:Wikidata_infoboxes&amp;diff=27338</id>
		<title>Template:Wikidata infoboxes</title>
		<link rel="alternate" type="text/html" href="https://edubase.wiki/index.php?title=Template:Wikidata_infoboxes&amp;diff=27338"/>
		<updated>2018-11-12T22:47:29Z</updated>

		<summary type="html">&lt;p&gt;Aron.hives@edubase.net: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;{{Navbox&lt;br /&gt;
| name       = Wikidata infoboxes&lt;br /&gt;
| title      = Infoboxes using [[Module:WikidataIB]]&lt;br /&gt;
| listclass  = hlist&lt;br /&gt;
| state      = {{{state|}}}&lt;br /&gt;
| group1     = Templates&lt;br /&gt;
| list1      =&lt;br /&gt;
* {{t|Infobox character/Wikidata}}&lt;br /&gt;
* {{t|Infobox deity/Wikidata}}&lt;br /&gt;
* {{t|Infobox historic site/Wikidata}}&lt;br /&gt;
* {{t|Infobox journal/wikidata}}&lt;br /&gt;
* {{tl|Ordination}}&lt;br /&gt;
* {{t|Infobox person/Wikidata}}&lt;br /&gt;
* {{t|Infobox product}}&lt;br /&gt;
* {{t|Infobox recurring event/Wikidata}}&lt;br /&gt;
* {{t|Infobox religious biography/Wikidata}}&lt;br /&gt;
* {{t|Infobox royalty/Wikidata}}&lt;br /&gt;
* {{t|Infobox organization/Wikidata}}&lt;br /&gt;
* {{t|Infobox scientist/Wikidata}}&lt;br /&gt;
* {{t|Infobox telescope}}&lt;br /&gt;
}}&lt;/div&gt;</summary>
		<author><name>Aron.hives@edubase.net</name></author>
	</entry>
	<entry>
		<id>https://edubase.wiki/index.php?title=Template:Wikidata_entity_link&amp;diff=27336</id>
		<title>Template:Wikidata entity link</title>
		<link rel="alternate" type="text/html" href="https://edubase.wiki/index.php?title=Template:Wikidata_entity_link&amp;diff=27336"/>
		<updated>2018-11-12T22:47:29Z</updated>

		<summary type="html">&lt;p&gt;Aron.hives@edubase.net: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;[{{#if:{{{1|}}}|{{#switch:{{uc:{{padleft:|1|{{#if:1|{{{1|}}}}}}}}}&lt;br /&gt;
|Q|P={{#invoke:Wikibase|wdurl|{{{1}}}}} {{#invoke:Wikibase|label|{{{1}}}}} &amp;lt;small&amp;gt;({{#if:1|{{{1|}}}}})&amp;lt;/small&amp;gt;&lt;br /&gt;
|#default={{#invoke:Wikibase|wdurl|Q{{#if:1|{{{1|}}}}}}} {{#invoke:Wikibase|label|Q{{#if:1|{{{1|}}}}}}} &amp;lt;small&amp;gt;(Q{{#if:1|{{{1|}}}}})&amp;lt;/small&amp;gt;&lt;br /&gt;
}}|{{#invoke:Wikibase|wdurl}} {{#invoke:Wikibase|label}} &amp;lt;small&amp;gt;({{#invoke:Wikibase|id}})&amp;lt;/small&amp;gt;}}]&amp;lt;noinclude&amp;gt;{{documentation}}&amp;lt;/noinclude&amp;gt;&lt;/div&gt;</summary>
		<author><name>Aron.hives@edubase.net</name></author>
	</entry>
	<entry>
		<id>https://edubase.wiki/index.php?title=Template:Q&amp;diff=27334</id>
		<title>Template:Q</title>
		<link rel="alternate" type="text/html" href="https://edubase.wiki/index.php?title=Template:Q&amp;diff=27334"/>
		<updated>2018-11-12T22:47:29Z</updated>

		<summary type="html">&lt;p&gt;Aron.hives@edubase.net: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;#REDIRECT [[Template:Wikidata entity link]]&lt;br /&gt;
{{R from move}}&lt;br /&gt;
[[Category:Wikidata templates]]&lt;/div&gt;</summary>
		<author><name>Aron.hives@edubase.net</name></author>
	</entry>
	<entry>
		<id>https://edubase.wiki/index.php?title=Dystopian_novel&amp;diff=27332</id>
		<title>Dystopian novel</title>
		<link rel="alternate" type="text/html" href="https://edubase.wiki/index.php?title=Dystopian_novel&amp;diff=27332"/>
		<updated>2018-11-12T22:47:29Z</updated>

		<summary type="html">&lt;p&gt;Aron.hives@edubase.net: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;#REDIRECT [[Utopian and dystopian fiction#Dystopian_fiction]]&lt;/div&gt;</summary>
		<author><name>Aron.hives@edubase.net</name></author>
	</entry>
	<entry>
		<id>https://edubase.wiki/index.php?title=Module:Section_link&amp;diff=27330</id>
		<title>Module:Section link</title>
		<link rel="alternate" type="text/html" href="https://edubase.wiki/index.php?title=Module:Section_link&amp;diff=27330"/>
		<updated>2018-11-12T22:47:29Z</updated>

		<summary type="html">&lt;p&gt;Aron.hives@edubase.net: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;-- This module implements {{section link}}.&lt;br /&gt;
&lt;br /&gt;
local checkType = require(&#039;libraryUtil&#039;).checkType&lt;br /&gt;
&lt;br /&gt;
local p = {}&lt;br /&gt;
&lt;br /&gt;
local function makeSectionLink(page, section, display)&lt;br /&gt;
	display = display or section&lt;br /&gt;
	page = page or &#039;&#039;&lt;br /&gt;
	return string.format(&#039;[[%s#%s|%s]]&#039;, page, section, display)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function normalizeTitle(title)&lt;br /&gt;
	title = mw.ustring.gsub(mw.ustring.gsub(title,&amp;quot;&#039;&amp;quot;,&amp;quot;&amp;quot;),&#039;&amp;quot;&#039;,&#039;&#039;)&lt;br /&gt;
	return mw.title.new(mw.ustring.gsub(title,&amp;quot;%b&amp;lt;&amp;gt;&amp;quot;,&amp;quot;&amp;quot;)).prefixedText&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p._main(page, sections, options, title)&lt;br /&gt;
	-- Validate input.&lt;br /&gt;
	checkType(&#039;_main&#039;, 1, page, &#039;string&#039;, true)&lt;br /&gt;
	checkType(&#039;_main&#039;, 3, options, &#039;table&#039;, true)&lt;br /&gt;
	if sections == nil then&lt;br /&gt;
		sections = {}&lt;br /&gt;
	elseif type(sections) == &#039;string&#039; then&lt;br /&gt;
		sections = {sections}&lt;br /&gt;
	elseif type(sections) ~= &#039;table&#039; then&lt;br /&gt;
		error(string.format(&lt;br /&gt;
			&amp;quot;type error in argument #2 to &#039;_main&#039; &amp;quot; ..&lt;br /&gt;
			&amp;quot;(string, table or nil expected, got %s)&amp;quot;,&lt;br /&gt;
			type(sections)&lt;br /&gt;
		), 2)&lt;br /&gt;
	end&lt;br /&gt;
	options = options or {}&lt;br /&gt;
	title = title or mw.title.getCurrentTitle()&lt;br /&gt;
&lt;br /&gt;
	-- Deal with blank page names elegantly&lt;br /&gt;
	if page and not page:find(&#039;%S&#039;) then&lt;br /&gt;
		page = nil&lt;br /&gt;
		options.nopage = true&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- Make the link(s).&lt;br /&gt;
	local isShowingPage = not options.nopage&lt;br /&gt;
	if #sections &amp;lt;= 1 then&lt;br /&gt;
		local linkPage = page or &#039;&#039;&lt;br /&gt;
		local section = sections[1] or &#039;Notes&#039;&lt;br /&gt;
		local display = &#039;§&amp;amp;nbsp;&#039; .. section&lt;br /&gt;
		if isShowingPage then&lt;br /&gt;
			page = page or title.prefixedText&lt;br /&gt;
			if options.display and options.display ~= &#039;&#039; then&lt;br /&gt;
				if normalizeTitle(options.display) == normalizeTitle(page) then&lt;br /&gt;
					display = options.display .. &#039; &#039; .. display&lt;br /&gt;
				else&lt;br /&gt;
					error(string.format(&lt;br /&gt;
						&#039;Display title &amp;quot;%s&amp;quot; was ignored since it is &#039; ..&lt;br /&gt;
						&amp;quot;not equivalent to the page&#039;s actual title&amp;quot;,&lt;br /&gt;
						options.display&lt;br /&gt;
					), 0)&lt;br /&gt;
				end&lt;br /&gt;
			else&lt;br /&gt;
				display = page .. &#039; &#039; .. display&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
		return makeSectionLink(linkPage, section, display)&lt;br /&gt;
	else&lt;br /&gt;
		-- Multiple sections. First, make a list of the links to display.&lt;br /&gt;
		local ret = {}&lt;br /&gt;
		for i, section in ipairs(sections) do&lt;br /&gt;
			ret[i] = makeSectionLink(page, section)&lt;br /&gt;
		end&lt;br /&gt;
&lt;br /&gt;
		-- Assemble the list of links into a string with mw.text.listToText.&lt;br /&gt;
		-- We use the default separator for mw.text.listToText, but a custom&lt;br /&gt;
		-- conjunction. There is also a special case conjunction if we only&lt;br /&gt;
		-- have two links.&lt;br /&gt;
		local conjunction&lt;br /&gt;
		if #sections == 2 then&lt;br /&gt;
			conjunction = &#039;&amp;amp;#8203; and &#039;&lt;br /&gt;
		else&lt;br /&gt;
			conjunction = &#039;, and &#039;&lt;br /&gt;
		end&lt;br /&gt;
		ret = mw.text.listToText(ret, nil, conjunction)&lt;br /&gt;
&lt;br /&gt;
		-- Add the intro text.&lt;br /&gt;
		local intro = &#039;§§&amp;amp;nbsp;&#039;&lt;br /&gt;
		if isShowingPage then&lt;br /&gt;
			intro = (page or title.prefixedText) .. &#039; &#039; .. intro&lt;br /&gt;
		end&lt;br /&gt;
		ret = intro .. ret&lt;br /&gt;
&lt;br /&gt;
		return ret&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.main(frame)&lt;br /&gt;
	local args = require(&#039;Module:Arguments&#039;).getArgs(frame, {&lt;br /&gt;
		wrappers = &#039;Template:Section link&#039;,&lt;br /&gt;
		valueFunc = function (key, value)&lt;br /&gt;
			value = value:match(&#039;^%s*(.-)%s*$&#039;) -- Trim whitespace&lt;br /&gt;
			-- Allow blank first parameters, as the wikitext template does this.&lt;br /&gt;
			if value ~= &#039;&#039; or key == 1 then&lt;br /&gt;
				return value&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
	})&lt;br /&gt;
&lt;br /&gt;
	-- Sort the arguments.&lt;br /&gt;
	local page&lt;br /&gt;
	local sections, options = {}, {}&lt;br /&gt;
	for k, v in pairs(args) do&lt;br /&gt;
		if k == 1 then&lt;br /&gt;
			-- Doing this in the loop because of a bug in [[Module:Arguments]]&lt;br /&gt;
			-- when using pairs with deleted arguments.&lt;br /&gt;
			page = mw.text.decode(v, decodeNamedEntities)&lt;br /&gt;
		elseif type(k) == &#039;number&#039; then&lt;br /&gt;
			sections[k] = v&lt;br /&gt;
		else&lt;br /&gt;
			options[k] = v&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	-- Extract section from page, if present&lt;br /&gt;
	if page then&lt;br /&gt;
		local p, s = page:match(&#039;^(.-)#(.*)$&#039;)&lt;br /&gt;
		if p then page, sections[1] = p, s end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- Compress the sections array.&lt;br /&gt;
	local function compressArray(t)&lt;br /&gt;
		local nums, ret = {}, {}&lt;br /&gt;
		for num in pairs(t) do&lt;br /&gt;
			nums[#nums + 1] = num&lt;br /&gt;
		end&lt;br /&gt;
		table.sort(nums)&lt;br /&gt;
		for i, num in ipairs(nums) do&lt;br /&gt;
			ret[i] = t[num]&lt;br /&gt;
		end&lt;br /&gt;
		return ret&lt;br /&gt;
	end&lt;br /&gt;
	sections = compressArray(sections)&lt;br /&gt;
&lt;br /&gt;
	return p._main(page, sections, options)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
return p&lt;/div&gt;</summary>
		<author><name>Aron.hives@edubase.net</name></author>
	</entry>
	<entry>
		<id>https://edubase.wiki/index.php?title=Module:InfoboxImage/doc&amp;diff=27328</id>
		<title>Module:InfoboxImage/doc</title>
		<link rel="alternate" type="text/html" href="https://edubase.wiki/index.php?title=Module:InfoboxImage/doc&amp;diff=27328"/>
		<updated>2018-11-12T22:47:28Z</updated>

		<summary type="html">&lt;p&gt;Aron.hives@edubase.net: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;{{High-risk|2,860,000}}&lt;br /&gt;
{{Module rating|protected}}&lt;br /&gt;
&lt;br /&gt;
==Overview==&lt;br /&gt;
This module is used within infoboxes to process the image parameters and tidy up the formatting of the result.&lt;br /&gt;
&lt;br /&gt;
==Parameters==&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
! Parameter&lt;br /&gt;
! Description&lt;br /&gt;
|-&lt;br /&gt;
| image&lt;br /&gt;
| Required. The main parameter that should be passed over which contains the image info.&lt;br /&gt;
|-&lt;br /&gt;
| size&lt;br /&gt;
| Size to display image.&lt;br /&gt;
|-&lt;br /&gt;
| maxsize&lt;br /&gt;
| Maximum size to display image. Note: If no size or sizedefault params specified then image will be shown at maxsize.&lt;br /&gt;
|-&lt;br /&gt;
| sizedefault&lt;br /&gt;
| The size to use for the image if no size param is specified. Defaults to [[Wikipedia:Autosizing images|frameless]].&lt;br /&gt;
|-&lt;br /&gt;
| alt&lt;br /&gt;
| Alt text for the image.&lt;br /&gt;
|-&lt;br /&gt;
| title&lt;br /&gt;
| Title text for image (mouseover text). If blank then alt text is used.&lt;br /&gt;
|-&lt;br /&gt;
| border&lt;br /&gt;
| If yes, then a border is added.&lt;br /&gt;
|-&lt;br /&gt;
| page&lt;br /&gt;
| The page number to be displayed when using a multi-page image&lt;br /&gt;
|-&lt;br /&gt;
| upright&lt;br /&gt;
| If upright=yes, adds &amp;quot;upright&amp;quot; which displays image at 75% of default image size (which is 220px if not changed at [[Special:Preferences]]). If a value, adds &amp;quot;upright=&#039;&#039;value&#039;&#039;&amp;quot; to image, where values less than 1 scale the image down (0.9 = 90%) and values greater than 1 scale the image up (1.15 = 115%).&lt;br /&gt;
|-&lt;br /&gt;
| center&lt;br /&gt;
| If yes, then the image is centered.&lt;br /&gt;
|-&lt;br /&gt;
| thumbtime&lt;br /&gt;
| thumbtime param, used for video clips.&lt;br /&gt;
|-&lt;br /&gt;
| suppressplaceholder&lt;br /&gt;
| If no, then will not suppress certain placeholder images. See {{section link||Placeholder images which can be suppressed}}.&lt;br /&gt;
|-&lt;br /&gt;
| link&lt;br /&gt;
| Page to go to when clicking on the image.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Note: If you specify the maxsize or sizedefault params, then you should include the px after the number.&lt;br /&gt;
&lt;br /&gt;
{{Use dmy dates|date=July 2016}}&lt;br /&gt;
&lt;br /&gt;
==Parameters displayed in image syntax==&lt;br /&gt;
All parameters:&lt;br /&gt;
:&amp;lt;pre style=&amp;quot;overflow:auto;&amp;quot;&amp;gt;{{#invoke:InfoboxImage | InfoboxImage | image={{{image}}} | size={{{size}}} | upright={{{upright}}} | alt={{{alt}}} | title={{{title}}} | thumbtime={{{thumbtime}}} | link={{{link}}} | border=yes | center=yes | page={{{page}}} }}&amp;lt;/pre&amp;gt;&lt;br /&gt;
:&amp;lt;code&amp;gt;{{#invoke:InfoboxImage | InfoboxImage | image={{{image}}} | size={{{size}}} | upright={{{upright}}} | alt={{{alt}}} | title={{{title}}} | thumbtime={{{thumbtime}}} | link={{{link}}} | border=yes | center=yes | page={{{page}}} }}&amp;lt;/code&amp;gt;&lt;br /&gt;
&lt;br /&gt;
When &amp;quot;size&amp;quot; and &amp;quot;maxsize&amp;quot; are defined, the smaller of the two is used (if &amp;quot;px&amp;quot; is omitted it will be added by the module):&lt;br /&gt;
:&amp;lt;pre style=&amp;quot;overflow:auto;&amp;quot;&amp;gt;{{#invoke:InfoboxImage | InfoboxImage | image={{{image}}} | size=300px | maxsize=250px }}&amp;lt;/pre&amp;gt;&lt;br /&gt;
:&amp;lt;code&amp;gt;{{#invoke:InfoboxImage | InfoboxImage | image={{{image}}} | size=300px | maxsize=250px }}&amp;lt;/code&amp;gt;&lt;br /&gt;
&lt;br /&gt;
When &amp;quot;size&amp;quot; is not defined, &amp;quot;sizedefault&amp;quot; is used, even if larger than &amp;quot;maxsize&amp;quot; (in actual use &amp;quot;px&amp;quot; is required after the number; omitted here to show it is not added by the module):&lt;br /&gt;
:&amp;lt;pre style=&amp;quot;overflow:auto;&amp;quot;&amp;gt;{{#invoke:InfoboxImage | InfoboxImage | image={{{image}}} | sizedefault=250px | maxsize=200px }}&amp;lt;/pre&amp;gt;&lt;br /&gt;
:&amp;lt;code&amp;gt;{{#invoke:InfoboxImage | InfoboxImage | image={{{image}}} | sizedefault=250px | maxsize=200px }}&amp;lt;/code&amp;gt;&lt;br /&gt;
&lt;br /&gt;
When &amp;quot;size&amp;quot; and &amp;quot;sizedefault&amp;quot; are not defined, &amp;quot;maxsize&amp;quot; is used (in actual use &amp;quot;px&amp;quot; is required after the number; omitted here to show it is not added by the module):&lt;br /&gt;
:&amp;lt;pre style=&amp;quot;overflow:auto;&amp;quot;&amp;gt;{{#invoke:InfoboxImage | InfoboxImage | image={{{image}}} | maxsize=250px }}&amp;lt;/pre&amp;gt;&lt;br /&gt;
:&amp;lt;code&amp;gt;{{#invoke:InfoboxImage | InfoboxImage | image={{{image}}} | maxsize=250px }}&amp;lt;/code&amp;gt;&lt;br /&gt;
&lt;br /&gt;
When &amp;quot;size&amp;quot;, &amp;quot;sizedefault&amp;quot;, and &amp;quot;maxsize&amp;quot; are not defined, &amp;quot;frameless&amp;quot; is added, which displays the image at the default thumbnail size (220px, but logged in users can change this at [[Special:Preferences]]) and is required if using &amp;quot;upright&amp;quot; to scale the default size:&lt;br /&gt;
:&amp;lt;pre style=&amp;quot;overflow:auto;&amp;quot;&amp;gt;{{#invoke:InfoboxImage | InfoboxImage | image={{{image}}} }}&amp;lt;/pre&amp;gt;&lt;br /&gt;
:&amp;lt;code&amp;gt;{{#invoke:InfoboxImage | InfoboxImage | image={{{image}}} }}&amp;lt;/code&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Use of &amp;quot;upright&amp;quot; without a number value, which displays the image at approximately 75% of the user&#039;s default size (multiplied by 0.75 then rounded to nearest 10):&lt;br /&gt;
:&amp;lt;pre style=&amp;quot;overflow:auto;&amp;quot;&amp;gt;{{#invoke:InfoboxImage | InfoboxImage | image={{{image}}} | upright = yes }}&amp;lt;/pre&amp;gt;&lt;br /&gt;
:&amp;lt;code&amp;gt;{{#invoke:InfoboxImage | InfoboxImage | image={{{image}}} | upright = yes }}&amp;lt;/code&amp;gt;&lt;br /&gt;
&lt;br /&gt;
When &amp;quot;alt&amp;quot; is used without &amp;quot;title&amp;quot;, the alt text is also used as the title:&lt;br /&gt;
:&amp;lt;pre style=&amp;quot;overflow:auto;&amp;quot;&amp;gt;{{#invoke:InfoboxImage | InfoboxImage | image={{{image}}} | alt = Alt text }}&amp;lt;/pre&amp;gt;&lt;br /&gt;
:&amp;lt;code&amp;gt;{{#invoke:InfoboxImage | InfoboxImage | image={{{image}}} | alt = Alt text }}&amp;lt;/code&amp;gt;&lt;br /&gt;
&lt;br /&gt;
For more information, see [[Wikipedia:Extended image syntax]].&lt;br /&gt;
&lt;br /&gt;
==Sample usage==&lt;br /&gt;
&amp;lt;pre style=&amp;quot;overflow:auto;&amp;quot;&amp;gt;&lt;br /&gt;
|image = {{#invoke:InfoboxImage|InfoboxImage|image={{{image|}}}|upright={{{image_upright|1}}}|alt={{{alt|}}}}}&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==Examples==&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
| &amp;lt;nowiki&amp;gt;{{#invoke:InfoboxImage|InfoboxImage}}&amp;lt;/nowiki&amp;gt;&lt;br /&gt;
| {{#invoke:InfoboxImage|InfoboxImage}}&lt;br /&gt;
|-&lt;br /&gt;
| &amp;lt;nowiki&amp;gt;{{#invoke:InfoboxImage|InfoboxImage|image=}}&amp;lt;/nowiki&amp;gt;&lt;br /&gt;
| {{#invoke:InfoboxImage|InfoboxImage|image=}}&lt;br /&gt;
|-&lt;br /&gt;
|&lt;br /&gt;
&amp;lt;nowiki&amp;gt;{{#invoke:InfoboxImage|InfoboxImage|image=Abbey Rd Studios.jpg}}&amp;lt;/nowiki&amp;gt;&amp;lt;br /&amp;gt;&lt;br /&gt;
&amp;lt;nowiki&amp;gt;{{#invoke:InfoboxImage|InfoboxImage|image=File:Abbey Rd Studios.jpg}}&amp;lt;/nowiki&amp;gt;&amp;lt;br /&amp;gt;&lt;br /&gt;
&amp;lt;nowiki&amp;gt;{{#invoke:InfoboxImage|InfoboxImage|image=Image:Abbey Rd Studios.jpg}}&amp;lt;/nowiki&amp;gt;&lt;br /&gt;
| {{#invoke:InfoboxImage|InfoboxImage|image=Abbey Rd Studios.jpg}}&lt;br /&gt;
|-&lt;br /&gt;
|&lt;br /&gt;
&amp;lt;nowiki&amp;gt;{{#invoke:InfoboxImage|InfoboxImage|image=Abbey Rd Studios.jpg|upright=yes}}&amp;lt;/nowiki&amp;gt;&amp;lt;br /&amp;gt;&lt;br /&gt;
| {{#invoke:InfoboxImage|InfoboxImage|image=Abbey Rd Studios.jpg|upright=yes}}&lt;br /&gt;
|-&lt;br /&gt;
|&lt;br /&gt;
&amp;lt;nowiki&amp;gt;{{#invoke:InfoboxImage|InfoboxImage|image=Abbey Rd Studios.jpg|upright=1.2}}&amp;lt;/nowiki&amp;gt;&amp;lt;br /&amp;gt;&lt;br /&gt;
| {{#invoke:InfoboxImage|InfoboxImage|image=Abbey Rd Studios.jpg|upright=1.2}}&lt;br /&gt;
|-&lt;br /&gt;
|&lt;br /&gt;
&amp;lt;nowiki&amp;gt;{{#invoke:InfoboxImage|InfoboxImage|image=Abbey Rd Studios.jpg|size=100px}}&amp;lt;/nowiki&amp;gt;&amp;lt;br /&amp;gt;&lt;br /&gt;
&amp;lt;nowiki&amp;gt;{{#invoke:InfoboxImage|InfoboxImage|image=Abbey Rd Studios.jpg|size=100}}&amp;lt;/nowiki&amp;gt;&lt;br /&gt;
| {{#invoke:InfoboxImage|InfoboxImage|image=Abbey Rd Studios.jpg|size=100px}}&lt;br /&gt;
|-&lt;br /&gt;
| &amp;lt;nowiki&amp;gt;{{#invoke:InfoboxImage|InfoboxImage|image=[[Image:Abbey Rd Studios.jpg|200px]]}}&amp;lt;/nowiki&amp;gt;&lt;br /&gt;
| {{#invoke:InfoboxImage|InfoboxImage|image=[[Image:Abbey Rd Studios.jpg|200px]]}}&lt;br /&gt;
|-&lt;br /&gt;
| &amp;lt;nowiki&amp;gt;{{#invoke:InfoboxImage|InfoboxImage|image=[[Image:Abbey Rd Studios.jpg|200px]]|title=Abbey Road!}}&amp;lt;/nowiki&amp;gt;&lt;br /&gt;
| {{#invoke:InfoboxImage|InfoboxImage|image=[[Image:Abbey Rd Studios.jpg|200px]]|title=Abbey Road!}}&lt;br /&gt;
|-&lt;br /&gt;
| &amp;lt;nowiki&amp;gt;{{#invoke:InfoboxImage|InfoboxImage|image=Abbey Rd Studios.jpg|sizedefault=250px|alt=The front stairs and door of Abbey Road Studios}}&amp;lt;/nowiki&amp;gt;&lt;br /&gt;
| {{#invoke:InfoboxImage|InfoboxImage|image=Abbey Rd Studios.jpg|sizedefault=250px|alt=The front stairs and door of Abbey Road Studios}}&lt;br /&gt;
|-&lt;br /&gt;
| &amp;lt;nowiki&amp;gt;{{#invoke:InfoboxImage|InfoboxImage|image=Abbey Rd Studios.jpg|sizedefault=250|alt=The front stairs and door of Abbey Road Studios}}&amp;lt;/nowiki&amp;gt;&lt;br /&gt;
| {{#invoke:InfoboxImage|InfoboxImage|image=Abbey Rd Studios.jpg|sizedefault=250|alt=The front stairs and door of Abbey Road Studios}}&lt;br /&gt;
|-&lt;br /&gt;
| &amp;lt;nowiki&amp;gt;{{#invoke:InfoboxImage|InfoboxImage|image=Abbey Rd Studios.jpg|sizedefault=250px|alt=The front stairs and door of Abbey Road Studios|title=Exterior, front view of Abbey Road studios}}&amp;lt;/nowiki&amp;gt;&lt;br /&gt;
| {{#invoke:InfoboxImage|InfoboxImage|image=Abbey Rd Studios.jpg|sizedefault=250px|alt=The front stairs and door of Abbey Road Studios|title=Exterior, front view of Abbey Road studios}}&lt;br /&gt;
|-&lt;br /&gt;
| &amp;lt;nowiki&amp;gt;{{#invoke:InfoboxImage|InfoboxImage|image=Abbey Rd Studios.jpg|alt=The front stairs and door of Abbey Road Studios}}&amp;lt;/nowiki&amp;gt;&lt;br /&gt;
| {{#invoke:InfoboxImage|InfoboxImage|image=Abbey Rd Studios.jpg|alt=The front stairs and door of Abbey Road Studios}}&lt;br /&gt;
|-&lt;br /&gt;
| &amp;lt;nowiki&amp;gt;{{#invoke:InfoboxImage|InfoboxImage|image=Abbey Rd Studios.jpg|size=100px|alt=The front stairs and door of Abbey Road Studios}}&amp;lt;/nowiki&amp;gt;&lt;br /&gt;
| {{#invoke:InfoboxImage|InfoboxImage|image=Abbey Rd Studios.jpg|size=100px|alt=The front stairs and door of Abbey Road Studios}}&lt;br /&gt;
|-&lt;br /&gt;
| &amp;lt;nowiki&amp;gt;{{#invoke:InfoboxImage|InfoboxImage|image=Bilbao.svg|size=100|border=yes}}&amp;lt;/nowiki&amp;gt;&lt;br /&gt;
| {{#invoke:InfoboxImage|InfoboxImage|image=Bilbao.svg|size=200|border=yes}}&lt;br /&gt;
|-&lt;br /&gt;
| &amp;lt;nowiki&amp;gt;{{#invoke:InfoboxImage|InfoboxImage|image=Image is needed male.svg}}&amp;lt;/nowiki&amp;gt;&lt;br /&gt;
| {{#invoke:InfoboxImage|InfoboxImage|image=Image is needed male.svg}}&lt;br /&gt;
|-&lt;br /&gt;
| &amp;lt;nowiki&amp;gt;{{#invoke:InfoboxImage|InfoboxImage|image=Image is needed male.svg|suppressplaceholder=no}}&amp;lt;/nowiki&amp;gt;&lt;br /&gt;
| {{#invoke:InfoboxImage|InfoboxImage|image=Image is needed male.svg|suppressplaceholder=no}}&lt;br /&gt;
|-&lt;br /&gt;
| &amp;lt;nowiki&amp;gt;{{#invoke:InfoboxImage|InfoboxImage|image=[[File:Image is needed male.svg|200px]]}}&amp;lt;/nowiki&amp;gt;&lt;br /&gt;
| {{#invoke:InfoboxImage|InfoboxImage|image=[[File:Image is needed male.svg|200px]]}}&lt;br /&gt;
|-&lt;br /&gt;
| &amp;lt;nowiki&amp;gt;{{#invoke:InfoboxImage|InfoboxImage|image=[[File:Image is needed male.svg|200px]]|suppressplaceholder=no}}&amp;lt;/nowiki&amp;gt;&lt;br /&gt;
| {{#invoke:InfoboxImage|InfoboxImage|image=[[File:Image is needed male.svg|200px]]|suppressplaceholder=no}}&lt;br /&gt;
|-&lt;br /&gt;
| &amp;lt;nowiki&amp;gt;{{#invoke:InfoboxImage|InfoboxImage|image=Abbey Rd Studios.jpg|size=50px|maxsize=100px}}&amp;lt;/nowiki&amp;gt;&lt;br /&gt;
| {{#invoke:InfoboxImage|InfoboxImage|image=Abbey Rd Studios.jpg|size=50px|maxsize=100px}}&lt;br /&gt;
|-&lt;br /&gt;
| &amp;lt;nowiki&amp;gt;{{#invoke:InfoboxImage|InfoboxImage|image=Abbey Rd Studios.jpg|size=200px|maxsize=100px}}&amp;lt;/nowiki&amp;gt;&lt;br /&gt;
| {{#invoke:InfoboxImage|InfoboxImage|image=Abbey Rd Studios.jpg|size=200px|maxsize=100px}}&lt;br /&gt;
|-&lt;br /&gt;
| &amp;lt;nowiki&amp;gt;{{#invoke:InfoboxImage|InfoboxImage|image=[[File:Abbey Rd Studios.jpg|200px]]|maxsize=100px}}&amp;lt;/nowiki&amp;gt;&lt;br /&gt;
| {{#invoke:InfoboxImage|InfoboxImage|image=[[File:Abbey Rd Studios.jpg|200px]]|maxsize=100px}}&lt;br /&gt;
|-&lt;br /&gt;
| &amp;lt;nowiki&amp;gt;{{#invoke:InfoboxImage|InfoboxImage|image=Abbey Rd Studios.jpg|maxsize=100px|center=yes}}&amp;lt;/nowiki&amp;gt;&lt;br /&gt;
| {{#invoke:InfoboxImage|InfoboxImage|image=Abbey Rd Studios.jpg|maxsize=100px|center=yes}}&lt;br /&gt;
&lt;br /&gt;
|-&lt;br /&gt;
| &amp;lt;nowiki&amp;gt;{{#invoke:InfoboxImage|InfoboxImage|image=no such image|maxsize=100px|center=yes}}&amp;lt;/nowiki&amp;gt;&amp;lt;!-- this issue sh&#039;d be fixed somewhow--&amp;gt;&lt;br /&gt;
| {{#invoke:InfoboxImage|InfoboxImage|image=no such image|maxsize=100px|center=yes}}&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== Placeholder images which can be suppressed ==&lt;br /&gt;
{|&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |&lt;br /&gt;
* [[:File:Blue - replace this image female.svg]]&lt;br /&gt;
* [[:File:Blue - replace this image male.svg]]&lt;br /&gt;
* [[:File:Female no free image yet.png]]&lt;br /&gt;
* [[:File:Male no free image yet.png]]&lt;br /&gt;
* [[:File:Flag of None (square).svg]]&lt;br /&gt;
* [[:File:Flag of None.svg]]&lt;br /&gt;
* [[:File:Flag of.svg]]&lt;br /&gt;
* [[:File:Green - replace this image female.svg]]&lt;br /&gt;
* [[:File:Green - replace this image male.svg]]&lt;br /&gt;
* [[:File:Image is needed female.svg]]&lt;br /&gt;
* [[:File:Image is needed male.svg]]&lt;br /&gt;
* [[:File:Location map of None.svg]]&lt;br /&gt;
* [[:File:Male no free image yet.png]]&lt;br /&gt;
* [[:File:Missing flag.png]]&lt;br /&gt;
* [[:File:No flag.svg]]&lt;br /&gt;
* [[:File:No free portrait.svg]]&lt;br /&gt;
* [[:File:No portrait (female).svg]]&lt;br /&gt;
* [[:File:No portrait (male).svg]]&lt;br /&gt;
* [[:File:Red - replace this image female.svg]]&lt;br /&gt;
* [[:File:Red - replace this image male.svg]]&lt;br /&gt;
* [[:File:Replace this image female (blue).svg]]&lt;br /&gt;
* [[:File:Replace this image female.svg]]&lt;br /&gt;
* [[:File:Replace this image male (blue).svg]]&lt;br /&gt;
* [[:File:Replace this image male.svg]]&lt;br /&gt;
* [[:File:Silver - replace this image female.svg]]&lt;br /&gt;
* [[:File:Silver - replace this image male.svg]]&lt;br /&gt;
* [[:File:Replace this image.svg]]&lt;br /&gt;
* [[:File:Cricket no pic.png]]&lt;br /&gt;
* [[:File:CarersLogo.gif]]&lt;br /&gt;
* [[:File:Diagram Needed.svg]]&lt;br /&gt;
* [[:File:Example.jpg]]&lt;br /&gt;
* [[:File:Image placeholder.png]]&lt;br /&gt;
* [[:File:No male portrait.svg]]&lt;br /&gt;
* [[:File:Nocover-upload.png]]&lt;br /&gt;
* [[:File:NoDVDcover copy.png]]&lt;br /&gt;
* [[:File:Noribbon.svg]]&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |&lt;br /&gt;
* [[:File:No portrait-BFD-test.svg]]&lt;br /&gt;
* [[:File:Placeholder barnstar ribbon.png]]&lt;br /&gt;
* [[:File:Project Trains no image.png]]&lt;br /&gt;
* [[:File:Image-request.png]]&lt;br /&gt;
* [[:File:Sin bandera.svg]]&lt;br /&gt;
* [[:File:Sin escudo.svg]]&lt;br /&gt;
* [[:File:Replace this image - temple.png]]&lt;br /&gt;
* [[:File:Replace this image butterfly.png]]&lt;br /&gt;
* [[:File:Replace this image.svg]]&lt;br /&gt;
* [[:File:Replace this image1.svg]]&lt;br /&gt;
* [[:File:Resolution angle.png]]&lt;br /&gt;
* [[:File:Image-No portrait-text-BFD-test.svg]]&lt;br /&gt;
* [[:File:Insert image here.svg]]&lt;br /&gt;
* [[:File:No image available.png]]&lt;br /&gt;
* [[:File:NO IMAGE YET square.png]]&lt;br /&gt;
* [[:File:NO IMAGE YET.png]]&lt;br /&gt;
* [[:File:No Photo Available.svg]]&lt;br /&gt;
* [[:File:No Screenshot.svg]]&lt;br /&gt;
* [[:File:No-image-available.jpg]]&lt;br /&gt;
* [[:File:Null.png]]&lt;br /&gt;
* [[:File:PictureNeeded.gif]]&lt;br /&gt;
* [[:File:Place holder.jpg]]&lt;br /&gt;
* [[:File:Unbenannt.JPG]]&lt;br /&gt;
* [[:File:UploadACopyrightFreeImage.svg]]&lt;br /&gt;
* [[:File:UploadAnImage.gif]]&lt;br /&gt;
* [[:File:UploadAnImage.svg]]&lt;br /&gt;
* [[:File:UploadAnImageShort.svg]]&lt;br /&gt;
* [[:File:CarersLogo.gif]]&lt;br /&gt;
* [[:File:Diagram Needed.svg]]&lt;br /&gt;
* [[:File:No male portrait.svg]]&lt;br /&gt;
* [[:File:NoDVDcover copy.png]]&lt;br /&gt;
* [[:File:Placeholder barnstar ribbon.png]]&lt;br /&gt;
* [[:File:Project Trains no image.png]]&lt;br /&gt;
* [[:File:Image-request.png]]&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== Tracking categories ==&lt;br /&gt;
* {{clc|Pages using deprecated image syntax}}&lt;br /&gt;
* {{clc|Pages using infoboxes with thumbnail images}}&lt;br /&gt;
&lt;br /&gt;
&amp;lt;includeonly&amp;gt;{{Sandbox other||&lt;br /&gt;
{{DEFAULTSORT:Image, {{PAGENAME}}}}&lt;br /&gt;
[[Category:Lua metamodules]]&lt;br /&gt;
[[Category:Modules for image handling]]&lt;br /&gt;
[[Category:Modules that add a tracking category]]&lt;br /&gt;
}}&amp;lt;/includeonly&amp;gt;&lt;/div&gt;</summary>
		<author><name>Aron.hives@edubase.net</name></author>
	</entry>
	<entry>
		<id>https://edubase.wiki/index.php?title=Template:Use_dmy_dates&amp;diff=27326</id>
		<title>Template:Use dmy dates</title>
		<link rel="alternate" type="text/html" href="https://edubase.wiki/index.php?title=Template:Use_dmy_dates&amp;diff=27326"/>
		<updated>2018-11-12T22:47:12Z</updated>

		<summary type="html">&lt;p&gt;Aron.hives@edubase.net: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;{{ {{{|safesubst:}}}#invoke:Unsubst||date=__DATE__ |$B=&lt;br /&gt;
{{DMCA|Use dmy dates|from|{{{date|}}}}}&lt;br /&gt;
}}&amp;lt;noinclude&amp;gt;{{Documentation}}&amp;lt;/noinclude&amp;gt;&lt;/div&gt;</summary>
		<author><name>Aron.hives@edubase.net</name></author>
	</entry>
	<entry>
		<id>https://edubase.wiki/index.php?title=Template:Section_link&amp;diff=27324</id>
		<title>Template:Section link</title>
		<link rel="alternate" type="text/html" href="https://edubase.wiki/index.php?title=Template:Section_link&amp;diff=27324"/>
		<updated>2018-11-12T22:47:12Z</updated>

		<summary type="html">&lt;p&gt;Aron.hives@edubase.net: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;{{#invoke:Section link|main}}&amp;lt;noinclude&amp;gt;&lt;br /&gt;
{{documentation}}&lt;br /&gt;
&amp;lt;!--  Categories go on the /doc subpage and interwikis go on Wikidata. --&amp;gt;&lt;br /&gt;
&amp;lt;/noinclude&amp;gt;&lt;/div&gt;</summary>
		<author><name>Aron.hives@edubase.net</name></author>
	</entry>
	<entry>
		<id>https://edubase.wiki/index.php?title=Template:DMCA&amp;diff=27322</id>
		<title>Template:DMCA</title>
		<link rel="alternate" type="text/html" href="https://edubase.wiki/index.php?title=Template:DMCA&amp;diff=27322"/>
		<updated>2018-11-12T22:47:11Z</updated>

		<summary type="html">&lt;p&gt;Aron.hives@edubase.net: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;{{Dated maintenance category&lt;br /&gt;
 |onlyarticles=yes&lt;br /&gt;
 |1={{{1|}}}&lt;br /&gt;
 |2={{{2|}}}&lt;br /&gt;
 |3={{{3|}}}&lt;br /&gt;
 |4={{{4|}}}&lt;br /&gt;
 |5={{{5|}}}&lt;br /&gt;
}}&amp;lt;noinclude&amp;gt;&lt;br /&gt;
{{documentation|Template:Dated maintenance category/doc}}&lt;br /&gt;
&amp;lt;/noinclude&amp;gt;&lt;/div&gt;</summary>
		<author><name>Aron.hives@edubase.net</name></author>
	</entry>
	<entry>
		<id>https://edubase.wiki/index.php?title=Module:Navbar/doc&amp;diff=27320</id>
		<title>Module:Navbar/doc</title>
		<link rel="alternate" type="text/html" href="https://edubase.wiki/index.php?title=Module:Navbar/doc&amp;diff=27320"/>
		<updated>2018-11-12T22:47:11Z</updated>

		<summary type="html">&lt;p&gt;Aron.hives@edubase.net: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;{{High-use|13200000|all-pages = yes}}&lt;br /&gt;
{{module rating|protected}}&lt;br /&gt;
&lt;br /&gt;
This is a [[WP:Lua|Lua]] implementation of {{tl|Navbar}}. It is used in [[Module:Navbox]].&lt;/div&gt;</summary>
		<author><name>Aron.hives@edubase.net</name></author>
	</entry>
	<entry>
		<id>https://edubase.wiki/index.php?title=Module:Ns_has_subpages&amp;diff=27318</id>
		<title>Module:Ns has subpages</title>
		<link rel="alternate" type="text/html" href="https://edubase.wiki/index.php?title=Module:Ns_has_subpages&amp;diff=27318"/>
		<updated>2018-11-12T22:47:11Z</updated>

		<summary type="html">&lt;p&gt;Aron.hives@edubase.net: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;-- This module implements [[Template:Ns has subpages]].&lt;br /&gt;
-- While the template is fairly simple, this information is made available to&lt;br /&gt;
-- Lua directly, so using a module means that we don&#039;t have to update the&lt;br /&gt;
-- template as new namespaces are added.&lt;br /&gt;
&lt;br /&gt;
local p = {}&lt;br /&gt;
&lt;br /&gt;
function p._main(ns, frame)&lt;br /&gt;
	-- Get the current namespace if we were not passed one.&lt;br /&gt;
	if not ns then&lt;br /&gt;
		ns = mw.title.getCurrentTitle().namespace&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- Look up the namespace table from mw.site.namespaces. This should work&lt;br /&gt;
	-- for a majority of cases.&lt;br /&gt;
	local nsTable = mw.site.namespaces[ns]&lt;br /&gt;
&lt;br /&gt;
	-- Try using string matching to get the namespace from page names.&lt;br /&gt;
	-- Do a quick and dirty bad title check to try and make sure we do the same&lt;br /&gt;
	-- thing as {{NAMESPACE}} in most cases.&lt;br /&gt;
	if not nsTable and type(ns) == &#039;string&#039; and not ns:find(&#039;[&amp;lt;&amp;gt;|%[%]{}]&#039;) then&lt;br /&gt;
		local nsStripped = ns:gsub(&#039;^[_%s]*:&#039;, &#039;&#039;)&lt;br /&gt;
		nsStripped = nsStripped:gsub(&#039;:.*$&#039;, &#039;&#039;)&lt;br /&gt;
		nsTable = mw.site.namespaces[nsStripped]&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- If we still have no match then try the {{NAMESPACE}} parser function,&lt;br /&gt;
	-- which should catch the remainder of cases. Don&#039;t use a mw.title object,&lt;br /&gt;
	-- as this would increment the expensive function count for each new page&lt;br /&gt;
	-- tested.&lt;br /&gt;
	if not nsTable then&lt;br /&gt;
		frame = frame or mw.getCurrentFrame()&lt;br /&gt;
		local nsProcessed = frame:callParserFunction(&#039;NAMESPACE&#039;, ns)&lt;br /&gt;
		nsTable = nsProcessed and mw.site.namespaces[nsProcessed]&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	return nsTable and nsTable.hasSubpages&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.main(frame)&lt;br /&gt;
	local ns = frame:getParent().args[1]&lt;br /&gt;
	if ns then&lt;br /&gt;
		ns = ns:match(&#039;^%s*(.-)%s*$&#039;) -- trim whitespace&lt;br /&gt;
		ns = tonumber(ns) or ns&lt;br /&gt;
	end&lt;br /&gt;
	local hasSubpages = p._main(ns, frame)&lt;br /&gt;
	return hasSubpages and &#039;yes&#039; or &#039;&#039;&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
return p&lt;/div&gt;</summary>
		<author><name>Aron.hives@edubase.net</name></author>
	</entry>
	<entry>
		<id>https://edubase.wiki/index.php?title=Module:Infobox/doc&amp;diff=27316</id>
		<title>Module:Infobox/doc</title>
		<link rel="alternate" type="text/html" href="https://edubase.wiki/index.php?title=Module:Infobox/doc&amp;diff=27316"/>
		<updated>2018-11-12T22:47:10Z</updated>

		<summary type="html">&lt;p&gt;Aron.hives@edubase.net: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;{{Improve documentation|date=October 2018}}&lt;br /&gt;
{{High-use|3,100,000+|all-pages = yes}}&lt;br /&gt;
{{module rating|protected}}&lt;br /&gt;
&lt;br /&gt;
This [[WP:Module|module]] implements the {{tl|Infobox}} template. Please see the template page for usage instructions.&lt;br /&gt;
&lt;br /&gt;
== Tracking categories ==&lt;br /&gt;
* {{clc|Articles which use infobox templates with no data rows}}&lt;br /&gt;
* {{clc|Pages which use embedded infobox templates with the title parameter}}&lt;br /&gt;
&lt;br /&gt;
&amp;lt;includeonly&amp;gt;{{#ifeq:{{SUBPAGENAME}}|sandbox||&lt;br /&gt;
[[Category:Modules that add a tracking category]]&lt;br /&gt;
[[Category:Wikipedia infoboxes]]&lt;br /&gt;
[[Category:Infobox modules]]&lt;br /&gt;
}}&amp;lt;/includeonly&amp;gt;&lt;/div&gt;</summary>
		<author><name>Aron.hives@edubase.net</name></author>
	</entry>
	<entry>
		<id>https://edubase.wiki/index.php?title=Template:Ns_has_subpages&amp;diff=27314</id>
		<title>Template:Ns has subpages</title>
		<link rel="alternate" type="text/html" href="https://edubase.wiki/index.php?title=Template:Ns_has_subpages&amp;diff=27314"/>
		<updated>2018-11-12T22:47:10Z</updated>

		<summary type="html">&lt;p&gt;Aron.hives@edubase.net: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;{{&amp;lt;includeonly&amp;gt;safesubst:&amp;lt;/includeonly&amp;gt;#invoke:Ns has subpages|main}}&amp;lt;noinclude&amp;gt;&lt;br /&gt;
{{documentation}}&lt;br /&gt;
&amp;lt;!-- Categories go on the /doc subpage and interwikis go on Wikidata. --&amp;gt;&lt;br /&gt;
&amp;lt;/noinclude&amp;gt;&lt;/div&gt;</summary>
		<author><name>Aron.hives@edubase.net</name></author>
	</entry>
	<entry>
		<id>https://edubase.wiki/index.php?title=Template:Improve_documentation&amp;diff=27312</id>
		<title>Template:Improve documentation</title>
		<link rel="alternate" type="text/html" href="https://edubase.wiki/index.php?title=Template:Improve_documentation&amp;diff=27312"/>
		<updated>2018-11-12T22:47:10Z</updated>

		<summary type="html">&lt;p&gt;Aron.hives@edubase.net: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;{{SAFESUBST:&amp;lt;noinclude /&amp;gt;#invoke:Unsubst||date=__DATE__ |$B={{Ombox&lt;br /&gt;
| type  = content&lt;br /&gt;
| name  = Improve documentation&lt;br /&gt;
| class = ambox-Refimprove&lt;br /&gt;
| image = [[File:Question book-new.svg|50x40px|alt=Question book (new version) SVG]]&lt;br /&gt;
| text  = This {{#switch:{{NAMESPACE}}|Module=module|#default=template}}&#039;s [[Wikipedia:Template documentation|documentation]] is &#039;&#039;&#039;missing, inadequate, or does not accurately describe its functionality and/or the [[Help:Parameters|parameters]] in its code.&#039;&#039;&#039; Please help [{{fullurl:{{FULLPAGENAME}}{{#ifexist:{{FULLPAGENAME}}/doc|/doc}}|action=edit}} to expand and improve it]. {{#if:{{{talk|{{{1|}}}}}} |See [[{{TALKPAGENAME}}|talk page]] for details.|}} {{#if:{{{date|{{{2|}}}}}} |{{smaller|&#039;&#039;({{{date}}})&#039;&#039;}}}}&lt;br /&gt;
}}&amp;lt;includeonly&amp;gt;{{Dated maintenance category|||Templates with missing or incorrect documentation}}&amp;lt;/includeonly&amp;gt;}}&amp;lt;noinclude&amp;gt;&lt;br /&gt;
{{Documentation}}&lt;br /&gt;
&amp;lt;/noinclude&amp;gt;&lt;/div&gt;</summary>
		<author><name>Aron.hives@edubase.net</name></author>
	</entry>
	<entry>
		<id>https://edubase.wiki/index.php?title=Template:FULLROOTPAGENAME&amp;diff=27310</id>
		<title>Template:FULLROOTPAGENAME</title>
		<link rel="alternate" type="text/html" href="https://edubase.wiki/index.php?title=Template:FULLROOTPAGENAME&amp;diff=27310"/>
		<updated>2018-11-12T22:47:09Z</updated>

		<summary type="html">&lt;p&gt;Aron.hives@edubase.net: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;{{ {{{|safesubst:}}}#if: {{ {{{|safesubst:}}}Ns has subpages | {{ {{{|safesubst:}}}#if:{{{1|}}}|{{ {{{|safesubst:}}}NAMESPACE:{{{1}}}}}|{{ {{{|safesubst:}}}NAMESPACE}}}} }} &lt;br /&gt;
  | {{ {{{|safesubst:}}}#titleparts:{{ {{{|safesubst:}}}#if:{{{1|}}}|{{{1}}}|{{ {{{|safesubst:}}}FULLPAGENAME}}}}|1}}&lt;br /&gt;
  | {{ {{{|safesubst:}}}#if:{{{1|}}}|{{{1}}}|{{ {{{|safesubst:}}}FULLPAGENAME}}}}&lt;br /&gt;
}}&amp;lt;noinclude&amp;gt;&lt;br /&gt;
&lt;br /&gt;
{{documentation}}&lt;br /&gt;
&lt;br /&gt;
&amp;lt;/noinclude&amp;gt;&lt;/div&gt;</summary>
		<author><name>Aron.hives@edubase.net</name></author>
	</entry>
	<entry>
		<id>https://edubase.wiki/index.php?title=Template:Dated_maintenance_category&amp;diff=27308</id>
		<title>Template:Dated maintenance category</title>
		<link rel="alternate" type="text/html" href="https://edubase.wiki/index.php?title=Template:Dated_maintenance_category&amp;diff=27308"/>
		<updated>2018-11-12T22:47:09Z</updated>

		<summary type="html">&lt;p&gt;Aron.hives@edubase.net: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;&amp;lt;nowiki/&amp;gt;&amp;lt;!--This nowiki helps to prevent whitespace at the top of articles--&amp;gt;{{#ifeq:{{FULLROOTPAGENAME}}|Wikipedia:Template messages|&amp;lt;!--Do not categorize--&amp;gt;|&amp;lt;!--&lt;br /&gt;
--&amp;gt;{{#ifexpr:{{#if:{{NAMESPACE}}|0|1}}+{{#ifeq:{{{onlyarticles|no}}}|yes|0|1}}&lt;br /&gt;
 |{{#if:{{{3|}}}&lt;br /&gt;
  |[[Category:{{{1}}} {{{2}}} {{{3}}}]]&amp;lt;!--&lt;br /&gt;
--&amp;gt;{{#ifexist:Category:{{{1}}} {{{2}}} {{{3}}}&lt;br /&gt;
    |&amp;lt;!--&lt;br /&gt;
 --&amp;gt;|[[Category:Articles with invalid date parameter in template]]&amp;lt;!--&lt;br /&gt;
--&amp;gt;}}&lt;br /&gt;
  |[[Category:{{#if:{{{5|}}}&lt;br /&gt;
               |{{{5}}}&amp;lt;!--&lt;br /&gt;
            --&amp;gt;|{{{1}}}&amp;lt;!--&lt;br /&gt;
           --&amp;gt;}}]]&amp;lt;!--&lt;br /&gt;
--&amp;gt;}}{{#if:{{{4|}}}&lt;br /&gt;
      |[[Category:{{{4}}}]]}}&amp;lt;!--&lt;br /&gt;
  --&amp;gt;}}&amp;lt;!--&lt;br /&gt;
--&amp;gt;}}&amp;lt;noinclude&amp;gt;&lt;br /&gt;
{{documentation}}&lt;br /&gt;
&amp;lt;/noinclude&amp;gt;&lt;/div&gt;</summary>
		<author><name>Aron.hives@edubase.net</name></author>
	</entry>
	<entry>
		<id>https://edubase.wiki/index.php?title=Module:Wikibase&amp;diff=27306</id>
		<title>Module:Wikibase</title>
		<link rel="alternate" type="text/html" href="https://edubase.wiki/index.php?title=Module:Wikibase&amp;diff=27306"/>
		<updated>2018-11-12T22:47:08Z</updated>

		<summary type="html">&lt;p&gt;Aron.hives@edubase.net: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;---------- Module:Wikibase ----------------&lt;br /&gt;
local p = {}&lt;br /&gt;
&lt;br /&gt;
-- Return the item ID of the item linked to the current page.&lt;br /&gt;
function p.id(frame)&lt;br /&gt;
	if not mw.wikibase then&lt;br /&gt;
		return &amp;quot;no mw.wikibase&amp;quot;&lt;br /&gt;
	end&lt;br /&gt;
	entity = mw.wikibase.getEntityObject()&lt;br /&gt;
&lt;br /&gt;
	if entity == nil then&lt;br /&gt;
		return &amp;quot;no entity&amp;quot;&lt;br /&gt;
	end&lt;br /&gt;
	return entity.id&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- Return the WD entity URL of a given data item, or of connected page&lt;br /&gt;
-- if no argument is provided to this method.&lt;br /&gt;
function p.wdurl(frame)&lt;br /&gt;
	if frame.args[1] == nil then&lt;br /&gt;
		entity = mw.wikibase.getEntityObject()&lt;br /&gt;
		if not entity then return nil end&lt;br /&gt;
		id = entity.id&lt;br /&gt;
	else&lt;br /&gt;
		id = mw.text.trim(frame.args[1])&lt;br /&gt;
	end&lt;br /&gt;
	return mw.wikibase.getEntityUrl( id )&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- Return the label of a given data item, or of connected page&lt;br /&gt;
-- if no argument is provided to this method.&lt;br /&gt;
function p.label(frame)&lt;br /&gt;
	if frame.args[1] == nil then&lt;br /&gt;
		entity = mw.wikibase.getEntityObject()&lt;br /&gt;
		if not entity then return nil end&lt;br /&gt;
		id = entity.id&lt;br /&gt;
	else&lt;br /&gt;
		id = mw.text.trim(frame.args[1])&lt;br /&gt;
	end&lt;br /&gt;
	return mw.wikibase.label( id )&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- Return the description of a given data item, or of connected page&lt;br /&gt;
-- if no argument is provided to this method.&lt;br /&gt;
function p.description(frame)&lt;br /&gt;
	if frame.args[1] == nil then&lt;br /&gt;
		entity = mw.wikibase.getEntityObject()&lt;br /&gt;
		if not entity then return nil end&lt;br /&gt;
		id = entity.id&lt;br /&gt;
	else&lt;br /&gt;
		id = mw.text.trim(frame.args[1])&lt;br /&gt;
	end&lt;br /&gt;
	return mw.wikibase.description( id )&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- Return the local page about a given data item, or of connected page&lt;br /&gt;
-- if id is not specified.&lt;br /&gt;
function p.page(frame)&lt;br /&gt;
	if frame.args[1] == nil then&lt;br /&gt;
		entity = mw.wikibase.getEntityObject()&lt;br /&gt;
		if not entity then return nil end&lt;br /&gt;
		id = entity.id&lt;br /&gt;
	else&lt;br /&gt;
		id = mw.text.trim(frame.args[1])&lt;br /&gt;
	end&lt;br /&gt;
	return mw.wikibase.sitelink( id )&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- Return the data type of a property&lt;br /&gt;
function p.datatype(frame)&lt;br /&gt;
	if frame.args[1] and string.find(frame.args[1], &amp;quot;Property:P&amp;quot;) then&lt;br /&gt;
		if mw.wikibase.getEntityObject(string.gsub(frame.args[1], &amp;quot;Property:P&amp;quot;, &amp;quot;P&amp;quot;))  then&lt;br /&gt;
			return mw.wikibase.getEntityObject(string.gsub(frame.args[1], &amp;quot;Property:P&amp;quot;, &amp;quot;P&amp;quot;) ).datatype&lt;br /&gt;
		end&lt;br /&gt;
	elseif frame.args[1] and string.find(frame.args[1], &amp;quot;P&amp;quot;) then&lt;br /&gt;
		if mw.wikibase.getEntityObject(frame.args[1])  then&lt;br /&gt;
			return mw.wikibase.getEntityObject(frame.args[1]).datatype&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
return p&lt;/div&gt;</summary>
		<author><name>Aron.hives@edubase.net</name></author>
	</entry>
	<entry>
		<id>https://edubase.wiki/index.php?title=Module:Redirect&amp;diff=27304</id>
		<title>Module:Redirect</title>
		<link rel="alternate" type="text/html" href="https://edubase.wiki/index.php?title=Module:Redirect&amp;diff=27304"/>
		<updated>2018-11-12T22:47:08Z</updated>

		<summary type="html">&lt;p&gt;Aron.hives@edubase.net: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;-- This module provides functions for getting the target of a redirect page.&lt;br /&gt;
&lt;br /&gt;
local p = {}&lt;br /&gt;
&lt;br /&gt;
-- Gets a mw.title object, using pcall to avoid generating script errors if we&lt;br /&gt;
-- are over the expensive function count limit (among other possible causes).&lt;br /&gt;
local function getTitle(...)&lt;br /&gt;
	local success, titleObj = pcall(mw.title.new, ...)&lt;br /&gt;
	if success then&lt;br /&gt;
		return titleObj&lt;br /&gt;
	else&lt;br /&gt;
		return nil&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- Gets the name of a page that a redirect leads to, or nil if it isn&#039;t a&lt;br /&gt;
-- redirect.&lt;br /&gt;
function p.getTargetFromText(text)&lt;br /&gt;
	return string.match(&lt;br /&gt;
		text,&lt;br /&gt;
		&amp;quot;^%s*#[Rr][Ee][Dd][Ii][Rr][Ee][Cc][Tt]%s*:?%s*%[%[([^%[%]|]-)%]%]&amp;quot;&lt;br /&gt;
	) or string.match(&lt;br /&gt;
		text,&lt;br /&gt;
		&amp;quot;^%s*#[Rr][Ee][Dd][Ii][Rr][Ee][Cc][Tt]%s*:?%s*%[%[([^%[%]|]-)|[^%[%]]-%]%]&amp;quot;&lt;br /&gt;
	)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- Gets the target of a redirect. If the page specified is not a redirect,&lt;br /&gt;
-- returns nil.&lt;br /&gt;
function p.getTarget(page, fulltext)&lt;br /&gt;
	-- Get the title object. Both page names and title objects are allowed&lt;br /&gt;
	-- as input.&lt;br /&gt;
	local titleObj&lt;br /&gt;
	if type(page) == &#039;string&#039; or type(page) == &#039;number&#039; then&lt;br /&gt;
		titleObj = getTitle(page)&lt;br /&gt;
	elseif type(page) == &#039;table&#039; and type(page.getContent) == &#039;function&#039; then&lt;br /&gt;
		titleObj = page&lt;br /&gt;
	else&lt;br /&gt;
		error(string.format(&lt;br /&gt;
			&amp;quot;bad argument #1 to &#039;getTarget&#039;&amp;quot;&lt;br /&gt;
				.. &amp;quot; (string, number, or title object expected, got %s)&amp;quot;,&lt;br /&gt;
			type(page)&lt;br /&gt;
		), 2)&lt;br /&gt;
	end&lt;br /&gt;
	if not titleObj or not titleObj.isRedirect then&lt;br /&gt;
		return nil&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	-- Find the target by using string matching on the page content.&lt;br /&gt;
	local target = p.getTargetFromText(titleObj:getContent() or &amp;quot;&amp;quot;)&lt;br /&gt;
	if target then&lt;br /&gt;
		local targetTitle = getTitle(target)&lt;br /&gt;
		if targetTitle then&lt;br /&gt;
			if fulltext then&lt;br /&gt;
				return targetTitle.fullText&lt;br /&gt;
			else&lt;br /&gt;
				return targetTitle.prefixedText&lt;br /&gt;
			end&lt;br /&gt;
		else&lt;br /&gt;
			return nil&lt;br /&gt;
		end&lt;br /&gt;
	else&lt;br /&gt;
		-- The page is a redirect, but matching failed. This indicates a bug in&lt;br /&gt;
		-- the redirect matching pattern, so throw an error.&lt;br /&gt;
		error(string.format(&lt;br /&gt;
			&#039;could not parse redirect on page &amp;quot;%s&amp;quot;&#039;,&lt;br /&gt;
			fulltext and titleObj.fullText or titleObj.prefixedText&lt;br /&gt;
		))&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
-- Given a single page name determines what page it redirects to and returns the&lt;br /&gt;
-- target page name, or the passed page name when not a redirect. The passed&lt;br /&gt;
-- page name can be given as plain text or as a page link.&lt;br /&gt;
-- &lt;br /&gt;
-- Returns page name as plain text, or when the bracket parameter is given, as a&lt;br /&gt;
-- page link. Returns an error message when page does not exist or the redirect&lt;br /&gt;
-- target cannot be determined for some reason.&lt;br /&gt;
--]]&lt;br /&gt;
function p.luaMain(rname, bracket, fulltext)&lt;br /&gt;
	if type(rname) ~= &amp;quot;string&amp;quot; or not rname:find(&amp;quot;%S&amp;quot;) then&lt;br /&gt;
		return nil&lt;br /&gt;
	end&lt;br /&gt;
	bracket = bracket and &amp;quot;[[%s]]&amp;quot; or &amp;quot;%s&amp;quot;&lt;br /&gt;
	rname = rname:match(&amp;quot;%[%[(.+)%]%]&amp;quot;) or rname&lt;br /&gt;
	local target = p.getTarget(rname, fulltext)&lt;br /&gt;
	local ret = target or rname&lt;br /&gt;
	ret = getTitle(ret)&lt;br /&gt;
	if ret then&lt;br /&gt;
		if fulltext then&lt;br /&gt;
			ret = ret.fullText&lt;br /&gt;
		else&lt;br /&gt;
			ret = ret.prefixedText&lt;br /&gt;
		end&lt;br /&gt;
		return bracket:format(ret)&lt;br /&gt;
	else&lt;br /&gt;
		return nil&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- Provides access to the luaMain function from wikitext.&lt;br /&gt;
function p.main(frame)&lt;br /&gt;
	local args = require(&#039;Module:Arguments&#039;).getArgs(frame, {frameOnly = true})&lt;br /&gt;
	return p.luaMain(args[1], args.bracket, args.fulltext) or &#039;&#039;&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- Returns true if the specified page is a redirect, and false otherwise.&lt;br /&gt;
function p.luaIsRedirect(page)&lt;br /&gt;
	local titleObj = getTitle(page)&lt;br /&gt;
	if not titleObj then&lt;br /&gt;
		return false&lt;br /&gt;
	end&lt;br /&gt;
	if titleObj.isRedirect then&lt;br /&gt;
		return true&lt;br /&gt;
	else&lt;br /&gt;
		return false&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- Provides access to the luaIsRedirect function from wikitext, returning &#039;yes&#039;&lt;br /&gt;
-- if the specified page is a redirect, and the blank string otherwise.&lt;br /&gt;
function p.isRedirect(frame)&lt;br /&gt;
	local args = require(&#039;Module:Arguments&#039;).getArgs(frame, {frameOnly = true})&lt;br /&gt;
	if p.luaIsRedirect(args[1]) then&lt;br /&gt;
		return &#039;yes&#039;&lt;br /&gt;
	else&lt;br /&gt;
		return &#039;&#039;&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
return p&lt;/div&gt;</summary>
		<author><name>Aron.hives@edubase.net</name></author>
	</entry>
	<entry>
		<id>https://edubase.wiki/index.php?title=Module:Authority_control/doc&amp;diff=27302</id>
		<title>Module:Authority control/doc</title>
		<link rel="alternate" type="text/html" href="https://edubase.wiki/index.php?title=Module:Authority_control/doc&amp;diff=27302"/>
		<updated>2018-11-12T22:47:08Z</updated>

		<summary type="html">&lt;p&gt;Aron.hives@edubase.net: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;{{High-risk|890000}}&lt;br /&gt;
{{Module rating|protected}}&lt;br /&gt;
{{Lua sidebar}}&lt;br /&gt;
{{Uses Wikidata|section=Parameters}}&lt;br /&gt;
{{Lua|Module:Navbox|Module:ResolveEntityId|Module:No globals}}&lt;br /&gt;
&lt;br /&gt;
This module contains the code of the {{T|Authority control}} template. See its documentation.&lt;br /&gt;
&lt;br /&gt;
{{Anchor|Parameters|Parameter names|Wikidata|Wikidata properties|Tracking categories}}&lt;br /&gt;
&lt;br /&gt;
== Parameters, Wikidata properties, and tracking categories ==&lt;br /&gt;
{{#invoke:Authority control|docConfTable}}&lt;br /&gt;
&lt;br /&gt;
== Additional tracking categories ==&lt;br /&gt;
This module also implements the following hidden tracking categories:&lt;br /&gt;
&lt;br /&gt;
* {{clc|Pages with red-linked authority control categories}}&lt;br /&gt;
* {{clc|Wikipedia articles with deprecated authority control identifiers}}&lt;br /&gt;
* {{clc|Wikipedia articles with suppressed authority control identifiers}}&lt;br /&gt;
* {{clc|Pages using authority control with parameters}}&lt;br /&gt;
&lt;br /&gt;
=== Number of identifiers ===&lt;br /&gt;
* {{clc|AC with 14 elements}}&lt;br /&gt;
* {{clc|AC with 15 elements}}&lt;br /&gt;
* {{clc|AC with 16 elements}}&lt;br /&gt;
* {{clc|AC with 17 elements}}&lt;br /&gt;
* {{clc|AC with 18 elements}}&lt;br /&gt;
* {{clc|AC with 19 elements}}&lt;br /&gt;
* {{clc|AC with 20 elements}}&lt;br /&gt;
* {{clc|AC with 21 elements}}&lt;br /&gt;
* {{clc|AC with 22 elements}}&lt;br /&gt;
* {{clc|AC with 23 elements}}&lt;br /&gt;
* {{clc|AC with 24 elements}}&lt;br /&gt;
&lt;br /&gt;
&amp;lt;includeonly&amp;gt;{{sandbox other||&lt;br /&gt;
[[Category:Modules that add a tracking category]]&lt;br /&gt;
[[Category:Modules using data from Wikidata]]&lt;br /&gt;
}}&amp;lt;/includeonly&amp;gt;&lt;/div&gt;</summary>
		<author><name>Aron.hives@edubase.net</name></author>
	</entry>
	<entry>
		<id>https://edubase.wiki/index.php?title=Template:Wikidata_property_link&amp;diff=27300</id>
		<title>Template:Wikidata property link</title>
		<link rel="alternate" type="text/html" href="https://edubase.wiki/index.php?title=Template:Wikidata_property_link&amp;diff=27300"/>
		<updated>2018-11-12T22:47:07Z</updated>

		<summary type="html">&lt;p&gt;Aron.hives@edubase.net: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;&amp;lt;includeonly&amp;gt;{{#switch: {{uc:{{Str left|{{{id|}}}|1}}}}&lt;br /&gt;
| N &amp;lt;!--none--&amp;gt; = {{#switch: {{uc:{{Str left|{{{1|}}}|1}}}}&lt;br /&gt;
  | P = [[d:Property:{{#if:1|{{{1|}}}}}|{{Label|{{#if:1|{{{1|}}}}}}}]]&lt;br /&gt;
  | [[d:Property:P{{#if:1|{{{1|}}}}}|{{Label|P{{#if:1|{{{1|}}}}}}}]]&lt;br /&gt;
  }}&lt;br /&gt;
| O &amp;lt;!--only--&amp;gt; = {{#switch: {{uc:{{Str left|{{{1|}}}|1}}}}&lt;br /&gt;
  | P = [[d:Property:{{#if:1|{{{1|}}}}}|{{#if:1|{{{1|}}}}}]]&lt;br /&gt;
  | [[d:Property:P{{#if:1|{{{1|}}}}}|P{{#if:1|{{{1|}}}}}]]&lt;br /&gt;
  }}&lt;br /&gt;
| F &amp;lt;!--first--&amp;gt; = {{#switch: {{uc:{{Str left|{{{1|}}}|1}}}}&lt;br /&gt;
  | P = [[d:Property:{{#if:1|{{{1|}}}}}|{{#if:1|{{{1|}}}}}]]{{#if:{{Label|{{#if:1|{{{1|}}}}}}}|&amp;amp;#58; &amp;lt;small&amp;gt;{{Label|{{#if:1|{{{1|}}}}}}}&amp;lt;/small&amp;gt;}}&lt;br /&gt;
  | [[d:Property:P{{#if:1|{{{1|}}}}}|P{{#if:1|{{{1|}}}}}]]{{#if:{{Label|P{{#if:1|{{{1|}}}}}}}|&amp;amp;#58; &amp;lt;small&amp;gt;{{Label|P{{#if:1|{{{1|}}}}}}}&amp;lt;/small&amp;gt;}}&lt;br /&gt;
  }}&lt;br /&gt;
| #default = {{#switch: {{uc:{{Str left|{{{1|}}}|1}}}}&lt;br /&gt;
  | P = [[d:Property:{{#if:1|{{{1|}}}}}|{{Label|{{#if:1|{{{1|}}}}}}} &amp;lt;small&amp;gt;({{#if:1|{{{1|}}}}})&amp;lt;/small&amp;gt;]]&lt;br /&gt;
  | [[d:Property:P{{#if:1|{{{1|}}}}}|{{Label|P{{#if:1|{{{1|}}}}}}} &amp;lt;small&amp;gt;(P{{#if:1|{{{1|}}}}})&amp;lt;/small&amp;gt;]]&lt;br /&gt;
  }}&lt;br /&gt;
}}&amp;lt;/includeonly&amp;gt;&amp;lt;noinclude&amp;gt;&lt;br /&gt;
{{Documentation}}&lt;br /&gt;
&amp;lt;/noinclude&amp;gt;&lt;/div&gt;</summary>
		<author><name>Aron.hives@edubase.net</name></author>
	</entry>
	<entry>
		<id>https://edubase.wiki/index.php?title=Template:T&amp;diff=27298</id>
		<title>Template:T</title>
		<link rel="alternate" type="text/html" href="https://edubase.wiki/index.php?title=Template:T&amp;diff=27298"/>
		<updated>2018-11-12T22:47:06Z</updated>

		<summary type="html">&lt;p&gt;Aron.hives@edubase.net: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;#REDIRECT [[Template:tl]]&lt;br /&gt;
&lt;br /&gt;
&amp;lt;!-- Used as Template:tl throughout English Wikipedia; demo template referenced only on meta -&amp;gt;&lt;/div&gt;</summary>
		<author><name>Aron.hives@edubase.net</name></author>
	</entry>
	<entry>
		<id>https://edubase.wiki/index.php?title=Template:Lua_sidebar&amp;diff=27296</id>
		<title>Template:Lua sidebar</title>
		<link rel="alternate" type="text/html" href="https://edubase.wiki/index.php?title=Template:Lua_sidebar&amp;diff=27296"/>
		<updated>2018-11-12T22:47:06Z</updated>

		<summary type="html">&lt;p&gt;Aron.hives@edubase.net: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;{{Sidebar|width=238px&lt;br /&gt;
| title = Related pages&lt;br /&gt;
| content1 = {{div col|colwidth=8em}}&lt;br /&gt;
&amp;lt;div class=&amp;quot;plainlist&amp;quot;&amp;gt;&lt;br /&gt;
* [[Template:{{{template|{{{title|{{BASEPAGENAME}}}}}}}}|Template]] {{#if:{{#invoke:redirect|isRedirect|Template talk:{{{template|{{{title|{{BASEPAGENAME}}}}}}}}}}||([[Template talk:{{{template|{{{title|{{BASEPAGENAME}}}}}}}}|talk]])}}&lt;br /&gt;
* [[Template:{{{template|{{{title|{{BASEPAGENAME}}}}}}}}/sandbox|Template sandbox]]&lt;br /&gt;
* [[Template:{{{template|{{{title|{{BASEPAGENAME}}}}}}}}/testcases|Template testcases]]&lt;br /&gt;
* [[Template:{{{template|{{{title|{{BASEPAGENAME}}}}}}}}/doc|Template doc]]&lt;br /&gt;
* [[Special:PrefixIndex/Template:{{{template|{{{title|{{BASEPAGENAME}}}}}}}}/|Template subpages]]&lt;br /&gt;
* [[Module:{{{module|{{{title|{{BASEPAGENAME}}}}}}}}|Module]] {{#if:{{#invoke:redirect|isRedirect|Module talk:{{{module|{{{title|{{BASEPAGENAME}}}}}}}}}}||([[Module talk:{{{module|{{{title|{{BASEPAGENAME}}}}}}}}|talk]])}}&lt;br /&gt;
* [[Module:{{{module|{{{title|{{BASEPAGENAME}}}}}}}}/sandbox|Module sandbox]]&lt;br /&gt;
* [[Module:{{{module|{{{title|{{BASEPAGENAME}}}}}}}}/testcases|Module testcases]]&lt;br /&gt;
* [[Module:{{{module|{{{title|{{BASEPAGENAME}}}}}}}}/doc|Module doc]]&lt;br /&gt;
* [[Special:PrefixIndex/Module:{{{module|{{{title|{{BASEPAGENAME}}}}}}}}/|Module subpages]]&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
{{div col end}}&lt;br /&gt;
| content2 = {{{1|}}}&lt;br /&gt;
}}&amp;lt;noinclude&amp;gt;{{Documentation}}&amp;lt;/noinclude&amp;gt;&lt;/div&gt;</summary>
		<author><name>Aron.hives@edubase.net</name></author>
	</entry>
	<entry>
		<id>https://edubase.wiki/index.php?title=Template:Label&amp;diff=27294</id>
		<title>Template:Label</title>
		<link rel="alternate" type="text/html" href="https://edubase.wiki/index.php?title=Template:Label&amp;diff=27294"/>
		<updated>2018-11-12T22:47:06Z</updated>

		<summary type="html">&lt;p&gt;Aron.hives@edubase.net: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;{{#if:{{{1|}}}|{{#invoke:Wikibase|label|{{{1}}}}}|{{#invoke:Wikibase|label}}}}&amp;lt;noinclude&amp;gt;{{documentation}}&amp;lt;/noinclude&amp;gt;&lt;/div&gt;</summary>
		<author><name>Aron.hives@edubase.net</name></author>
	</entry>
	<entry>
		<id>https://edubase.wiki/index.php?title=Template:Div_col_end&amp;diff=27292</id>
		<title>Template:Div col end</title>
		<link rel="alternate" type="text/html" href="https://edubase.wiki/index.php?title=Template:Div_col_end&amp;diff=27292"/>
		<updated>2018-11-12T22:47:05Z</updated>

		<summary type="html">&lt;p&gt;Aron.hives@edubase.net: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;&amp;lt;includeonly&amp;gt;&amp;lt;/div&amp;gt;&amp;lt;/includeonly&amp;gt;&amp;lt;noinclude&amp;gt;&lt;br /&gt;
{{Documentation|Template:Div col/doc}}&lt;br /&gt;
&amp;lt;/noinclude&amp;gt;&lt;/div&gt;</summary>
		<author><name>Aron.hives@edubase.net</name></author>
	</entry>
	<entry>
		<id>https://edubase.wiki/index.php?title=Template:Div_col&amp;diff=27290</id>
		<title>Template:Div col</title>
		<link rel="alternate" type="text/html" href="https://edubase.wiki/index.php?title=Template:Div_col&amp;diff=27290"/>
		<updated>2018-11-12T22:47:05Z</updated>

		<summary type="html">&lt;p&gt;Aron.hives@edubase.net: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;&amp;lt;includeonly&amp;gt;&amp;lt;div class=&amp;quot;div-col columns column-width&amp;quot; style=&amp;quot;{{column-width|{{{colwidth|30em}}}}} &amp;lt;!--&lt;br /&gt;
 --&amp;gt;{{#if: {{{gap|}}}&lt;br /&gt;
    | {{column-gap|{{{gap}}}}} }}&amp;lt;!--&lt;br /&gt;
 --&amp;gt;{{#switch: {{{rules|}}}&lt;br /&gt;
    | = &amp;lt;!--empty--&amp;gt;&lt;br /&gt;
    | yes = {{column-rule}}&lt;br /&gt;
    | {{Column-rule|{{{rules}}}}} }} &amp;lt;!--&lt;br /&gt;
 --&amp;gt;{{#ifeq: {{{small|}}}|yes&lt;br /&gt;
    | font-size:90%; }} &amp;lt;!--&lt;br /&gt;
 --&amp;gt;{{#if: {{{style|}}}&lt;br /&gt;
    | {{{style}}} }}&amp;quot;&amp;gt;&amp;lt;!--&lt;br /&gt;
 --&amp;gt;{{#if: {{{content|}}}&lt;br /&gt;
    |{{{content}}}&amp;lt;/div&amp;gt;}}&amp;lt;!-- Inventory how many pages use small=yes &lt;br /&gt;
 --&amp;gt;{{#ifeq: {{{small|}}}|yes&lt;br /&gt;
    |[[Category:Pages using div col with small parameter]]}}&amp;lt;/includeonly&amp;gt;{{#invoke:Check for unknown parameters|check|unknown={{main other|[[Category:Pages using div col with unknown parameters|_VALUE_{{PAGENAME}}]]}}|preview=Page using [[Template:Div col]] with unknown parameter &amp;quot;_VALUE_&amp;quot;; use colwidth= to specify column size |ignoreblank=y | colwidth | content | gap | rules | small | style }}&amp;lt;noinclude&amp;gt;&lt;br /&gt;
{{Documentation}}&lt;br /&gt;
&amp;lt;/noinclude&amp;gt;&lt;/div&gt;</summary>
		<author><name>Aron.hives@edubase.net</name></author>
	</entry>
	<entry>
		<id>https://edubase.wiki/index.php?title=Template:Column-width&amp;diff=27288</id>
		<title>Template:Column-width</title>
		<link rel="alternate" type="text/html" href="https://edubase.wiki/index.php?title=Template:Column-width&amp;diff=27288"/>
		<updated>2018-11-12T22:47:05Z</updated>

		<summary type="html">&lt;p&gt;Aron.hives@edubase.net: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;&amp;lt;includeonly&amp;gt;-moz-column-width: {{{1|30em}}}; -webkit-column-width: {{{1|30em}}}; column-width: {{{1|30em}}};&amp;lt;/includeonly&amp;gt;&amp;lt;noinclude&amp;gt;&lt;br /&gt;
{{documentation}}&lt;br /&gt;
&amp;lt;/noinclude&amp;gt;&lt;/div&gt;</summary>
		<author><name>Aron.hives@edubase.net</name></author>
	</entry>
	<entry>
		<id>https://edubase.wiki/index.php?title=Module:Yesno/doc&amp;diff=27286</id>
		<title>Module:Yesno/doc</title>
		<link rel="alternate" type="text/html" href="https://edubase.wiki/index.php?title=Module:Yesno/doc&amp;diff=27286"/>
		<updated>2018-11-12T22:47:05Z</updated>

		<summary type="html">&lt;p&gt;Aron.hives@edubase.net: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;{{High-use|15,600,000|all-pages = yes}}&lt;br /&gt;
{{used in system}}&lt;br /&gt;
{{Module rating|protected}}&lt;br /&gt;
This module provides a consistent interface for processing boolean or boolean-style string input. While Lua allows the &amp;lt;code&amp;gt;true&amp;lt;/code&amp;gt; and &amp;lt;code&amp;gt;false&amp;lt;/code&amp;gt; boolean values, wikicode templates can only express boolean values through strings such as &amp;quot;yes&amp;quot;, &amp;quot;no&amp;quot;, etc. This module processes these kinds of strings and turns them into boolean input for Lua to process. It also returns &amp;lt;code&amp;gt;nil&amp;lt;/code&amp;gt; values as &amp;lt;code&amp;gt;nil&amp;lt;/code&amp;gt;, to allow for distinctions between &amp;lt;code&amp;gt;nil&amp;lt;/code&amp;gt; and &amp;lt;code&amp;gt;false&amp;lt;/code&amp;gt;. The module also accepts other Lua structures as input, i.e. booleans, numbers, tables, and functions. If it is passed input that it does not recognise as boolean or &amp;lt;code&amp;gt;nil&amp;lt;/code&amp;gt;, it is possible to specify a default value to return.&lt;br /&gt;
&lt;br /&gt;
== Syntax ==&lt;br /&gt;
&lt;br /&gt;
&amp;lt;source lang=&amp;quot;lua&amp;quot;&amp;gt;yesno(value, default)&amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;code&amp;gt;value&amp;lt;/code&amp;gt; is the value to be tested. Boolean input or boolean-style input (see below) always evaluates to either &amp;lt;code&amp;gt;true&amp;lt;/code&amp;gt; or &amp;lt;code&amp;gt;false&amp;lt;/code&amp;gt;, and &amp;lt;code&amp;gt;nil&amp;lt;/code&amp;gt; always evaluates to &amp;lt;code&amp;gt;nil&amp;lt;/code&amp;gt;. Other values evaluate to &amp;lt;code&amp;gt;default&amp;lt;/code&amp;gt;.&lt;br /&gt;
&lt;br /&gt;
== Usage ==&lt;br /&gt;
&lt;br /&gt;
First, load the module. Note that it can only be loaded from other Lua modules, not from normal wiki pages. For normal wiki pages you can use {{tl|yesno}} instead.&lt;br /&gt;
&lt;br /&gt;
&amp;lt;source lang=&amp;quot;lua&amp;quot;&amp;gt;&lt;br /&gt;
local yesno = require(&#039;Module:Yesno&#039;)&lt;br /&gt;
&amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Some input values always return &amp;lt;code&amp;gt;true&amp;lt;/code&amp;gt;, and some always return &amp;lt;code&amp;gt;false&amp;lt;/code&amp;gt;. &amp;lt;code&amp;gt;nil&amp;lt;/code&amp;gt; values always return &amp;lt;code&amp;gt;nil&amp;lt;/code&amp;gt;.&lt;br /&gt;
&lt;br /&gt;
&amp;lt;source lang=&amp;quot;lua&amp;quot;&amp;gt;&lt;br /&gt;
-- These always return true:&lt;br /&gt;
yesno(&#039;yes&#039;)&lt;br /&gt;
yesno(&#039;y&#039;)&lt;br /&gt;
yesno(&#039;true&#039;)&lt;br /&gt;
yesno(&#039;t&#039;)&lt;br /&gt;
yesno(&#039;1&#039;)&lt;br /&gt;
yesno(1)&lt;br /&gt;
yesno(true)&lt;br /&gt;
&lt;br /&gt;
-- These always return false:&lt;br /&gt;
yesno(&#039;no&#039;)&lt;br /&gt;
yesno(&#039;n&#039;)&lt;br /&gt;
yesno(&#039;false&#039;)&lt;br /&gt;
yesno(&#039;f&#039;)&lt;br /&gt;
yesno(&#039;0&#039;)&lt;br /&gt;
yesno(0)&lt;br /&gt;
yesno(false)&lt;br /&gt;
&lt;br /&gt;
-- A nil value always returns nil:&lt;br /&gt;
yesno(nil)&lt;br /&gt;
&amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
String values are converted to lower case before they are matched:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;source lang=&amp;quot;lua&amp;quot;&amp;gt;&lt;br /&gt;
-- These always return true:&lt;br /&gt;
yesno(&#039;Yes&#039;)&lt;br /&gt;
yesno(&#039;YES&#039;)&lt;br /&gt;
yesno(&#039;yEs&#039;)&lt;br /&gt;
yesno(&#039;Y&#039;)&lt;br /&gt;
yesno(&#039;tRuE&#039;)&lt;br /&gt;
&lt;br /&gt;
-- These always return false:&lt;br /&gt;
yesno(&#039;No&#039;)&lt;br /&gt;
yesno(&#039;NO&#039;)&lt;br /&gt;
yesno(&#039;nO&#039;)&lt;br /&gt;
yesno(&#039;N&#039;)&lt;br /&gt;
yesno(&#039;fALsE&#039;)&lt;br /&gt;
&amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
You can specify a default value if yesno receives input other than that listed above. If you don&#039;t supply a default, the module will return &amp;lt;code&amp;gt;nil&amp;lt;/code&amp;gt; for these inputs.&lt;br /&gt;
&lt;br /&gt;
&amp;lt;source lang=&amp;quot;lua&amp;quot;&amp;gt;&lt;br /&gt;
-- These return nil:&lt;br /&gt;
yesno(&#039;foo&#039;)&lt;br /&gt;
yesno({})&lt;br /&gt;
yesno(5)&lt;br /&gt;
yesno(function() return &#039;This is a function.&#039; end)&lt;br /&gt;
&lt;br /&gt;
-- These return true:&lt;br /&gt;
yesno(&#039;foo&#039;, true)&lt;br /&gt;
yesno({}, true)&lt;br /&gt;
yesno(5, true)&lt;br /&gt;
yesno(function() return &#039;This is a function.&#039; end, true)&lt;br /&gt;
&lt;br /&gt;
-- These return &amp;quot;bar&amp;quot;:&lt;br /&gt;
yesno(&#039;foo&#039;, &#039;bar&#039;)&lt;br /&gt;
yesno({}, &#039;bar&#039;)&lt;br /&gt;
yesno(5, &#039;bar&#039;)&lt;br /&gt;
yesno(function() return &#039;This is a function.&#039; end, &#039;bar&#039;)&lt;br /&gt;
&amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Note that the blank string also functions this way:&lt;br /&gt;
&amp;lt;source lang=&amp;quot;lua&amp;quot;&amp;gt;&lt;br /&gt;
yesno(&#039;&#039;)        -- Returns nil.&lt;br /&gt;
yesno(&#039;&#039;, true)  -- Returns true.&lt;br /&gt;
yesno(&#039;&#039;, &#039;bar&#039;) -- Returns &amp;quot;bar&amp;quot;.&lt;br /&gt;
&amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Although the blank string usually evaluates to false in wikitext, it evaluates to true in Lua. This module prefers the Lua behaviour over the wikitext behaviour. If treating the blank string as false is important for your module, you will need to remove blank arguments at an earlier stage of processing.&amp;lt;includeonly&amp;gt;{{#ifeq:{{SUBPAGENAME}}|sandbox||&lt;br /&gt;
[[Category:Lua metamodules]]&lt;br /&gt;
}}&amp;lt;/includeonly&amp;gt;&lt;/div&gt;</summary>
		<author><name>Aron.hives@edubase.net</name></author>
	</entry>
	<entry>
		<id>https://edubase.wiki/index.php?title=Module:Arguments/doc&amp;diff=27284</id>
		<title>Module:Arguments/doc</title>
		<link rel="alternate" type="text/html" href="https://edubase.wiki/index.php?title=Module:Arguments/doc&amp;diff=27284"/>
		<updated>2018-11-12T22:47:03Z</updated>

		<summary type="html">&lt;p&gt;Aron.hives@edubase.net: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;{{High-use|22000000|all-pages = yes}}&lt;br /&gt;
{{Used in system}}&lt;br /&gt;
{{Module rating|p}}&lt;br /&gt;
&lt;br /&gt;
This module provides easy processing of arguments passed from #invoke. It is a meta-module, meant for use by other modules, and should not be called from #invoke directly. Its features include:&lt;br /&gt;
* Easy trimming of arguments and removal of blank arguments.&lt;br /&gt;
* Arguments can be passed by both the current frame and by the parent frame at the same time. (More details below.)&lt;br /&gt;
* Arguments can be passed in directly from another Lua module or from the debug console.&lt;br /&gt;
* Arguments are fetched as needed, which can help avoid (some) problems with {{tag|ref}} tags.&lt;br /&gt;
* Most features can be customized.&lt;br /&gt;
&lt;br /&gt;
== Basic use ==&lt;br /&gt;
&lt;br /&gt;
First, you need to load the module. It contains one function, named &amp;lt;code&amp;gt;getArgs&amp;lt;/code&amp;gt;.&lt;br /&gt;
&lt;br /&gt;
&amp;lt;source lang=&amp;quot;lua&amp;quot;&amp;gt;&lt;br /&gt;
local getArgs = require(&#039;Module:Arguments&#039;).getArgs&lt;br /&gt;
&amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
In the most basic scenario, you can use getArgs inside your main function. The variable &amp;lt;code&amp;gt;args&amp;lt;/code&amp;gt; is a table containing the arguments from #invoke. (See below for details.)&lt;br /&gt;
&lt;br /&gt;
&amp;lt;source lang=&amp;quot;lua&amp;quot;&amp;gt;&lt;br /&gt;
local getArgs = require(&#039;Module:Arguments&#039;).getArgs&lt;br /&gt;
local p = {}&lt;br /&gt;
&lt;br /&gt;
function p.main(frame)&lt;br /&gt;
	local args = getArgs(frame)&lt;br /&gt;
	-- Main module code goes here.&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
return p&lt;br /&gt;
&amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
However, the recommended practice is to use a function just for processing arguments from #invoke. This means that if someone calls your module from another Lua module you don&#039;t have to have a frame object available, which improves performance.&lt;br /&gt;
&lt;br /&gt;
&amp;lt;source lang=&amp;quot;lua&amp;quot;&amp;gt;&lt;br /&gt;
local getArgs = require(&#039;Module:Arguments&#039;).getArgs&lt;br /&gt;
local p = {}&lt;br /&gt;
&lt;br /&gt;
function p.main(frame)&lt;br /&gt;
	local args = getArgs(frame)&lt;br /&gt;
	return p._main(args)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p._main(args)&lt;br /&gt;
	-- Main module code goes here.&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
return p&lt;br /&gt;
&amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
If you want multiple functions to use the arguments, and you also want them to be accessible from #invoke, you can use a wrapper function.&lt;br /&gt;
&lt;br /&gt;
&amp;lt;source lang=&amp;quot;lua&amp;quot;&amp;gt;&lt;br /&gt;
local getArgs = require(&#039;Module:Arguments&#039;).getArgs&lt;br /&gt;
&lt;br /&gt;
local p = {}&lt;br /&gt;
&lt;br /&gt;
local function makeInvokeFunc(funcName)&lt;br /&gt;
	return function (frame)&lt;br /&gt;
		local args = getArgs(frame)&lt;br /&gt;
		return p[funcName](args)&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
p.func1 = makeInvokeFunc(&#039;_func1&#039;)&lt;br /&gt;
&lt;br /&gt;
function p._func1(args)&lt;br /&gt;
	-- Code for the first function goes here.&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
p.func2 = makeInvokeFunc(&#039;_func2&#039;)&lt;br /&gt;
&lt;br /&gt;
function p._func2(args)&lt;br /&gt;
	-- Code for the second function goes here.&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
return p&lt;br /&gt;
&amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
=== Options ===&lt;br /&gt;
&lt;br /&gt;
The following options are available. They are explained in the sections below.&lt;br /&gt;
&lt;br /&gt;
&amp;lt;source lang=&amp;quot;lua&amp;quot;&amp;gt;&lt;br /&gt;
local args = getArgs(frame, {&lt;br /&gt;
	trim = false,&lt;br /&gt;
	removeBlanks = false,&lt;br /&gt;
	valueFunc = function (key, value)&lt;br /&gt;
		-- Code for processing one argument&lt;br /&gt;
	end,&lt;br /&gt;
	frameOnly = true,&lt;br /&gt;
	parentOnly = true,&lt;br /&gt;
	parentFirst = true,&lt;br /&gt;
	wrappers = {&lt;br /&gt;
		&#039;Template:A wrapper template&#039;,&lt;br /&gt;
		&#039;Template:Another wrapper template&#039;&lt;br /&gt;
	},&lt;br /&gt;
	readOnly = true,&lt;br /&gt;
	noOverwrite = true&lt;br /&gt;
})&lt;br /&gt;
&amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
=== Trimming and removing blanks ===&lt;br /&gt;
&lt;br /&gt;
Blank arguments often trip up coders new to converting MediaWiki templates to Lua. In template syntax, blank strings and strings consisting only of whitespace are considered false. However, in Lua, blank strings and strings consisting of whitespace are considered true. This means that if you don&#039;t pay attention to such arguments when you write your Lua modules, you might treat something as true that should actually be treated as false. To avoid this, by default this module removes all blank arguments.&lt;br /&gt;
&lt;br /&gt;
Similarly, whitespace can cause problems when dealing with positional arguments. Although whitespace is trimmed for named arguments coming from #invoke, it is preserved for positional arguments. Most of the time this additional whitespace is not desired, so this module trims it off by default.&lt;br /&gt;
&lt;br /&gt;
However, sometimes you want to use blank arguments as input, and sometimes you want to keep additional whitespace. This can be necessary to convert some templates exactly as they were written. If you want to do this, you can set the &amp;lt;code&amp;gt;trim&amp;lt;/code&amp;gt; and &amp;lt;code&amp;gt;removeBlanks&amp;lt;/code&amp;gt; arguments to &amp;lt;code&amp;gt;false&amp;lt;/code&amp;gt;.&lt;br /&gt;
&lt;br /&gt;
&amp;lt;source lang=&amp;quot;lua&amp;quot;&amp;gt;&lt;br /&gt;
local args = getArgs(frame, {&lt;br /&gt;
	trim = false,&lt;br /&gt;
	removeBlanks = false&lt;br /&gt;
})&lt;br /&gt;
&amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
=== Custom formatting of arguments ===&lt;br /&gt;
&lt;br /&gt;
Sometimes you want to remove some blank arguments but not others, or perhaps you might want to put all of the positional arguments in lower case. To do things like this you can use the &amp;lt;code&amp;gt;valueFunc&amp;lt;/code&amp;gt; option. The input to this option must be a function that takes two parameters, &amp;lt;code&amp;gt;key&amp;lt;/code&amp;gt; and &amp;lt;code&amp;gt;value&amp;lt;/code&amp;gt;, and returns a single value. This value is what you will get when you access the field &amp;lt;code&amp;gt;key&amp;lt;/code&amp;gt; in the &amp;lt;code&amp;gt;args&amp;lt;/code&amp;gt; table.&lt;br /&gt;
&lt;br /&gt;
Example 1: this function preserves whitespace for the first positional argument, but trims all other arguments and removes all other blank arguments.&lt;br /&gt;
&amp;lt;source lang=&amp;quot;lua&amp;quot;&amp;gt;&lt;br /&gt;
local args = getArgs(frame, {&lt;br /&gt;
	valueFunc = function (key, value)&lt;br /&gt;
		if key == 1 then&lt;br /&gt;
			return value&lt;br /&gt;
		elseif value then&lt;br /&gt;
			value = mw.text.trim(value)&lt;br /&gt;
			if value ~= &#039;&#039; then&lt;br /&gt;
				return value&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
		return nil&lt;br /&gt;
	end&lt;br /&gt;
})&lt;br /&gt;
&amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Example 2: this function removes blank arguments and converts all arguments to lower case, but doesn&#039;t trim whitespace from positional parameters.&lt;br /&gt;
&amp;lt;source lang=&amp;quot;lua&amp;quot;&amp;gt;&lt;br /&gt;
local args = getArgs(frame, {&lt;br /&gt;
	valueFunc = function (key, value)&lt;br /&gt;
		if not value then&lt;br /&gt;
			return nil&lt;br /&gt;
		end&lt;br /&gt;
		value = mw.ustring.lower(value)&lt;br /&gt;
		if mw.ustring.find(value, &#039;%S&#039;) then&lt;br /&gt;
			return value&lt;br /&gt;
		end&lt;br /&gt;
		return nil&lt;br /&gt;
	end&lt;br /&gt;
})&lt;br /&gt;
&amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Note: the above functions will fail if passed input that is not of type &amp;lt;code&amp;gt;string&amp;lt;/code&amp;gt; or &amp;lt;code&amp;gt;nil&amp;lt;/code&amp;gt;. This might be the case if you use the &amp;lt;code&amp;gt;getArgs&amp;lt;/code&amp;gt; function in the main function of your module, and that function is called by another Lua module. In this case, you will need to check the type of your input. This is not a problem if you are using a function specially for arguments from #invoke (i.e. you have &amp;lt;code&amp;gt;p.main&amp;lt;/code&amp;gt; and &amp;lt;code&amp;gt;p._main&amp;lt;/code&amp;gt; functions, or something similar).&lt;br /&gt;
&lt;br /&gt;
{{cot|Examples 1 and 2 with type checking}}&lt;br /&gt;
Example 1:&lt;br /&gt;
&amp;lt;source lang=&amp;quot;lua&amp;quot;&amp;gt;&lt;br /&gt;
local args = getArgs(frame, {&lt;br /&gt;
	valueFunc = function (key, value)&lt;br /&gt;
		if key == 1 then&lt;br /&gt;
			return value&lt;br /&gt;
		elseif type(value) == &#039;string&#039; then&lt;br /&gt;
			value = mw.text.trim(value)&lt;br /&gt;
			if value ~= &#039;&#039; then&lt;br /&gt;
				return value&lt;br /&gt;
			else&lt;br /&gt;
				return nil&lt;br /&gt;
			end&lt;br /&gt;
		else&lt;br /&gt;
			return value&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
})&lt;br /&gt;
&amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Example 2:&lt;br /&gt;
&amp;lt;source lang=&amp;quot;lua&amp;quot;&amp;gt;&lt;br /&gt;
local args = getArgs(frame, {&lt;br /&gt;
	valueFunc = function (key, value)&lt;br /&gt;
		if type(value) == &#039;string&#039; then&lt;br /&gt;
			value = mw.ustring.lower(value)&lt;br /&gt;
			if mw.ustring.find(value, &#039;%S&#039;) then&lt;br /&gt;
				return value&lt;br /&gt;
			else&lt;br /&gt;
				return nil&lt;br /&gt;
			end&lt;br /&gt;
		else&lt;br /&gt;
			return value&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
})&lt;br /&gt;
&amp;lt;/source&amp;gt;&lt;br /&gt;
{{cob}}&lt;br /&gt;
&lt;br /&gt;
Also, please note that the &amp;lt;code&amp;gt;valueFunc&amp;lt;/code&amp;gt; function is called more or less every time an argument is requested from the &amp;lt;code&amp;gt;args&amp;lt;/code&amp;gt; table, so if you care about performance you should make sure you aren&#039;t doing anything inefficient with your code.&lt;br /&gt;
&lt;br /&gt;
=== Frames and parent frames ===&lt;br /&gt;
&lt;br /&gt;
Arguments in the &amp;lt;code&amp;gt;args&amp;lt;/code&amp;gt; table can be passed from the current frame or from its parent frame at the same time. To understand what this means, it is easiest to give an example. Let&#039;s say that we have a module called &amp;lt;code&amp;gt;Module:ExampleArgs&amp;lt;/code&amp;gt;. This module prints the first two positional arguments that it is passed.&lt;br /&gt;
&lt;br /&gt;
{{cot|Module:ExampleArgs code}}&lt;br /&gt;
&amp;lt;source lang=&amp;quot;lua&amp;quot;&amp;gt;&lt;br /&gt;
local getArgs = require(&#039;Module:Arguments&#039;).getArgs&lt;br /&gt;
local p = {}&lt;br /&gt;
&lt;br /&gt;
function p.main(frame)&lt;br /&gt;
	local args = getArgs(frame)&lt;br /&gt;
	return p._main(args)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p._main(args)&lt;br /&gt;
	local first = args[1] or &#039;&#039;&lt;br /&gt;
	local second = args[2] or &#039;&#039;&lt;br /&gt;
	return first .. &#039; &#039; .. second&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
return p&lt;br /&gt;
&amp;lt;/source&amp;gt;&lt;br /&gt;
{{cob}}&lt;br /&gt;
&lt;br /&gt;
&amp;lt;code&amp;gt;Module:ExampleArgs&amp;lt;/code&amp;gt; is then called by &amp;lt;code&amp;gt;Template:ExampleArgs&amp;lt;/code&amp;gt;, which contains the code &amp;lt;code&amp;gt;&amp;lt;nowiki&amp;gt;{{#invoke:ExampleArgs|main|firstInvokeArg}}&amp;lt;/nowiki&amp;gt;&amp;lt;/code&amp;gt;. This produces the result &amp;quot;firstInvokeArg&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
Now if we were to call &amp;lt;code&amp;gt;Template:ExampleArgs&amp;lt;/code&amp;gt;, the following would happen:&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; style=&amp;quot;width: 50em; max-width: 100%;&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! style=&amp;quot;width: 60%;&amp;quot; | Code&lt;br /&gt;
! style=&amp;quot;width: 40%;&amp;quot; | Result&lt;br /&gt;
|-&lt;br /&gt;
| &amp;lt;code&amp;gt;&amp;lt;nowiki&amp;gt;{{ExampleArgs}}&amp;lt;/nowiki&amp;gt;&amp;lt;/code&amp;gt;&lt;br /&gt;
| firstInvokeArg&lt;br /&gt;
|-&lt;br /&gt;
| &amp;lt;code&amp;gt;&amp;lt;nowiki&amp;gt;{{ExampleArgs|firstTemplateArg}}&amp;lt;/nowiki&amp;gt;&amp;lt;/code&amp;gt;&lt;br /&gt;
| firstInvokeArg&lt;br /&gt;
|-&lt;br /&gt;
| &amp;lt;code&amp;gt;&amp;lt;nowiki&amp;gt;{{ExampleArgs|firstTemplateArg|secondTemplateArg}}&amp;lt;/nowiki&amp;gt;&amp;lt;/code&amp;gt;&lt;br /&gt;
| firstInvokeArg secondTemplateArg&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
There are three options you can set to change this behaviour: &amp;lt;code&amp;gt;frameOnly&amp;lt;/code&amp;gt;, &amp;lt;code&amp;gt;parentOnly&amp;lt;/code&amp;gt; and &amp;lt;code&amp;gt;parentFirst&amp;lt;/code&amp;gt;. If you set &amp;lt;code&amp;gt;frameOnly&amp;lt;/code&amp;gt; then only arguments passed from the current frame will be accepted; if you set &amp;lt;code&amp;gt;parentOnly&amp;lt;/code&amp;gt; then only arguments passed from the parent frame will be accepted; and if you set &amp;lt;code&amp;gt;parentFirst&amp;lt;/code&amp;gt; then arguments will be passed from both the current and parent frames, but the parent frame will have priority over the current frame. Here are the results in terms of &amp;lt;code&amp;gt;Template:ExampleArgs&amp;lt;/code&amp;gt;:&lt;br /&gt;
&lt;br /&gt;
; frameOnly&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; style=&amp;quot;width: 50em; max-width: 100%;&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! style=&amp;quot;width: 60%;&amp;quot; | Code&lt;br /&gt;
! style=&amp;quot;width: 40%;&amp;quot; | Result&lt;br /&gt;
|-&lt;br /&gt;
| &amp;lt;code&amp;gt;&amp;lt;nowiki&amp;gt;{{ExampleArgs}}&amp;lt;/nowiki&amp;gt;&amp;lt;/code&amp;gt;&lt;br /&gt;
| firstInvokeArg&lt;br /&gt;
|-&lt;br /&gt;
| &amp;lt;code&amp;gt;&amp;lt;nowiki&amp;gt;{{ExampleArgs|firstTemplateArg}}&amp;lt;/nowiki&amp;gt;&amp;lt;/code&amp;gt;&lt;br /&gt;
| firstInvokeArg&lt;br /&gt;
|-&lt;br /&gt;
| &amp;lt;code&amp;gt;&amp;lt;nowiki&amp;gt;{{ExampleArgs|firstTemplateArg|secondTemplateArg}}&amp;lt;/nowiki&amp;gt;&amp;lt;/code&amp;gt;&lt;br /&gt;
| firstInvokeArg&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
; parentOnly&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; style=&amp;quot;width: 50em; max-width: 100%;&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! style=&amp;quot;width: 60%;&amp;quot; | Code&lt;br /&gt;
! style=&amp;quot;width: 40%;&amp;quot; | Result&lt;br /&gt;
|-&lt;br /&gt;
| &amp;lt;code&amp;gt;&amp;lt;nowiki&amp;gt;{{ExampleArgs}}&amp;lt;/nowiki&amp;gt;&amp;lt;/code&amp;gt;&lt;br /&gt;
| &lt;br /&gt;
|-&lt;br /&gt;
| &amp;lt;code&amp;gt;&amp;lt;nowiki&amp;gt;{{ExampleArgs|firstTemplateArg}}&amp;lt;/nowiki&amp;gt;&amp;lt;/code&amp;gt;&lt;br /&gt;
| firstTemplateArg&lt;br /&gt;
|-&lt;br /&gt;
| &amp;lt;code&amp;gt;&amp;lt;nowiki&amp;gt;{{ExampleArgs|firstTemplateArg|secondTemplateArg}}&amp;lt;/nowiki&amp;gt;&amp;lt;/code&amp;gt;&lt;br /&gt;
| firstTemplateArg secondTemplateArg&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
; parentFirst&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; style=&amp;quot;width: 50em; max-width: 100%;&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! style=&amp;quot;width: 60%;&amp;quot; | Code&lt;br /&gt;
! style=&amp;quot;width: 40%;&amp;quot; | Result&lt;br /&gt;
|-&lt;br /&gt;
| &amp;lt;code&amp;gt;&amp;lt;nowiki&amp;gt;{{ExampleArgs}}&amp;lt;/nowiki&amp;gt;&amp;lt;/code&amp;gt;&lt;br /&gt;
| firstInvokeArg&lt;br /&gt;
|-&lt;br /&gt;
| &amp;lt;code&amp;gt;&amp;lt;nowiki&amp;gt;{{ExampleArgs|firstTemplateArg}}&amp;lt;/nowiki&amp;gt;&amp;lt;/code&amp;gt;&lt;br /&gt;
| firstTemplateArg&lt;br /&gt;
|-&lt;br /&gt;
| &amp;lt;code&amp;gt;&amp;lt;nowiki&amp;gt;{{ExampleArgs|firstTemplateArg|secondTemplateArg}}&amp;lt;/nowiki&amp;gt;&amp;lt;/code&amp;gt;&lt;br /&gt;
| firstTemplateArg secondTemplateArg&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Notes:&lt;br /&gt;
# If you set both the &amp;lt;code&amp;gt;frameOnly&amp;lt;/code&amp;gt; and &amp;lt;code&amp;gt;parentOnly&amp;lt;/code&amp;gt; options, the module won&#039;t fetch any arguments at all from #invoke. This is probably not what you want.&lt;br /&gt;
# In some situations a parent frame may not be available, e.g. if getArgs is passed the parent frame rather than the current frame. In this case, only the frame arguments will be used (unless parentOnly is set, in which case no arguments will be used) and the &amp;lt;code&amp;gt;parentFirst&amp;lt;/code&amp;gt; and &amp;lt;code&amp;gt;frameOnly&amp;lt;/code&amp;gt; options will have no effect.&lt;br /&gt;
&lt;br /&gt;
=== Wrappers ===&lt;br /&gt;
&lt;br /&gt;
The &#039;&#039;wrappers&#039;&#039; option is used to specify a limited number of templates as &#039;&#039;wrapper templates&#039;&#039;, that is, templates whose only purpose is to call a module. If the module detects that it is being called from a wrapper template, it will only check for arguments in the parent frame; otherwise it will only check for arguments in the frame passed to getArgs. This allows modules to be called by either #invoke or through a wrapper template without the loss of performance associated with having to check both the frame and the parent frame for each argument lookup.&lt;br /&gt;
&lt;br /&gt;
For example, the only content of [[Template:Side box]] (excluding content in {{tag|noinclude}} tags) is &amp;lt;code&amp;gt;&amp;lt;nowiki&amp;gt;{{#invoke:Side box|main}}&amp;lt;/nowiki&amp;gt;&amp;lt;/code&amp;gt;. There is no point in checking the arguments passed directly to the #invoke statement for this template, as no arguments will ever be specified there. We can avoid checking arguments passed to #invoke by using the &#039;&#039;parentOnly&#039;&#039; option, but if we do this then #invoke will not work from other pages either. If this were the case, the {{para|text|Some text}} in the code &amp;lt;code&amp;gt;&amp;lt;nowiki&amp;gt;{{#invoke:Side box|main|text=Some text}}&amp;lt;/nowiki&amp;gt;&amp;lt;/code&amp;gt; would be ignored completely, no matter what page it was used from. By using the &amp;lt;code&amp;gt;wrappers&amp;lt;/code&amp;gt; option to specify &#039;Template:Side box&#039; as a wrapper, we can make &amp;lt;code&amp;gt;&amp;lt;nowiki&amp;gt;{{#invoke:Side box|main|text=Some text}}&amp;lt;/nowiki&amp;gt;&amp;lt;/code&amp;gt; work from most pages, while still not requiring that the module check for arguments on the [[Template:Side box]] page itself.&lt;br /&gt;
&lt;br /&gt;
Wrappers can be specified either as a string, or as an array of strings.&lt;br /&gt;
&lt;br /&gt;
&amp;lt;source lang=&amp;quot;lua&amp;quot;&amp;gt;&lt;br /&gt;
local args = getArgs(frame, {&lt;br /&gt;
	wrappers = &#039;Template:Wrapper template&#039;&lt;br /&gt;
})&lt;br /&gt;
&amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&amp;lt;source lang=&amp;quot;lua&amp;quot;&amp;gt;&lt;br /&gt;
local args = getArgs(frame, {&lt;br /&gt;
	wrappers = {&lt;br /&gt;
		&#039;Template:Wrapper 1&#039;,&lt;br /&gt;
		&#039;Template:Wrapper 2&#039;,&lt;br /&gt;
		-- Any number of wrapper templates can be added here.&lt;br /&gt;
	}&lt;br /&gt;
})&lt;br /&gt;
&amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Notes:&lt;br /&gt;
# The module will automatically detect if it is being called from a wrapper template&#039;s /sandbox subpage, so there is no need to specify sandbox pages explicitly.&lt;br /&gt;
# The &#039;&#039;wrappers&#039;&#039; option effectively changes the default of the &#039;&#039;frameOnly&#039;&#039; and &#039;&#039;parentOnly&#039;&#039; options. If, for example, &#039;&#039;parentOnly&#039;&#039; were explicitly set to false with &#039;&#039;wrappers&#039;&#039; set, calls via wrapper templates would result in both frame and parent arguments being loaded, though calls not via wrapper templates would result in only frame arguments being loaded.&lt;br /&gt;
# If the &#039;&#039;wrappers&#039;&#039; option is set and no parent frame is available, the module will always get the arguments from the frame passed to &amp;lt;code&amp;gt;getArgs&amp;lt;/code&amp;gt;.&lt;br /&gt;
&lt;br /&gt;
=== Writing to the args table ===&lt;br /&gt;
&lt;br /&gt;
Sometimes it can be useful to write new values to the args table. This is possible with the default settings of this module. (However, bear in mind that it is usually better coding style to create a new table with your new values and copy arguments from the args table as needed.)&lt;br /&gt;
&lt;br /&gt;
&amp;lt;source lang=&amp;quot;lua&amp;quot;&amp;gt;&lt;br /&gt;
args.foo = &#039;some value&#039;&lt;br /&gt;
&amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
It is possible to alter this behaviour with the &amp;lt;code&amp;gt;readOnly&amp;lt;/code&amp;gt; and &amp;lt;code&amp;gt;noOverwrite&amp;lt;/code&amp;gt; options. If &amp;lt;code&amp;gt;readOnly&amp;lt;/code&amp;gt; is set then it is not possible to write any values to the args table at all. If &amp;lt;code&amp;gt;noOverwrite&amp;lt;/code&amp;gt; is set, then it is possible to add new values to the table, but it is not possible to add a value if it would overwrite any arguments that are passed from #invoke.&lt;br /&gt;
&lt;br /&gt;
=== Ref tags ===&lt;br /&gt;
&lt;br /&gt;
This module uses [[mw:Extension:Scribunto/Lua reference manual#Metatables|metatables]] to fetch arguments from #invoke. This allows access to both the frame arguments and the parent frame arguments without using the &amp;lt;code&amp;gt;pairs()&amp;lt;/code&amp;gt; function. This can help if your module might be passed {{tag|ref}} tags as input.&lt;br /&gt;
&lt;br /&gt;
As soon as {{tag|ref}} tags are accessed from Lua, they are processed by the MediaWiki software and the reference will appear in the reference list at the bottom of the article. If your module proceeds to omit the reference tag from the output, you will end up with a phantom reference - a reference that appears in the reference list, but no number that links to it. This has been a problem with modules that use &amp;lt;code&amp;gt;pairs()&amp;lt;/code&amp;gt; to detect whether to use the arguments from the frame or the parent frame, as those modules automatically process every available argument.&lt;br /&gt;
&lt;br /&gt;
This module solves this problem by allowing access to both frame and parent frame arguments, while still only fetching those arguments when it is necessary. The problem will still occur if you use &amp;lt;code&amp;gt;pairs(args)&amp;lt;/code&amp;gt; elsewhere in your module, however.&lt;br /&gt;
&lt;br /&gt;
=== Known limitations ===&lt;br /&gt;
&lt;br /&gt;
The use of metatables also has its downsides. Most of the normal Lua table tools won&#039;t work properly on the args table, including the &amp;lt;code&amp;gt;#&amp;lt;/code&amp;gt; operator, the &amp;lt;code&amp;gt;next()&amp;lt;/code&amp;gt; function, and the functions in the table library. If using these is important for your module, you should use your own argument processing function instead of this module.&amp;lt;includeonly&amp;gt;{{#ifeq:{{SUBPAGENAME}}|sandbox||&lt;br /&gt;
[[Category:Lua metamodules]]&lt;br /&gt;
}}&amp;lt;/includeonly&amp;gt;&lt;/div&gt;</summary>
		<author><name>Aron.hives@edubase.net</name></author>
	</entry>
	<entry>
		<id>https://edubase.wiki/index.php?title=Template:Cot&amp;diff=27282</id>
		<title>Template:Cot</title>
		<link rel="alternate" type="text/html" href="https://edubase.wiki/index.php?title=Template:Cot&amp;diff=27282"/>
		<updated>2018-11-12T22:46:59Z</updated>

		<summary type="html">&lt;p&gt;Aron.hives@edubase.net: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;#REDIRECT [[Template:Collapse top]]&lt;br /&gt;
&amp;lt;noinclude&amp;gt;{{pp-template|small=yes}}&amp;lt;/noinclude&amp;gt;&lt;/div&gt;</summary>
		<author><name>Aron.hives@edubase.net</name></author>
	</entry>
	<entry>
		<id>https://edubase.wiki/index.php?title=Template:Cob&amp;diff=27280</id>
		<title>Template:Cob</title>
		<link rel="alternate" type="text/html" href="https://edubase.wiki/index.php?title=Template:Cob&amp;diff=27280"/>
		<updated>2018-11-12T22:46:59Z</updated>

		<summary type="html">&lt;p&gt;Aron.hives@edubase.net: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;#REDIRECT [[Template:Collapse bottom]]&lt;/div&gt;</summary>
		<author><name>Aron.hives@edubase.net</name></author>
	</entry>
	<entry>
		<id>https://edubase.wiki/index.php?title=Module:Navbox/doc&amp;diff=27278</id>
		<title>Module:Navbox/doc</title>
		<link rel="alternate" type="text/html" href="https://edubase.wiki/index.php?title=Module:Navbox/doc&amp;diff=27278"/>
		<updated>2018-11-12T22:46:59Z</updated>

		<summary type="html">&lt;p&gt;Aron.hives@edubase.net: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;{{#ifeq:{{FULLPAGENAME}}|Module:Navbox|{{High-risk| approximately 3600000 }}}}&lt;br /&gt;
{{module rating|protected}}&lt;br /&gt;
&lt;br /&gt;
This module implements the {{tl|Navbox}} template. Please see the template page for usage instructions.&lt;br /&gt;
&lt;br /&gt;
== Tracking/maintenance categories ==&lt;br /&gt;
* {{clc|Navigational boxes without horizontal lists}}&lt;br /&gt;
* {{clc|Navboxes using background colours}}&lt;br /&gt;
* {{clc|Potentially illegible navboxes}}&lt;br /&gt;
* {{clc|Navboxes using borders}}&lt;br /&gt;
&lt;br /&gt;
&amp;lt;includeonly&amp;gt;{{#ifeq:{{SUBPAGENAME}}|sandbox||&lt;br /&gt;
[[Category:Modules that add a tracking category]]&lt;br /&gt;
}}&amp;lt;/includeonly&amp;gt;&lt;/div&gt;</summary>
		<author><name>Aron.hives@edubase.net</name></author>
	</entry>
	<entry>
		<id>https://edubase.wiki/index.php?title=Module:Message_box/doc&amp;diff=27276</id>
		<title>Module:Message box/doc</title>
		<link rel="alternate" type="text/html" href="https://edubase.wiki/index.php?title=Module:Message_box/doc&amp;diff=27276"/>
		<updated>2018-11-12T22:46:59Z</updated>

		<summary type="html">&lt;p&gt;Aron.hives@edubase.net: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;{{High-use|6,323,224+|all-pages = yes}}&lt;br /&gt;
{{Used in system}}&lt;br /&gt;
{{module rating|p}}&lt;br /&gt;
&lt;br /&gt;
This is a meta-module that implements the message box templates {{tl|mbox}}, {{tl|ambox}}, {{tl|cmbox}}, {{tl|fmbox}}, {{tl|imbox}}, {{tl|ombox}}, and {{tl|tmbox}}. It is intended to be used from Lua modules, and should not be used directly from wiki pages. If you want to use this module&#039;s functionality from a wiki page, please use the individual message box templates instead.&lt;br /&gt;
&lt;br /&gt;
== Usage ==&lt;br /&gt;
&lt;br /&gt;
To use this module from another Lua module, first you need to load it.&lt;br /&gt;
&lt;br /&gt;
&amp;lt;source lang=&amp;quot;lua&amp;quot;&amp;gt;&lt;br /&gt;
local messageBox = require(&#039;Module:Message box&#039;)&lt;br /&gt;
&amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
To create a message box, use the &amp;lt;code&amp;gt;main&amp;lt;/code&amp;gt; function. It takes two parameters: the first is the box type (as a string), and the second is a table containing the message box parameters.&lt;br /&gt;
&lt;br /&gt;
&amp;lt;source lang=&amp;quot;lua&amp;quot;&amp;gt;&lt;br /&gt;
local box = messageBox.main( boxType, {&lt;br /&gt;
    param1 = param1,&lt;br /&gt;
    param2 = param2,&lt;br /&gt;
    -- More parameters...&lt;br /&gt;
})&lt;br /&gt;
&amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
There are seven available box types:&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
! Box type !! Template !! Purpose&lt;br /&gt;
|-&lt;br /&gt;
| &amp;lt;code&amp;gt;mbox&amp;lt;/code&amp;gt; || {{tl|mbox}} || For message boxes to be used in multiple namespaces&lt;br /&gt;
|-&lt;br /&gt;
| &amp;lt;code&amp;gt;ambox&amp;lt;/code&amp;gt; || {{tl|ambox}} || For article message boxes&lt;br /&gt;
|-&lt;br /&gt;
| &amp;lt;code&amp;gt;cmbox&amp;lt;/code&amp;gt; || {{tl|cmbox}} || For category message boxes&lt;br /&gt;
|-&lt;br /&gt;
| &amp;lt;code&amp;gt;fmbox&amp;lt;/code&amp;gt; || {{tl|fmbox}} || For interface message boxes&lt;br /&gt;
|-&lt;br /&gt;
| &amp;lt;code&amp;gt;imbox&amp;lt;/code&amp;gt; || {{tl|imbox}} || For file namespace message boxes&lt;br /&gt;
|-&lt;br /&gt;
| &amp;lt;code&amp;gt;tmbox&amp;lt;/code&amp;gt; || {{tl|tmbox}} || For talk page message boxes&lt;br /&gt;
|-&lt;br /&gt;
| &amp;lt;code&amp;gt;ombox&amp;lt;/code&amp;gt; || {{tl|ombox}} || For message boxes in other namespaces&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
See the template page of each box type for the available parameters.&lt;br /&gt;
&lt;br /&gt;
== Usage from #invoke ==&lt;br /&gt;
&lt;br /&gt;
As well as the &amp;lt;code&amp;gt;main&amp;lt;/code&amp;gt; function, this module has separate functions for each box type. They are accessed using the code &amp;lt;code&amp;gt;&amp;lt;nowiki&amp;gt;{{#invoke:Message box|mbox|...}}&amp;lt;/nowiki&amp;gt;&amp;lt;/code&amp;gt;, &amp;lt;code&amp;gt;&amp;lt;nowiki&amp;gt;{{#invoke:Message box|ambox|...}}&amp;lt;/nowiki&amp;gt;&amp;lt;/code&amp;gt;, etc. These will work when called from other modules, but they access code used to process arguments passed from #invoke, and so calling them will be less efficient than calling &amp;lt;code&amp;gt;main&amp;lt;/code&amp;gt;.&lt;br /&gt;
&lt;br /&gt;
== Technical details ==&lt;br /&gt;
&lt;br /&gt;
The module uses the same basic code for each of the templates listed above; the differences between each of them are configured using the data at [[Module:Message box/configuration]]. Here are the various configuration options and what they mean:&lt;br /&gt;
&lt;br /&gt;
* &amp;lt;code&amp;gt;types&amp;lt;/code&amp;gt; - a table containing data used by the type parameter of the message box. The table keys are the values that can be passed to the type parameter, and the table values are tables containing the class and the image used by that type.&lt;br /&gt;
* &amp;lt;code&amp;gt;default&amp;lt;/code&amp;gt; - the type to use if no value was passed to the type parameter, or if an invalid value was specified.&lt;br /&gt;
* &amp;lt;code&amp;gt;showInvalidTypeError&amp;lt;/code&amp;gt; - whether to show an error if the value passed to the type parameter was invalid.&lt;br /&gt;
* &amp;lt;code&amp;gt;allowBlankParams&amp;lt;/code&amp;gt; - usually blank values are stripped from parameters passed to the module. However, whitespace is preserved for the parameters included in the allowBlankParams table.&lt;br /&gt;
* &amp;lt;code&amp;gt;allowSmall&amp;lt;/code&amp;gt; - whether a small version of the message box can be produced with &amp;quot;small=yes&amp;quot;.&lt;br /&gt;
* &amp;lt;code&amp;gt;smallParam&amp;lt;/code&amp;gt; - a custom name for the small parameter. For example, if set to &amp;quot;left&amp;quot; you can produce a small message box using &amp;quot;small=left&amp;quot;.&lt;br /&gt;
* &amp;lt;code&amp;gt;smallClass&amp;lt;/code&amp;gt; - the class to use for small message boxes.&lt;br /&gt;
* &amp;lt;code&amp;gt;substCheck&amp;lt;/code&amp;gt; - whether to perform a subst check or not.&lt;br /&gt;
* &amp;lt;code&amp;gt;classes&amp;lt;/code&amp;gt; - an array of classes to use with the message box.&lt;br /&gt;
* &amp;lt;code&amp;gt;imageEmptyCell&amp;lt;/code&amp;gt; - whether to use an empty {{tag|td}} cell if there is no image set. This is used to preserve spacing for message boxes with a width of less than 100% of the screen.&lt;br /&gt;
* &amp;lt;code&amp;gt;imageEmptyCellStyle&amp;lt;/code&amp;gt; - whether empty image cells should be styled.&lt;br /&gt;
* &amp;lt;code&amp;gt;imageCheckBlank&amp;lt;/code&amp;gt; - whether &amp;quot;image=blank&amp;quot; results in no image being displayed.&lt;br /&gt;
* &amp;lt;code&amp;gt;imageSmallSize&amp;lt;/code&amp;gt; - usually, images used in small message boxes are set to 30x30px. This sets a custom size.&lt;br /&gt;
* &amp;lt;code&amp;gt;imageCellDiv&amp;lt;/code&amp;gt; - whether to enclose the image in a div enforcing a maximum image size.&lt;br /&gt;
* &amp;lt;code&amp;gt;useCollapsibleTextFields&amp;lt;/code&amp;gt; - whether to use text fields that can be collapsed, i.e. &amp;quot;issue&amp;quot;, &amp;quot;fix&amp;quot;, &amp;quot;talk&amp;quot;, etc. Currently only used in ambox.&lt;br /&gt;
* &amp;lt;code&amp;gt;imageRightNone&amp;lt;/code&amp;gt; - whether imageright=none results in no image being displayed on the right-hand side of the message box.&lt;br /&gt;
* &amp;lt;code&amp;gt;sectionDefault&amp;lt;/code&amp;gt; - the default name for the &amp;quot;section&amp;quot; parameter. Depends on &amp;lt;code&amp;gt;useCollapsibleTextFields&amp;lt;/code&amp;gt;.&lt;br /&gt;
* &amp;lt;code&amp;gt;allowMainspaceCategories&amp;lt;/code&amp;gt; - allow categorisation in the main namespace.&lt;br /&gt;
* &amp;lt;code&amp;gt;templateCategory&amp;lt;/code&amp;gt; - the name of a category to be placed on the template page.&lt;br /&gt;
* &amp;lt;code&amp;gt;templateCategoryRequireName&amp;lt;/code&amp;gt; - whether the &amp;lt;code&amp;gt;name&amp;lt;/code&amp;gt; parameter is required to display the template category.&lt;br /&gt;
* &amp;lt;code&amp;gt;templateErrorCategory&amp;lt;/code&amp;gt; - the name of the error category to be used on the template page.&lt;br /&gt;
* &amp;lt;code&amp;gt;templateErrorParamsToCheck&amp;lt;/code&amp;gt; - an array of parameter names to check. If any are absent, the &amp;lt;code&amp;gt;templateErrorCategory&amp;lt;/code&amp;gt; is applied to the template page.&lt;/div&gt;</summary>
		<author><name>Aron.hives@edubase.net</name></author>
	</entry>
</feed>