| This module is rated as ready for general use. It has reached a mature state, is considered relatively stable and bug-free, and may be used wherever appropriate. It can be mentioned on help pages and other Wikipedia resources as an option for new users. To minimise server load and avoid disruptive output, improvements should be developed through sandbox testing rather than repeated trial-and-error editing. |
| This module is currently protected from editing. See the protection policy and protection log for more details. Please discuss any changes on the talk page; you may submit an edit request to ask an administrator to make an edit if it is uncontroversial or supported by consensus. You may also request that this page be unprotected. |
| 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