Module:Road data/browse
Appearance
This module is subject to page protection. It is a highly visible module in use by a very large number of pages, or is substituted very frequently. Because vandalism or mistakes would affect many pages, and even trivial editing might cause substantial load on the servers, it is protected from editing. |
This Lua module is used on approximately 18,000 pages and changes may be widely noticed. Test changes in the module's /sandbox or /testcases subpages, or in your own module sandbox. Consider discussing changes on the talk page before implementing them. |
This module is used by Template:Infobox road (via Module:Infobox road), but can be used outside of the infobox. Also see Module:Road data/browsetable which can serve as a container for the output produced by the module.
This module powers many of the templates in Category:Browse templates. The unified documentation Template:Browse template documentation exists for those templates.
local p = {}
local format = mw.ustring.format
local roadDataModule = require("Module:Road data")
local function routeText(route)
local shieldText = roadDataModule.shield(route, nil, nil, nil, true)
local linkText = roadDataModule.link(route)
local result = mw.html.create("span"):css({display = "inline-block"})
result:wikitext(shieldText .. ' ' .. linkText)
return tostring(result)
end
local function previousRoute(route)
local cell = mw.html.create('td'):css({
["text-align"] = "left"
})
if not route.type or route.type == '' then
cell:wikitext(" ")
else
cell:wikitext("← " .. routeText(route))
end
return cell
end
local function nextRoute(route)
local cell = mw.html.create('td'):css({
direction = "rtl",
["text-align"] = "right"
})
if not route.type or route.type == '' then
cell:wikitext(" ")
else
cell:wikitext("→ " .. routeText(route))
end
return cell
end
function p._browse(route)
local country = route.country
local state = route.state or route.province
local county = route.county
local previousData = {
country = country, state = state, county = county,
type = route.previous_type, route = route.previous_route,
dab = route.previous_dab
}
local nextData = {
country = country, state = state, county = county,
type = route.next_type, route = route.next_route,
dab = route.next_dab
}
local previousRoute = previousRoute(previousData)
local nextRoute = nextRoute(nextData)
if previousData.typeerror or nextData.typeerror then
route.typeerror = true
end
local centerRoute = mw.html.create('td'):css({
["text-align"] = "center",
["white-space"] = "nowrap",
["padding-left"] = "3px",
["padding-right"] = "3px"
})
local route = route.browse_route
if route then
centerRoute:css("padding-left", "6px")
centerRoute:css("padding-right", "6px")
centerRoute:wikitext(format("'''%s'''", route))
end
local browseRow = mw.html.create('tr')
browseRow:node(previousRoute):node(centerRoute):node(nextRoute)
return tostring(browseRow)
end
function p.browse(frame)
-- Import module function to work with passed arguments
local getArgs = require('Module:Arguments').getArgs
local args = getArgs(frame)
args.browse_route = args.route
return p._browse(args)
end
return p