Difference between revisions of "Module:Template translation"

From FIThydrowiki
Jump to navigation Jump to search
what>Guillom
m (fix named parameter)
what>Guillom
(\o/)
Line 18: Line 18:
 
      
 
      
 
     --[[ If the subpage is a valid language code, check if a translation of the
 
     --[[ If the subpage is a valid language code, check if a translation of the
         template exists in that language; if so, put it in langcode ]]
+
         template exists in that language; if so, put it in langcode.
   
+
        ]]
 +
 
 
     if ( mw.language.isKnownLanguageTag( subpage ) )
 
     if ( mw.language.isKnownLanguageTag( subpage ) )
 
     then
 
     then
Line 29: Line 30:
 
     end
 
     end
  
     -- Render the template
+
     -- Copy args pseudo-table to a proper table so we can feed it to expandTemplate
    return frame:expandTemplate{ title = template..langcode, args = frame.args }
 
   
 
end
 
 
 
 
 
function p.debug(frame)
 
   
 
    -- Copy args table so we can feed it to expandTemplate
 
 
     local arguments = {}
 
     local arguments = {}
 
     for k, v in pairs( frame.args ) do
 
     for k, v in pairs( frame.args ) do
 
         arguments[k] = v
 
         arguments[k] = v
 
     end
 
     end
 +
 +
    -- Render the template
 +
    return frame:expandTemplate{ title = template..langcode, args = arguments }
 
      
 
      
    return frame:expandTemplate{ title = frame.args['template'], args = arguments }
 
 
end
 
end
  
 
return p
 
return p

Revision as of 20:03, 24 May 2013

-- THIS IS ALPHA CODE. USE CAREFULLY.

local p = {}

function p.renderTranslatedTemplate(frame)

   --[[ If on a translation subpage (like Foobar/de), this function renders
       a given template in the same language, if the translation is available.
       Otherwise, the template is rendered in its default language, without
       modification.
       This is aimed at replacing the current implementation of Template:TNT.
       ]]
   
   local template = frame.args['template']
   local langcode = '/en'
   
   -- Get the last subpage
   local subpage = mw.title.getCurrentTitle().subpageText
   
   --[[ If the subpage is a valid language code, check if a translation of the
       template exists in that language; if so, put it in langcode.
       ]]
   if ( mw.language.isKnownLanguageTag( subpage ) )
   then
       local translation = mw.title.new( template..'/'..subpage, 'Template' )
       if ( translation.id ~= 0)
       then
           langcode='/'..subpage
       end
   end
   -- Copy args pseudo-table to a proper table so we can feed it to expandTemplate
   local arguments = {}
   for k, v in pairs( frame.args ) do
       arguments[k] = v
   end
   -- Render the template
   return frame:expandTemplate{ title = template..langcode, args = arguments }
   

end

return p