Editing Module:Navbar
The edit can be undone. Please check the comparison below to verify that this is what you want to do, and then publish the changes below to finish undoing the edit.
Latest revision | Your text | ||
Line 1: | Line 1: | ||
local p = {} | local p = {} | ||
local | local HtmlBuilder = require('Module:HtmlBuilder') | ||
function trim(s) | |||
return mw.ustring.match( s, "^%s*(.-)%s*$" ) | |||
end | end | ||
function error(s) | |||
local span = HtmlBuilder.create('span') | |||
span | |||
.addClass('error') | |||
.css('float', 'left') | |||
.css('white-space', 'nowrap') | |||
.wikitext('Error: ' .. s) | |||
return tostring(span) | |||
end | end | ||
function | function _navbar( args ) | ||
if not args[1] then | |||
return error('No name provided') | |||
end | |||
local title; | |||
local pageName = trim(args[1]) | |||
if mw.ustring.sub(pageName, 1, 1) == ':' then | |||
title = mw.title.new( mw.ustring.sub(pageName, 2) ); | |||
else | |||
title = mw.title.new( pageName, 'Template' ); | |||
end | |||
if not title then | |||
return error('Page does not exist') | |||
end | |||
local mainpage = title.fullText; | |||
local talkpage = title.talkPageTitle and title.talkPageTitle.fullText or '' | |||
local editurl = title:fullUrl( 'action=edit' ); | |||
local viewLink, talkLink, editLink = 'view', 'talk', 'edit' | |||
if args.mini then | |||
viewLink, talkLink, editLink = 'v', 't', 'e' | |||
end | |||
local div = HtmlBuilder.create( 'div' ) | |||
div | |||
.addClass( 'noprint' ) | |||
.addClass( 'plainlinks' ) | |||
.addClass( 'hlist' ) | |||
.addClass( 'navbar') | |||
.cssText( args.style ) | |||
if args.mini then div.addClass('mini') end | |||
if not (args.mini or args.plain) then | |||
div | |||
.tag( 'span' ) | |||
.css( 'word-spacing', 0 ) | |||
.cssText( args.fontstyle ) | |||
.wikitext( args.text or 'This box:' ) | |||
.wikitext( ' ' ) | |||
end | |||
if args.brackets then | |||
div | |||
.tag('span') | |||
.css('margin-right', '-0.125em') | |||
.cssText( args.fontstyle ) | |||
.wikitext( '[' ) | |||
.newline(); | |||
end | |||
local ul = div.tag('ul'); | |||
ul | |||
.tag( 'li' ) | |||
.addClass( 'nv-view' ) | |||
.wikitext( '[[' .. mainpage .. '|' ) | |||
.tag( 'span ' ) | |||
.attr( 'title', 'View this template' ) | |||
.cssText( args.fontstyle or '' ) | |||
.wikitext( viewLink ) | |||
.done() | |||
.wikitext( ']]' ) | |||
.done() | |||
.tag( 'li' ) | |||
.addClass( 'nv-talk' ) | |||
.wikitext( '[[' .. talkpage .. '|' ) | |||
.tag( 'span ' ) | |||
.attr( 'title', 'Discuss this template' ) | |||
.cssText( args.fontstyle or '' ) | |||
.wikitext( talkLink ) | |||
.done() | |||
.wikitext( ']]' ); | |||
if not args.noedit then | |||
ul | |||
.tag( 'li' ) | |||
.addClass( 'nv-edit' ) | |||
.wikitext( '[' .. editurl .. ' ' ) | |||
.tag( 'span ' ) | |||
.attr( 'title', 'Edit this template' ) | |||
.cssText( args.fontstyle or '' ) | |||
.wikitext( editLink ) | |||
.done() | |||
.wikitext( ']' ); | |||
end | |||
if args.brackets then | |||
div | |||
.tag('span') | |||
.css('margin-left', '-0.125em') | |||
.cssText( args.fontstyle or '' ) | |||
.wikitext( ']' ) | |||
.newline(); | |||
end | |||
return tostring(div) | |||
end | end | ||
function p.navbar(frame) | function p.navbar(frame) | ||
local origArgs | |||
-- If called via #invoke, use the args passed into the invoking template. | |||
-- Otherwise, for testing purposes, assume args are being passed directly in. | |||
if frame == mw.getCurrentFrame() then | |||
origArgs = frame:getParent().args | |||
else | |||
origArgs = frame | |||
end | |||
-- ParserFunctions considers the empty string to be false, so to preserve the previous | |||
-- behavior of {{navbar}}, change any empty arguments to nil, so Lua will consider | |||
-- them false too. | |||
args = {} | |||
for k, v in pairs(origArgs) do | |||
if v ~= '' then | |||
args[k] = v | |||
end | |||
end | |||
return _navbar(args) | |||
end | end | ||
return p | return p |