Content deleted Content added
BrandonXLF (talk | contribs) No edit summary |
BrandonXLF (talk | contribs) Restored revision 1241724286 by BrandonXLF (Restorer) |
||
(37 intermediate revisions by the same user not shown) | |||
Line 5:
local p = {}
-- Parameters that can be numbered
local function displayService(service, dest, dir)▼
local numeredParams = {
service = true,
dest = true,
note = true
}
-- Labels for platform types
local platformLabels = {
island = 'Island platform',
top = 'Side platform',
bottom = 'Side platform'
}
-- Generate the HTML to display a service
▲local function displayService(service, dest, note, dir)
if not service then return '' end
return '<div
'<div class="' .. (dir ~= 'left' and 'hidden' or '') .. '">←</div>' ..
'<div>' .. service .. (dest and ' toward ' .. dest or '') .. (note and ' ' .. note or '') .. '</div>' ..
(dir == 'right' and '<div>→</div>' or '') ..
'</div>'
end
-- Generate the HTML to display a track (one or more services)
local function displayTrack(floorPart)
return ''
end▼
floorPart.dest = floorPart.dest or {}
floorPart.note = floorPart.note or {}
local out = ''
for i = 1, floorPart.service.max do
out = out .. displayService(floorPart.service[i]
end
Line 21 ⟶ 48:
end
-- Generate the HTML to generate a "row" of the floor
local function displayFloorPart(floorPart, floorNum, partNum)
local out = ''
if floorPart.name then
elseif floorPart.platform then▼
out = out .. '<div style="grid-column: 1 / 3;">' .. floorPart.platform .. '</div>'▼
local prefix = floorNum .. '_' .. partNum .. '_'▼
out = out .. 'Invalid floor part! Must have either <code>' .. prefix .. 'name</code> or <code>' .. prefix .. 'platform</code>.'▼
end
if not platformLabels[floorPart.platform] then
▲end
return '<div class="part-error">Invalid platform type!</div>'
▲
platformLabels[floorPart.platform] ..
(floorPart.accessible and ' ' .. mw.getCurrentFrame():expandTemplate{ title = 'access icon' } or '') ..
(floorPart.note and ', ' .. floorPart.note or '') ..
'</div>'
end
local function displayFloor(stationFloor, num)▼
▲
end
out = out .. '<div>'▼
-- Generate the HTML to display a floor
▲local function displayFloor(stationFloor, num, last)
local out = '<div class="floor' .. (last and ' last' or '') .. '" style="grid-row: span ' .. stationFloor.count .. ';">' .. stationFloor.letter .. '</div>'
for i = 1, stationFloor.max do
Line 49 ⟶ 82:
end
return out
end
-- Create a table that can hold numbered arguments
tbl = tbl or {}
tbl.max = 0
tbl.count = 0
return tbl
end
-- Add an argument number to a table of numbered arguments
▲local function addArg(tbl, num)
local function addArg(tbl, num, value)
if num > tbl.max then
tbl.max = num
Line 58 ⟶ 102:
if not tbl[num] then
tbl[num] =
tbl.count = tbl.count + 1
end
end
-- Process an argument with the format level_part_param[paramNum]
local function processArg(out, level, part,
level = tonumber(level)
part = tonumber(part)
addArg(out, level, createArgTable())
addArg(out[level], part, {})
if
out[level][part
end
addArg(out[level][part][param], paramNum, value)
else
out[level][part][param] = value
Line 78 ⟶ 127:
end
-- Process the argument table
local function processArgs(args)
local out =
for i, v in pairs(args) do
if type(i) == 'number' then
addArg(out, i, createArgTable({ letter = v }))
▲ end
else
local level, part,
if level and part and param then
processArg(out, level, part,
end
end
Line 102 ⟶ 146:
end
-- Main function, called by wikitext
function p.main(frame)
local sortedArgs = processArgs(frame.args)
local out =
name = 'templatestyles',
args = { src = 'User:BrandonXLF/styles.css' }
}
▲ out = out .. '<div class="station-layout">'
for i = 1, sortedArgs.max do
out = out .. displayFloor(sortedArgs[i], i, i == sortedArgs.max)
end
return out .. '</div>'
end
|