Module:Road data/browse
Appearance
From Wikipedia, the free encyclopedia
[画像:Ready for use] This module is rated as ready for general use. It has reached a mature form and is thought to be relatively bug-free and ready for use wherever appropriate. It is ready to mention on help pages and other Wikipedia resources as an option for new users to learn. To reduce server load and bad output, it should be improved by sandbox testing rather than repeated trial-and-error editing.
[画像:Protected] 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.
Warning 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.
The above documentation is transcluded from Module:Road data/browse/doc. (edit | history)
Editors can experiment in this module's sandbox (edit | diff) and testcases (edit) pages.
Subpages of this module.
Editors can experiment in this module's sandbox (edit | diff) and testcases (edit) pages.
Subpages of this module.
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