Module:Documentation: Difference between revisions
Jump to navigation
Jump to search
m (update code comment according to Special:Diff/989669779) |
No edit summary |
||
(2 intermediate revisions by 2 users not shown) | |||
Line 1: | Line 1: | ||
-- | -- <nowiki> | ||
local dependencyList = require( 'Module:DependencyList' ) | |||
local yn = require( 'Module:Yesno' ) | |||
local | |||
local | |||
local p = {} | local p = {} | ||
function p.doc( frame ) | |||
local | local title = mw.title.getCurrentTitle() | ||
local args = frame:getParent().args | |||
-- | local page = args[1] or mw.ustring.gsub( title.fullText, '/doc$', '' ) | ||
local addDependencyList = yn( args.DependencyList or true ) | |||
local ret, cats, ret1, ret2, ret3 | |||
local onModule = title.namespace == 828 | |||
- | |||
-- | -- subpage header | ||
if title.subpageText == 'doc' then | |||
ret = mw.html.create( 'table' ) | |||
:addClass( 'messagebox' ) | |||
:addClass( 'info' ) | |||
:tag( 'tr' ) | |||
:tag( 'td' ) | |||
:css( 'width', '40px' ) | |||
:wikitext( '[[File:Information icon-grey.png|35px|centre|link=]]' ) | |||
:done() | |||
:tag( 'td' ) | |||
:tag( 'b' ) | |||
:wikitext( 'This is a documentation subpage for [[' .. page .. ']].' ) | |||
:done() | |||
:tag( 'div' ) | |||
:css({ ['font-size'] = '0.85em', ['line-height'] = '1.4em' }) | |||
:wikitext( | |||
string.format( | |||
'It contains usage information, categories, and other content that is not part of the original %s page.', | |||
onModule and 'module' or 'template' | |||
) | |||
) | |||
:done() | |||
:done() | |||
:done() | |||
:done() | |||
if title.namespace == 10 then -- Template namespace | |||
cats = '[[Category:Template documentation|' .. title.baseText .. ']]' | |||
ret2 = addDependencyList and dependencyList._main() or '' | |||
elseif title.namespace == 116 then -- Calculator namespace | |||
cats = '' | |||
ret2 = addDependencyList and dependencyList._main() or '' | |||
elseif title.namespace == 828 then -- Module namespace | |||
cats = '[[Category:Module documentation|' .. title.baseText .. ']]' | |||
ret2 = addDependencyList and dependencyList._main() or '' | |||
else | |||
cats = '' | |||
ret2 = '' | |||
end | |||
return tostring( ret ) .. ret2 .. cats | |||
end | |||
-- template header | |||
-- don't use mw.html as we aren't closing the main div tag | |||
ret1 = '<div class="documentation">' | |||
ret2 = mw.html.create( nil ) | |||
:tag( 'div' ) | |||
:addClass( 'doc-header documentation-header') | |||
:tag( 'span' ) | |||
:addClass( 'doc-title documentation-title' ) | |||
:wikitext( string.format('%s documentation', onModule and 'Module' or 'Template') ) | |||
:done() | |||
:done() | |||
:tag( 'div' ) | |||
:addClass( 'doc-transclusion documentation-subheader' ) | |||
:tag( 'span' ) | |||
:addClass( 'documentation-documentation' ) | |||
:wikitext( 'This documentation is transcluded from [[' .. page .. '/doc]]. ' ) | |||
:done() | |||
:tag( 'span' ) | |||
:addClass( 'doc-editlinks documentation-links plainlinks' ) | |||
:wikitext( | |||
'[[' .. tostring( mw.uri.fullUrl( page .. '/doc', {action='edit'} ) ) .. ' edit]] ' .. | |||
'[[' .. tostring( mw.uri.fullUrl( page .. '/doc', {action='history'} ) ) .. ' history]] ' .. | |||
'[<span class="jsPurgeLink">[' .. tostring( mw.uri.fullUrl( title.fullText, {action='purge'} ) ) .. ' purge]</span>]' | |||
) | |||
:done() | |||
:done() | |||
ret3 = addDependencyList and dependencyList._main() or '' | |||
return ret1 .. tostring( ret2 ) .. '<div class="documentation-content">' .. ret3 | |||
end | end | ||
return p | |||
p | |||
-- </nowiki> | |||
Latest revision as of 18:29, 4 October 2022
Module documentation
This documentation is transcluded from Module:Documentation/doc. [edit] [history] [purge]
Module:Documentation's function doc is invoked by Template:Documentation.
Module:Documentation requires Module:DependencyList.
Module:Documentation requires Module:Yesno.
Implements Template:Documentation for templates and modules.
-- <nowiki> local dependencyList = require( 'Module:DependencyList' ) local yn = require( 'Module:Yesno' ) local p = {} function p.doc( frame ) local title = mw.title.getCurrentTitle() local args = frame:getParent().args local page = args[1] or mw.ustring.gsub( title.fullText, '/doc$', '' ) local addDependencyList = yn( args.DependencyList or true ) local ret, cats, ret1, ret2, ret3 local onModule = title.namespace == 828 -- subpage header if title.subpageText == 'doc' then ret = mw.html.create( 'table' ) :addClass( 'messagebox' ) :addClass( 'info' ) :tag( 'tr' ) :tag( 'td' ) :css( 'width', '40px' ) :wikitext( '[[File:Information icon-grey.png|35px|centre|link=]]' ) :done() :tag( 'td' ) :tag( 'b' ) :wikitext( 'This is a documentation subpage for [[' .. page .. ']].' ) :done() :tag( 'div' ) :css({ ['font-size'] = '0.85em', ['line-height'] = '1.4em' }) :wikitext( string.format( 'It contains usage information, categories, and other content that is not part of the original %s page.', onModule and 'module' or 'template' ) ) :done() :done() :done() :done() if title.namespace == 10 then -- Template namespace cats = '[[Category:Template documentation|' .. title.baseText .. ']]' ret2 = addDependencyList and dependencyList._main() or '' elseif title.namespace == 116 then -- Calculator namespace cats = '' ret2 = addDependencyList and dependencyList._main() or '' elseif title.namespace == 828 then -- Module namespace cats = '[[Category:Module documentation|' .. title.baseText .. ']]' ret2 = addDependencyList and dependencyList._main() or '' else cats = '' ret2 = '' end return tostring( ret ) .. ret2 .. cats end -- template header -- don't use mw.html as we aren't closing the main div tag ret1 = '<div class="documentation">' ret2 = mw.html.create( nil ) :tag( 'div' ) :addClass( 'doc-header documentation-header') :tag( 'span' ) :addClass( 'doc-title documentation-title' ) :wikitext( string.format('%s documentation', onModule and 'Module' or 'Template') ) :done() :done() :tag( 'div' ) :addClass( 'doc-transclusion documentation-subheader' ) :tag( 'span' ) :addClass( 'documentation-documentation' ) :wikitext( 'This documentation is transcluded from [[' .. page .. '/doc]]. ' ) :done() :tag( 'span' ) :addClass( 'doc-editlinks documentation-links plainlinks' ) :wikitext( '[[' .. tostring( mw.uri.fullUrl( page .. '/doc', {action='edit'} ) ) .. ' edit]] ' .. '[[' .. tostring( mw.uri.fullUrl( page .. '/doc', {action='history'} ) ) .. ' history]] ' .. '[<span class="jsPurgeLink">[' .. tostring( mw.uri.fullUrl( title.fullText, {action='purge'} ) ) .. ' purge]</span>]' ) :done() :done() ret3 = addDependencyList and dependencyList._main() or '' return ret1 .. tostring( ret2 ) .. '<div class="documentation-content">' .. ret3 end return p -- </nowiki>