Changes
Jump to navigation
Jump to search
mLine 3:
Line 3:
− local messageBox = require('Module:Message box')
Line 44:
Line 43:
− local ret = ugsub(msg, '$([1-9][0-9]*)', getMessageVal) +
− return ret
Line 82:
Line 80:
− +
+
+
Line 129:
Line 129:
− --
− -- Messages:
− -- 'main-div-id' --> 'template-documentation'
− -- 'main-div-classes' --> 'template-documentation iezoomfix'
Line 140:
Line 136:
− -- This div tag is from {{documentation/start box}}, but moving it here
− -- so that we don't have to worry about unclosed tags.
− :attr('id', message('main-div-id')) +
− +
− :wikitext(p._startBox(args, env))
− :wikitext(p._content(args, env))
− +
+
+
+
+
+
+
+
+
+
− :wikitext(p._endBox(args, env))
− +
+
+
+
Line 164:
Line 167:
− +
− -- path-related data.+
Line 290:
Line 293:
− +
− +
− +
+
Line 318:
Line 322:
− +
Line 367:
Line 371:
− +
+
Line 410:
Line 415:
− +
− omargs.text = text +
− local ret = '<div style="clear: both;"></div>' +
− ret = ret .. messageBox.main('ombox', omargs)+
− return ret+
Line 423:
Line 428:
− +
− local title = env.title
− protectionLevels = env.protectionLevels
Line 433:
Line 436:
− mProtectionBanner = require('Module:Protection banner') +
− local reason = message('protection-reason-edit')+
− return mProtectionBanner._main{reason, small = true}+
− mProtectionBanner = require('Module:Protection banner') +
− return mProtectionBanner._main{action = 'move', small = true}+
+
Line 579:
Line 583:
− -- 'start-box-linkclasses' --> 'mw-editsection-like plainlinks'
− -- 'start-box-link-id' --> 'doc_editlinks'
Line 613:
Line 615:
− elseif subjectSpace == 10 then
− -- We are in the template or template talk namespaces.
− data.headingFontWeight = 'bold'
− data.headingFontSize = '125%'
− +
+
− data.linksClass = message('start-box-linkclasses') +
− +
Line 636:
Line 635:
− :css('padding-bottom', '3px') +
− +
− :css('margin-bottom', '1ex')
+
− :css('font-weight', data.headingFontWeight)
− :css('font-size', data.headingFontSize)
Line 700:
Line 697:
− -- Messages:
− -- 'fmbox-id' --> 'documentation-meta-data'
− -- 'fmbox-style' --> 'background-color: #ecfcf4'
− -- 'fmbox-textstyle' --> 'font-style: italic'
− --
− -- The HTML is generated by the {{fmbox}} template, courtesy of [[Module:Message box]].
Line 731:
Line 722:
− +
− local fmargs = {}
− fmargs.id = message('fmbox-id') -- Sets 'documentation-meta-data'
− fmargs.image = 'none'
− fmargs.style = message('fmbox-style') -- Sets 'background-color: #ecfcf4'
− fmargs.textstyle = message('fmbox-textstyle') -- 'font-style: italic;'
−
− -- Assemble the fmbox text field.
Line 748:
Line 732:
− +
− text = text .. '<br />'
Line 763:
Line 746:
− fmargs.text = text +
+
+
+
+
+
+
+
+
− +
Line 779:
Line 770:
− +
role=note for end box
-- Get required modules.
-- Get required modules.
local getArgs = require('Module:Arguments').getArgs
local getArgs = require('Module:Arguments').getArgs
-- Get the config table.
-- Get the config table.
end
end
return ugsub(msg, '$([1-9][0-9]*)', getMessageVal)
end
end
ret[#ret + 1] = select(i, ...)
ret[#ret + 1] = select(i, ...)
end
end
return '<small style="font-style: normal;">(' .. table.concat(ret, ' | ') .. ')</small>'
-- 'documentation-toolbar'
return '<span class="' .. message('toolbar-class') .. '">('
.. table.concat(ret, ' | ') .. ')</span>'
end
end
-- This function defines logic flow for the module.
-- This function defines logic flow for the module.
-- @args - table of arguments passed by the user
-- @args - table of arguments passed by the user
--]]
--]]
local env = p.getEnvironment(args)
local env = p.getEnvironment(args)
:wikitext(p.protectionTemplate(env))
:wikitext(p.protectionTemplate(env))
:wikitext(p.sandboxNotice(args, env))
:wikitext(p.sandboxNotice(args, env))
:tag('div')
:tag('div')
-- 'documentation-container'
:addClass(message('main-div-classes'))
:addClass(message('container'))
:newline()
:newline()
:tag('div')
:tag('div')
:css('clear', 'both') -- So right or left floating items don't stick out of the doc box.
-- 'documentation'
:addClass(message('main-div-classes'))
:newline()
:wikitext(p._startBox(args, env))
:wikitext(p._content(args, env))
:tag('div')
-- 'documentation-clear'
:addClass(message('clear'))
:done()
:newline()
:newline()
:done()
:done()
:wikitext(p._endBox(args, env))
:done()
:done()
:wikitext(p.addTrackingCategories(env))
:wikitext(p.addTrackingCategories(env))
return tostring(root)
-- 'Module:Documentation/styles.css'
return mw.getCurrentFrame():extensionTag (
'templatestyles', '', {src=cfg['templatestyles']
}) .. tostring(root)
end
end
function p.getEnvironment(args)
function p.getEnvironment(args)
--[[
--[[
-- Returns a table with information about the environment, including title objects and other namespace- or
-- Returns a table with information about the environment, including title
-- objects and other namespace- or path-related data.
-- @args - table of arguments passed by the user
-- @args - table of arguments passed by the user
--
--
function envFuncs.docSpace()
function envFuncs.docSpace()
-- The documentation namespace number. For most namespaces this is the same as the
-- The documentation namespace number. For most namespaces this is the
-- subject namespace. However, pages in the Article, File, MediaWiki or Category
-- same as the subject namespace. However, pages in the Article, File,
-- namespaces must have their /doc, /sandbox and /testcases pages in talk space.
-- MediaWiki or Category namespaces must have their /doc, /sandbox and
-- /testcases pages in talk space.
local subjectSpace = env.subjectSpace
local subjectSpace = env.subjectSpace
if subjectSpace == 0 or subjectSpace == 6 or subjectSpace == 8 or subjectSpace == 14 then
if subjectSpace == 0 or subjectSpace == 6 or subjectSpace == 8 or subjectSpace == 14 then
local compareUrl = mw.uri.fullUrl(
local compareUrl = mw.uri.fullUrl(
'Special:ComparePages',
'Special:ComparePages',
{page1 = templateTitle.prefixedText, page2 = sandboxTitle.prefixedText}
{ page1 = templateTitle.prefixedText, page2 = sandboxTitle.prefixedText}
)
)
return tostring(compareUrl)
return tostring(compareUrl)
local templateTitle = env.templateTitle
local templateTitle = env.templateTitle
local subjectSpace = env.subjectSpace
local subjectSpace = env.subjectSpace
if not (subjectSpace and title and sandboxTitle and templateTitle and mw.title.equals(title, sandboxTitle)) then
if not (subjectSpace and title and sandboxTitle and templateTitle
and mw.title.equals(title, sandboxTitle)) then
return nil
return nil
end
end
end
end
-- Add the sandbox to the sandbox category.
-- Add the sandbox to the sandbox category.
text = text .. makeCategoryLink(message('sandbox-category'))
omargs.text = text .. makeCategoryLink(message('sandbox-category'))
-- 'documentation-clear'
return '<div class="' .. message('clear') .. '"></div>'
.. require('Module:Message box').main('ombox', omargs)
end
end
-- 'protection-template' --> 'pp-template'
-- 'protection-template' --> 'pp-template'
-- 'protection-template-args' --> {docusage = 'yes'}
-- 'protection-template-args' --> {docusage = 'yes'}
local protectionLevels, mProtectionBanner
local protectionLevels = env.protectionLevels
if not protectionLevels then
if not protectionLevels then
return nil
return nil
if editProt then
if editProt then
-- The page is edit-protected.
-- The page is edit-protected.
return require('Module:Protection banner')._main{
message('protection-reason-edit'), small = true
}
elseif moveProt and moveProt ~= 'autoconfirmed' then
elseif moveProt and moveProt ~= 'autoconfirmed' then
-- The page is move-protected but not edit-protected. Exclude move
-- The page is move-protected but not edit-protected. Exclude move
-- protection with the level "autoconfirmed", as this is equivalent to
-- protection with the level "autoconfirmed", as this is equivalent to
-- no move protection at all.
-- no move protection at all.
return require('Module:Protection banner')._main{
action = 'move', small = true
}
else
else
return nil
return nil
-- 'file-namespace-heading' --> 'Summary'
-- 'file-namespace-heading' --> 'Summary'
-- 'other-namespaces-heading' --> 'Documentation'
-- 'other-namespaces-heading' --> 'Documentation'
-- 'testcases-create-link-display' --> 'create'
-- 'testcases-create-link-display' --> 'create'
--]=]
--]=]
if headingStyle then
if headingStyle then
data.headingStyleText = headingStyle
data.headingStyleText = headingStyle
else
else
data.headingFontSize = '150%'
-- 'documentation-heading'
data.headingClass = message('main-div-heading-class')
end
end
-- Data for the [view][edit][history][purge] or [create] links.
-- Data for the [view][edit][history][purge] or [create] links.
if links then
if links then
-- 'mw-editsection-like plainlinks'
data.linksId = message('start-box-link-id')
data.linksClass = message('start-box-link-classes')
data.links = links
data.links = links
end
end
local sbox = mw.html.create('div')
local sbox = mw.html.create('div')
sbox
sbox
-- 'documentation-startbox'
:css('border-bottom', '1px solid #aaa')
:addClass(message('start-box-class'))
:newline()
:newline()
:tag('span')
:tag('span')
:addClass(data.headingClass)
:cssText(data.headingStyleText)
:cssText(data.headingStyleText)
:wikitext(data.heading)
:wikitext(data.heading)
local links = data.links
local links = data.links
-- @env - environment table containing title objects, etc., generated with p.getEnvironment
-- @env - environment table containing title objects, etc., generated with p.getEnvironment
--
--
--]=]
--]=]
end
end
-- Assemble the arguments for {{fmbox}}.
-- Assemble the link box.
local text = ''
local text = ''
if linkBox then
if linkBox then
-- Add sandbox and testcases links.
-- Add sandbox and testcases links.
-- "Editors can experiment in this template's sandbox and testcases pages."
-- "Editors can experiment in this template's sandbox and testcases pages."
text = text .. (p.makeExperimentBlurb(args, env) or '')
text = text .. (p.makeExperimentBlurb(args, env) or '') .. '<br />'
if not args.content and not args[1] then
if not args.content and not args[1] then
-- "Please add categories to the /doc subpage."
-- "Please add categories to the /doc subpage."
end
end
end
end
local box = mw.html.create('div')
-- 'documentation-metadata'
box:attr('role', 'note')
:addClass(message('end-box-class'))
-- 'plainlinks'
:addClass(message('end-box-plainlinks'))
:wikitext(text)
:done()
return messageBox.main('fmbox', fmargs)
return '\n' .. tostring(box)
end
end
-- 'transcluded-from-blurb' -->
-- 'transcluded-from-blurb' -->
-- 'The above [[Wikipedia:Template documentation|documentation]]
-- 'The above [[Wikipedia:Template documentation|documentation]]
-- is [[Wikipedia:Transclusion|transcluded]] from $1.'
-- is [[Help:Transclusion|transcluded]] from $1.'
-- 'module-preload' --> 'Template:Documentation/preload-module-doc'
-- 'module-preload' --> 'Template:Documentation/preload-module-doc'
-- 'create-link-display' --> 'create'
-- 'create-link-display' --> 'create'