Module:Test: Difference between revisions

From Resonite Wiki
mNo edit summary
mNo edit summary
Line 42: Line 42:
   :tag( 'td' )
   :tag( 'td' )
   :attr('colspan', '3')
   :attr('colspan', '3')
  :attr('style', 'text-align: center; padding: 10px;' )
   :wikitext(frame.args.Category)
   :wikitext(frame.args.Category)



Revision as of 05:50, 13 January 2024

Documentation for this module may be created at Module:Test/doc

local p = {}

local typeColor = 
{
 User = '255, 128, 255',
 Impulse = '179, 255, 255',
 Boolean = '115, 115, 115'
}

local mt = {__index = function () return "0,0,0" end}
setmetatable(typeColor, mt)

function p.ProtoFlux( frame )
 local inputsDecode = mw.text.jsonDecode( frame.args.Inputs );
 local outputsDecode = mw.text.jsonDecode( frame.args.Outputs );

 local protofluxContainer = mw.html.create( 'table' )
 
 protofluxContainer
  :attr( 'cellspacing', '0px')
  :attr( 'style', 'color: white; background-color: #11151d;' )
  :attr( 'width', "256px" )
  :tag( 'tr' )
  :attr( 'style', 'height: 50px; background-color: #1a2a36;')
   :tag( 'th' )
    :attr('width', '15%')
    :done()
   :tag( 'th' )
    :attr('width', '70%')
    :wikitext(frame.args.Name)
    :done()
   :tag( 'th')
    :attr('width', '15%');

 local maxRows = math.max(#inputsDecode, #outputsDecode)
 for i=1,maxRows,1 do
  CreateIORow(protofluxContainer, inputsDecode[i], outputsDecode[i]);
 end
 
protofluxContainer
 :tag( 'tr' )
  :tag( 'td' )
   :attr('colspan', '3')
   :attr('style', 'text-align: center; padding: 10px;' )
   :wikitext(frame.args.Category)

 return tostring(protofluxContainer);

end

-- Each Input/Output row is really 2 rows high. 
function CreateIORow(Container, Input, Output)
 Container
  :tag( 'tr' )
  :attr( 'style', 'height: 36px;')
   :tag( 'td' ) -- The Input binding post
    :attr( 'rowspan', '2' )
    :attr( 'style', 'background-color: ' .. getIOColor(Input, 0.3) .. '; border: 5px solid ' .. getIOColor(Input, 1.0) .. '; border-left: none;')
    :done()
   :tag( 'td' ) -- The Input name
    :attr( 'style', 'text-align: left; border-right: 20px solid #11151d; border-bottom: 4px solid #11151d; border-top: 4px solid #11151d; background-color:' .. getIOColor(Input, 0.6) .. ';')
    :wikitext( Input and Input.Name or ' ' )
    :done()
   :tag( 'td' ) -- The Output binding post
    :attr( 'rowspan', '2' )
    :attr( 'style', 'background-color: ' .. getIOColor(Output, 0.3) .. '; border: 5px solid ' .. getIOColor(Output, 1.0) .. '; border-right: none;')
    :done()
   :done()
  :tag( 'tr')
  :attr( 'style', 'height: 36px;')
   :tag( 'td' )
    :attr( 'style', 'text-align: right; border-left: 20px solid #11151d; border-bottom: 4px solid #11151d; border-top: 4px solid #11151d; background-color: ' .. getIOColor(Output, 0.6) .. ';')
    :wikitext( Output and Output.Name or ' ' )
    :done()
   
end

function getIOColor(Connector, alpha)
 return (Connector and 'rgba(' .. typeColor[Connector.Type] .. ',' .. alpha .. ')' or 'rgba(0,0,0,0)')
end

return p