Module:Portal bar/sandbox: Difference between revisions

Content deleted Content added
sync
clean for readability
Line 3:
require('Module:No globals')
 
local getImageName = require( 'Module:Portal' ).image
local yesno = require( 'Module:Yesno' )
local p = {}
 
local function checkPortalExists(portal)
return not (mw.title.makeTitle(100, portal).id =~= 0)
end
local getImageName = require( 'Module:Portal' ).image
local yesno = require( 'Module:Yesno' )
 
local trackingEnabled = true
 
-- Check whether to do tracking in this namespace
-- Returns true unless the page is one of the banned namespaces
local function checkTrackingNamespaceisTrackedNamespace()
local thisPagethisPageNS = mw.title.getCurrentTitle().namespace
ifreturn (thisPage.namespacethisPageNS =~= 1) -- Talk
orand (thisPage.namespacethisPageNS =~= 2) -- User
orand (thisPage.namespacethisPageNS =~= 3) -- User talk
orand (thisPage.namespacethisPageNS =~= 5) -- Wikipedia talk
orand (thisPage.namespacethisPageNS =~= 7) -- File talk
orand (thisPage.namespacethisPageNS =~= 11) -- Template talk
orand (thisPage.namespacethisPageNS =~= 15) -- Category talk
orand (thisPage.namespacethisPageNS =~= 101) -- Portal talk
orand (thisPage.namespacethisPageNS =~= 109)118 -- Book talkDraft
orand (thisPage.namespacethisPageNS =~= 118)119 -- Draft talk
orand (thisPage.namespacethisPageNS =~= 119)829 -- DraftModule talk
or (thisPage.namespace == 829) -- Module talk
then
return false
end
return true
end
 
Line 37 ⟶ 31:
-- Returns false if the page title matches one of the banned strings
-- Otherwise returns true
local function checkTrackingPagenameisTrackedPagename()
local thisPagethisPageLC = mw.ustring.lower(mw.title.getCurrentTitle().text)
local match = string.match
local thisPageLC = mw.ustring.lower(thisPage.text)
ifreturn (string.match(thisPageLC, "/archive") ~== nil) then
if and (string.match(thisPageLC, "/doc") ~== nil) then
return false
if and (string.match(thisPageLC, "/test") ~== nil) then
end
if (string.match(thisPageLC, "/doc") ~= nil) then
return false
end
if (string.match(thisPageLC, "/test") ~= nil) then
return false
end
return true
end
 
 
-- Builds the portal bar used by {{portal bar}}.
function p._main( portals, args )
if #portals < 1 then return '' end -- Don't display a blank navbox if no portals were specified.
if #portals < 1 then return '' end
local nav = mw.html.create( 'div' )
Line 74 ⟶ 61:
end
local trackingEnabled = true
if (args.tracking == 'no') or (args.tracking == 'n') or (args.tracking == 'false') then
local tracking = args.tracking
trackingEnabled = false
if (args.tracking == 'no') or (args.tracking == 'n') or (args.tracking == 'false') thenor
end
not isTrackedNamespace() or not isTrackedPagename() then
if (checkTrackingNamespace() == false) then
trackingEnabled = false
end
if (checkTrackingPagename() == false) then
trackingEnabled = false
end
 
-- TODO: This used to say 'if no portals are specified', but we return early
-- If no portals have been specified, display an error and add the page to a tracking category.
-- above. Someone should check whether this is really 'portals[1]' or #portals < 0.
-- If the first portal is not specified,
-- If no portals have been specified, display an error and add the page to a tracking category.
if not portals[1] then
iflocal (args.nominimum == 'yes') or (args.nominimum == 'y') or (args.nominimum == 'true') then
-- if nominimum as~= been'yes' setand tonominimum yes~= (or'y' similar),and nominimum omit~= the'true' warningthen
root:tag('strong')
:addClass('error')
else
root :wikitext('<strong class="error">No portals specified: please specify at least one portal</strong>')
end
if (trackingEnabled) then
root:wikitext('[[Category:Portal templates without a parameter]]')
end
Line 98 ⟶ 85:
end
 
-- scan for nonexistent portals, if they exist remove them from the portals
-- table. If redlinks=yes, then don't remove
local portallen = #portals
-- traverse the list backwards to ensure that no portals are missed
-- (table.remove also moves down the portals in the list, so that the next
-- portal isn't checked if going fowards. going backwards allows us to
-- going backwards allows us to circumvent this issue
for i=portallen,1,-1 do
-- the use of pcall here catches any errors that may occour when
-- attempting to locate pages when the page name is invalid. if pcall
-- if pcall returns true, then rerun the function to find if the page exists
if not pcall(checkPortalExists, portals[i]) or not checkPortalExists(portals[i]) then
-- Getting here means a redlinked portal has been found
iflocal redlinks = (args.redlinks
if redlinks == 'yes') or (args.redlinks == 'y') or (args.redlinks == 'true') or (args.redlinks == 'include') then
-- if redlinks as been set to yes (or similar), add the cleanup
-- category and then break the loop before the portal is removed
-- from the list
if trackingEnabled then
nav:wikitext('[[Category:Portal templates with redlinked portals]]')
end
-- TODO: This looks buggy given the comment above; we will always
-- break if redlinks are yes, whether or not tracking is enabled
break
end
Line 119 ⟶ 115:
end
-- if the length of the table is different, then rows were removed from the
-- table, so portals were removed. If this is the case add the cleanup category
if not (portallen == #portals) then
if #portals == 0 then
if trackingEnabled then
Line 139 ⟶ 136:
:tag( 'li' )
:css( 'display', 'inline' )
:css( 'white-space', 'nowrap' )
:tag( 'span' ) -- Inline-block on inner span for IE6-7 compatibility.
:csstag( 'display', 'inline-blockspan' )
:css( 'white-spacemargin', 'nowrap0 0.5em' )
:tagwikitext( 'span' )string.format(
'[[File:css( 'margin%s|24x21px|alt=]]', '0getImageName{ 0.5em'portal )}
) )
:wikitext( string.format( '[[File:%s|24x21px|alt=]]', getImageName{ portal } ) )
:done()
:wikitext( string.format(
'[[Portal:%s|%s portal]]', portal, portal ) )
) )
end
Line 157 ⟶ 156:
-- Processes external arguments and sends them to the other functions.
function p.main( frame )
-- If called via #invoke, use the args passed into the invoking template, or
-- template, or the args passed to #invoke if any exist. Otherwise assume args are being
-- assume args are being passed directly in from the debug console or from another Lua module.
-- or from another Lua module.
local origArgs
if type( frame.getParent ) == 'function' then
Line 171 ⟶ 169:
origArgs = frame
end
-- Process the args to make an array of portal names that can be used with
-- ipairs. We need to use ipairs because we want to list all the portals in
-- all the portals in the order they were passed to the template, but we also want to be able
-- to deal with positional arguments passed explicitly, for example
-- passed explicitly, for example {{portal|2=Politics}}. The behaviour of ipairs is undefined if nil values are present, so we
-- are present, so we need to make sure they are all removed.
local portals, args = {}, {}
for k, v in pairs( origArgs ) do
if type( k ) == 'number' and type( v ) == 'string' then -- Make sure we have no non-string portal names.
if type( k ) == 'number' and type( v ) == 'string' then
if mw.ustring.find( v, '%S' ) then -- Remove blank values.
table.insert( portals, k )
Line 190 ⟶ 191:
table.sort( portals )
for i, v in ipairs( portals ) do
portals[ i ] = mw.text.trim( origArgs[ v ] ) -- Swap keys with values, trimming whitespace.
portals[ i ] = mw.text.trim( origArgs[ v ] )
end
return p._main( portals, args )