<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="en">
	<id>https://maruneko.autumns.page/mediawiki/index.php?action=history&amp;feed=atom&amp;title=Module%3AParliament_diagram</id>
	<title>Module:Parliament diagram - Revision history</title>
	<link rel="self" type="application/atom+xml" href="https://maruneko.autumns.page/mediawiki/index.php?action=history&amp;feed=atom&amp;title=Module%3AParliament_diagram"/>
	<link rel="alternate" type="text/html" href="https://maruneko.autumns.page/mediawiki/index.php?title=Module:Parliament_diagram&amp;action=history"/>
	<updated>2026-04-04T09:44:29Z</updated>
	<subtitle>Revision history for this page on the wiki</subtitle>
	<generator>MediaWiki 1.41.0</generator>
	<entry>
		<id>https://maruneko.autumns.page/mediawiki/index.php?title=Module:Parliament_diagram&amp;diff=6773&amp;oldid=prev</id>
		<title>Marie: 1 revision imported</title>
		<link rel="alternate" type="text/html" href="https://maruneko.autumns.page/mediawiki/index.php?title=Module:Parliament_diagram&amp;diff=6773&amp;oldid=prev"/>
		<updated>2024-11-07T01:59:39Z</updated>

		<summary type="html">&lt;p&gt;1 revision imported&lt;/p&gt;
&lt;table style=&quot;background-color: #fff; color: #202122;&quot; data-mw=&quot;interface&quot;&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;tr class=&quot;diff-title&quot; lang=&quot;en&quot;&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;← Older revision&lt;/td&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;Revision as of 20:59, 6 November 2024&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;4&quot; class=&quot;diff-notice&quot; lang=&quot;en&quot;&gt;&lt;div class=&quot;mw-diff-empty&quot;&gt;(No difference)&lt;/div&gt;
&lt;/td&gt;&lt;/tr&gt;
&lt;!-- diff cache key jth_wiki:diff:1.41:old-6772:rev-6773 --&gt;
&lt;/table&gt;</summary>
		<author><name>Marie</name></author>
	</entry>
	<entry>
		<id>https://maruneko.autumns.page/mediawiki/index.php?title=Module:Parliament_diagram&amp;diff=6772&amp;oldid=prev</id>
		<title>wikipedia&gt;Julio974fr: fixed conversion for some templates</title>
		<link rel="alternate" type="text/html" href="https://maruneko.autumns.page/mediawiki/index.php?title=Module:Parliament_diagram&amp;diff=6772&amp;oldid=prev"/>
		<updated>2023-09-20T12:07:54Z</updated>

		<summary type="html">&lt;p&gt;fixed conversion for some templates&lt;/p&gt;
&lt;p&gt;&lt;b&gt;New page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;require('strict')&lt;br /&gt;
local p = {}&lt;br /&gt;
local getArgs = require('Module:Arguments').getArgs&lt;br /&gt;
local errorCategory = '[[Category:Compilation error of the Parliamentary diagram template]]'&lt;br /&gt;
local getColor = require('Module:Political party').fetch&lt;br /&gt;
local dimx = 175&lt;br /&gt;
local dimr = 50&lt;br /&gt;
local dimc = 40&lt;br /&gt;
local limite = 2000&lt;br /&gt;
local bgcolor = &amp;quot;#fff&amp;quot;&lt;br /&gt;
&lt;br /&gt;
-- Error handler using xpcall, format the error&lt;br /&gt;
local function errhandler(msg)&lt;br /&gt;
	local cat = mw.title.getCurrentTitle().namespace == 0 and errorCategory or ''&lt;br /&gt;
	return string.format('&amp;lt;span class=&amp;quot;error&amp;quot;&amp;gt;%s&amp;lt;/span&amp;gt;%s', msg, cat)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- create a single array from string&lt;br /&gt;
local function agg(a,...)&lt;br /&gt;
    local args = {...}&lt;br /&gt;
    for _, s in ipairs(args) do&lt;br /&gt;
        table.insert(a, s)&lt;br /&gt;
    end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- get the party color from Module:Party color&lt;br /&gt;
-- a = party; b = optional color&lt;br /&gt;
local function color(a,b)&lt;br /&gt;
	local c = '#CCC'&lt;br /&gt;
	if (b) then&lt;br /&gt;
		c = b&lt;br /&gt;
	else&lt;br /&gt;
		c = getColor({a, &amp;quot;color&amp;quot;})&lt;br /&gt;
	end&lt;br /&gt;
	if string.sub(c,1,5) == '&amp;amp;#35;' then c = &amp;quot;#&amp;quot; .. string.sub(c, 6, 11) end&lt;br /&gt;
	return c&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- create circles&lt;br /&gt;
local function values(n)&lt;br /&gt;
	local totals= {4, 17, 36, 65, 100, 144, 196, 255, 322, 398, 480, 571, 670, 776, 891, 1013, 1143, 1281, 1427, 1580, 1743, 1911, 2089}&lt;br /&gt;
&lt;br /&gt;
   	local dots = 0&lt;br /&gt;
	local benches = 1&lt;br /&gt;
	local jj,rr,aa&lt;br /&gt;
&lt;br /&gt;
	-- searches for the amount of benches needed to show all the dots&lt;br /&gt;
   	while (n &amp;gt; totals[benches]) do&lt;br /&gt;
      benches = benches + 1&lt;br /&gt;
	end&lt;br /&gt;
	local dd = dimr/benches -- distance between the arches&lt;br /&gt;
	dimc = 0.7*dimr/benches -- size of the circles&lt;br /&gt;
	local list = {} -- list of dots&lt;br /&gt;
	-- calculate angle and radius of each dot&lt;br /&gt;
	for rg=0,benches-2 do&lt;br /&gt;
		rr = dimx - dd*(2*rg+1) -- radius&lt;br /&gt;
    	jj = math.floor((n/totals[benches])*math.pi/(2*math.asin(dd/rr)))+1 --n° dots&lt;br /&gt;
    	if (jj==1) then&lt;br /&gt;
      		dots = dots + 1&lt;br /&gt;
        	list[dots] = {0.5, rr}&lt;br /&gt;
    	else&lt;br /&gt;
        	for ps=0,jj-1 do&lt;br /&gt;
        		aa = ps/(jj-1)&lt;br /&gt;
        		dots = dots + 1&lt;br /&gt;
        		list[dots] = {aa,rr}&lt;br /&gt;
        	end&lt;br /&gt;
        end&lt;br /&gt;
	end&lt;br /&gt;
	-- dots left to place on an internal arch&lt;br /&gt;
    jj=n-dots&lt;br /&gt;
    rr= dimx - dd*(2*benches-1) -- radius&lt;br /&gt;
    if (jj==1) then&lt;br /&gt;
		dots = dots + 1&lt;br /&gt;
		list[dots] = {1/2, rr}&lt;br /&gt;
    else&lt;br /&gt;
    	for ps=0,jj-1 do&lt;br /&gt;
			aa=ps/(jj-1)&lt;br /&gt;
			dots = dots + 1&lt;br /&gt;
			list[dots] = {aa,rr}&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	-- order dots per increasing angle from the center&lt;br /&gt;
	table.sort(list, function(a,b) return ((a[1]&amp;lt;b[1]) or (a[1]==b[1] and a[2]&amp;lt;b[2])) end)&lt;br /&gt;
	return list&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- create the parliamentary arch&lt;br /&gt;
function p._parliament(args)&lt;br /&gt;
	local ss = {}&lt;br /&gt;
	local ss2 = {}&lt;br /&gt;
	local data = {}&lt;br /&gt;
	local num = 1&lt;br /&gt;
	local totalDots = 0&lt;br /&gt;
	local cap = args.caption or ''&lt;br /&gt;
	local show = tonumber(args.show) or 0&lt;br /&gt;
&lt;br /&gt;
	while (args['n'..num]) do&lt;br /&gt;
		if (tonumber(args['n'..num])) then&lt;br /&gt;
			data[num] = {&lt;br /&gt;
				n = args['n'..num] and tonumber(args['n'..num]),&lt;br /&gt;
				c = color(args['p'..num] or '', args['c'..num]),&lt;br /&gt;
				b = args['b'..num] or '-',&lt;br /&gt;
				p = args['p'..num] or 'Serie '..num&lt;br /&gt;
			}&lt;br /&gt;
			totalDots = totalDots + data[num].n&lt;br /&gt;
			num = num+1&lt;br /&gt;
		else&lt;br /&gt;
			error(string.format('Invalid value for n%d', num),2)&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	num = num - 1&lt;br /&gt;
	if (totalDots&amp;gt;limite) then&lt;br /&gt;
		error('Number of dots superior to the limit')&lt;br /&gt;
	elseif (totalDots&amp;lt;1) then&lt;br /&gt;
		error('No dots are indicated')&lt;br /&gt;
	end&lt;br /&gt;
	local dots = values(totalDots)&lt;br /&gt;
	local width = 2*dimx&lt;br /&gt;
	local height = dimx+dimc&lt;br /&gt;
	local scale = 1.0&lt;br /&gt;
	if (args['background']) then&lt;br /&gt;
		bgcolor = args['background']&lt;br /&gt;
	end&lt;br /&gt;
	if (args['width'] and tonumber(args['width'])) then&lt;br /&gt;
		width = tonumber(args['width'])&lt;br /&gt;
		scale = width/(2*dimx)&lt;br /&gt;
		height = (dimx+dimc)*scale&lt;br /&gt;
	elseif (args['height'] and tonumber(args['height'])) then&lt;br /&gt;
		height = tonumber(args['height'])&lt;br /&gt;
		scale = height/(dimx+dimc)&lt;br /&gt;
		width = 2*dimx*scale&lt;br /&gt;
	elseif (totalDots&amp;lt;29) then&lt;br /&gt;
		width = 280&lt;br /&gt;
		scale = width/(2*dimx)&lt;br /&gt;
		height = (dimx+dimc)*scale&lt;br /&gt;
	elseif (totalDots&amp;lt;101) then&lt;br /&gt;
		width = 300&lt;br /&gt;
		scale = width/(2*dimx)&lt;br /&gt;
		height = (dimx+dimc)*scale&lt;br /&gt;
	elseif (totalDots&amp;lt;281) then&lt;br /&gt;
		width = 350&lt;br /&gt;
		scale = width/(2*dimx)&lt;br /&gt;
		height = (dimx+dimc)*scale&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	-- TEMPORARY FIX WHILE THE GRAPH EXTENSION IS DISABLED --&lt;br /&gt;
	local seats_diagram = require('Module:Seats_diagram')&lt;br /&gt;
	args.width = width&lt;br /&gt;
	if true then return tostring(seats_diagram._parliament(args)) end&lt;br /&gt;
	---------------------------------------------------------&lt;br /&gt;
	&lt;br /&gt;
	local graph = {&lt;br /&gt;
		version = 2, width = width, height = height, padding = &amp;quot;no&amp;quot;,&lt;br /&gt;
		background = bgcolor,&lt;br /&gt;
		data = { },&lt;br /&gt;
		scales = {&lt;br /&gt;
			{ name = &amp;quot;x&amp;quot;, type = &amp;quot;linear&amp;quot;, range = &amp;quot;width&amp;quot;, zero = true, domainMin = 0, domainMax = 2*dimx },&lt;br /&gt;
			{ name = &amp;quot;y&amp;quot;, type = &amp;quot;linear&amp;quot;, range = &amp;quot;height&amp;quot;, zero = true, domainMin = 0, domainMax = dimx + dimc }&lt;br /&gt;
		},&lt;br /&gt;
		marks = { }&lt;br /&gt;
	}&lt;br /&gt;
	local ee = 0&lt;br /&gt;
	local values&lt;br /&gt;
	for i=1,num do&lt;br /&gt;
		values = {}&lt;br /&gt;
		for j=1,data[i].n do&lt;br /&gt;
			ee = ee + 1&lt;br /&gt;
			values[j] = {&lt;br /&gt;
				px = dimx-dots[ee][2]*math.cos(math.pi*dots[ee][1]),&lt;br /&gt;
				py = dimc+dots[ee][2]*math.sin(math.pi*dots[ee][1]),&lt;br /&gt;
			}&lt;br /&gt;
		end&lt;br /&gt;
		graph['data'][i] = { name = &amp;quot;tab&amp;quot;..i, values = values }&lt;br /&gt;
		graph['marks'][i] = { type = &amp;quot;symbol&amp;quot;, from = {data = &amp;quot;tab&amp;quot;..i },&lt;br /&gt;
			properties = {&lt;br /&gt;
				enter = {&lt;br /&gt;
					x = {scale = &amp;quot;x&amp;quot;,field = &amp;quot;px&amp;quot;},&lt;br /&gt;
					y = {scale = &amp;quot;y&amp;quot;,field = &amp;quot;py&amp;quot;},&lt;br /&gt;
					fill = {value = data[i].c},&lt;br /&gt;
					size = {value = (2*dimc*scale)^2}&lt;br /&gt;
				}&lt;br /&gt;
			}&lt;br /&gt;
		}&lt;br /&gt;
		if (data[i].b ~= &amp;quot;-&amp;quot;) then&lt;br /&gt;
			local bl = data[i].b&lt;br /&gt;
			if string.sub(bl,1,5) == '&amp;amp;#35;' then bl = &amp;quot;#&amp;quot; .. string.sub(bl, 6, 11) end&lt;br /&gt;
			graph['marks'][i]['properties']['enter']['stroke'] = {value = bl}&lt;br /&gt;
			graph['marks'][i]['properties']['enter']['strokeWidth'] = {value = 1}&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	graph['marks'][num+1] = {&lt;br /&gt;
		type = &amp;quot;text&amp;quot;,&lt;br /&gt;
		properties = {&lt;br /&gt;
			enter = {&lt;br /&gt;
				x = {scale = &amp;quot;x&amp;quot;,value=dimx},&lt;br /&gt;
				y = {scale = &amp;quot;y&amp;quot;,value=dimc+8},&lt;br /&gt;
				align = {value = &amp;quot;center&amp;quot;},&lt;br /&gt;
				fill = {value = &amp;quot;#000&amp;quot;},&lt;br /&gt;
				font = {value = &amp;quot;Helvetica&amp;quot;},&lt;br /&gt;
				fontSize = { value = 36*scale },&lt;br /&gt;
				fontWeight = { value = &amp;quot;bold&amp;quot; },&lt;br /&gt;
				text = {value = totalDots }&lt;br /&gt;
			}&lt;br /&gt;
		}&lt;br /&gt;
	}&lt;br /&gt;
	agg(ss, mw.getCurrentFrame():extensionTag('graph', mw.text.jsonEncode(graph)))&lt;br /&gt;
	if (cap ~= '') then&lt;br /&gt;
		agg(ss,string.format('&amp;lt;p style=&amp;quot;font-size:90%%; margin-left:10px&amp;quot;&amp;gt;%s&amp;lt;/p&amp;gt;',cap))&lt;br /&gt;
	end&lt;br /&gt;
	if show == 1 then&lt;br /&gt;
		for i=1,num do&lt;br /&gt;
			agg(ss2,string.format('&amp;lt;span style=&amp;quot;display:inline-block;border:solid grey 1px;background:%s;width:1em;height:1em&amp;quot;&amp;gt;&amp;amp;nbsp;&amp;lt;/span&amp;gt;&amp;amp;nbsp;%s', data[i].c, data[i].n))&lt;br /&gt;
		end&lt;br /&gt;
		agg(ss,'&amp;lt;p style=&amp;quot;font-size:90%; margin-left:10px&amp;quot;&amp;gt;')&lt;br /&gt;
		agg(ss,table.concat(ss2,&amp;quot; · &amp;quot;))&lt;br /&gt;
		agg(ss,'&amp;lt;/p&amp;gt;')&lt;br /&gt;
	elseif show ==2 then&lt;br /&gt;
		for i=1,num do&lt;br /&gt;
			agg(ss2,string.format('&amp;lt;span style=&amp;quot;display:inline-block;border:solid grey 1px;background:%s;width:1em;height:1em&amp;quot;&amp;gt;&amp;amp;nbsp;&amp;lt;/span&amp;gt;&amp;amp;nbsp;%s %s', data[i].c, data[i].p, data[i].n))&lt;br /&gt;
		end&lt;br /&gt;
		agg(ss,'&amp;lt;p style=&amp;quot;font-size:90%; margin-left:10px&amp;quot;&amp;gt;')&lt;br /&gt;
		agg(ss,table.concat(ss2,&amp;quot;&amp;lt;br/&amp;gt;&amp;quot;))&lt;br /&gt;
		agg(ss,'&amp;lt;/p&amp;gt;')&lt;br /&gt;
	end&lt;br /&gt;
	if args['debug'] then&lt;br /&gt;
		return mw.text.jsonEncode(graph)&lt;br /&gt;
	else&lt;br /&gt;
		return table.concat(ss)&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.parliament(frame)&lt;br /&gt;
	return select(2, xpcall(function()&lt;br /&gt;
		return p._parliament(getArgs(frame, { parentOnly = true }))&lt;br /&gt;
	end, errhandler))&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
return p&lt;/div&gt;</summary>
		<author><name>wikipedia&gt;Julio974fr</name></author>
	</entry>
</feed>