Módulu:Dates

De Wikipedia

La documentación pa esti módulu pue crease en Módulu:Dates/usu

local z = {}

local meses = {
       'xineru','febreru','marzu','abril','mayu','xunu','xunetu','agostu','setiembre','ochobre','payares','avientu'}

function z.NombreDelMes(mes)
  -- Función que devuelve'l nome del mes, onde mes ye un númberu ente 1 y 12. 
  -- Si nun ye asina devuélvese'l valor de mes.
  -- Por exemplu, 2  --> febreru
  --              02 --> febreru
  --              abril --> abril
  --              MAYU --> MAYU
   return meses[tonumber(mes)] or mes
end

function z.Fecha(frame)
    -- Función que formatea una data
    -- L'únicu parámetru obligatoriu ye l'añu o 3.
    -- Obtener los argumentos colos que se llama a la función

    local argumentos = {}
    local parent = {}
    if frame == mw.getCurrentFrame() then
        if   frame.args[3]  or frame.args["añu"]  then
    	    argumentos = frame.args
        else 
    	    parent = frame:getParent()
            argumentos = parent.args
        end 
    else
        argumentos = frame
    end
    
    local enlace = argumentos["enlace"] ~= "no"

    -- Obtener el día, el nome del mes y l'añu incluyendo pa los años negativos a.d.
    local dia = argumentos["día"] or argumentos[1] or ''    
    if dia ~='' then 
    	dia=tonumber(dia) or dia -- Eliminar ceros a la esquierda del día.
    end
    local mes = argumentos["mes"] or argumentos[2] or ''
    if mes~='' then 
    	mes =meses[tonumber(mes)] or mes 
    end
    local anyo=tonumber(argumentos["añu"] or argumentos[3]) or 0
    if anyo < 0 then
    	anyo = -anyo .. ' e. C.'
    end
    
    local calendario = ''
    
    if argumentos["calendario"] == 'xulianu' then
    	calendario = '<sup>[[Calendariu xulianu|xul.]]</sup>'
    end

    -- Formatiar la data dependiendo de si'l día, el mes o l'añu tán informaos
    if dia ~='' then
    	if enlace then
    	  return '[[' .. dia .. ' de ' .. mes .. ']] de [[' .. anyo .. ']]' .. calendario
    	else
    	  return dia .. ' de ' .. mes .. ' de ' .. anyo .. calendario
    	end
    elseif mes~='' then
        if argumentos["mayúscula"] == 'sí' then
            mes = mw.language.new('ast'):ucfirst(mes)
        end
        if enlace then
	    return  '[[' .. mes .. ']] de [[' .. anyo .. ']]'
	else
	    return  mes .. ' de ' .. anyo
	end
    elseif anyo ~= 0 then
        if enlace then
    	    return '[[' .. anyo .. ']]'
    	else
    	    return anyo
    	end
     end
 end
 function getNumeroMes(nombreMes)
     local numeroMes = ''
     local nombreMeses = { 
    	 ['01'] = 'xineru', ['02'] = 'febreru', ['03'] = 'marzu', ['04'] = 'abril', ['05'] = 'mayu', ['06'] = 'xunu', ['07'] =  'xunetu', ['08'] =  'agostu',
    	 ['09'] =  'setiembre', ['10'] = 'ochobre',  ['11'] =  'payares', ['12'] =  'avientu'
    	 }
     for k, n in pairs(nombreMeses) do
         if nombreMeses[k] == mw.ustring.lower(nombreMes) then
             numeroMes = k
         end
     end
     if numeroMes == nil or numeroMes == '' then
         numeroMes = '00' 
     end
     return numeroMes
 end
 
 function setString(cadena)
     local dia, mes, anno
     local error = '<strong class="error">Cadena de data non válida</strong>'
     local valorDia = mw.ustring.gsub(cadena,'(%d+) de %a+ del? %d+.*','%1')
     if valorDia == nil or valorDia == '' or mw.ustring.len(valorDia) > 2 or type(tonumber(valorDia)) ~= 'number' then 
         return error 
     else
         dia = mw.ustring.format('%02d', tonumber(valorDia))
     end
     local valorMes = getNumeroMes(mw.ustring.gsub(cadena,'%d+ de (%a+) del? %d+.*','%1'))
     if valorMes == '00' then
        return error 
     else
         mes = mw.ustring.format('%02d',tonumber(valorMes))
     end
     local valorAnno = mw.ustring.gsub(cadena,'%d+ de %a+ del? (%d+).*','%1')
     if valorAnno == nil or valorAnno == '' or type(tonumber(valorAnno)) ~= 'number' then
         return error
     else
        anno = mw.ustring.format('%04d',tonumber(valorAnno))
     end
     local newCadena = anno..mes..dia
     return newCadena
 end
 
 function z.Numerica(frame)
     return setString(frame.args[1])
 end

 
return z