Modul:Vorlage:FormatDate
Version vom 2. Juni 2013, 18:53 Uhr von te>Antonsusi
Die Dokumentation für dieses Modul kann unter Modul:Vorlage:FormatDate/Doku erstellt werden
local p = {}
-- Trennen der Parameter
local function Split(str)
local Datum = {}
local Teil=""
local pos = 0
Datum.y = 0
Datum.m = 0
Datum.d = 0
pos = mw.ustring.find(str,'-',1,true);
if pos == 1 then -- Minuszeichen am Anfang - nochmal suchen
pos = mw.ustring.find(str,'-',2,true);
end
if not pos then
Datum.y = tonumber(str) or 'x'
return false, Datum -- Kein Wert erkennbar
end
Teil = mw.ustring.sub(str,1,pos-1)
Datum.y = tonumber(Teil) or 'x'
str = mw.ustring.sub(str,pos+1, -1)
pos = mw.ustring.find(str,'-',1,true);
if not pos or pos == 0 then
return true, Datum -- Nur Jahr
end
Teil = mw.ustring.sub(str,1,pos-1)
Datum.m = tonumber(Teil) or 0
Teil = mw.ustring.sub(str,pos+1, -1)
if #Teil == 0 then
return true, Datum -- Nur Jahr und Monat
end
if Datum.m == 0 then
Datum.d = 0
else
Datum.d = tonumber(Teil) or 0
end
return true, Datum
end
--
local function CheckDate(Date)
if ( Date.m == 4 or Date.m == 6 or Date.m == 9 or Date.m == 11) and Date.d > 30 then
return false;
end
if Date.m == 2 then -- Die greg. Sonderregeln werden ignoriert.
if Date.y % 4 ~= 0 and Date.d > 28 then return false; end
if Date.y % 4 == 0 and Date.d > 29 then return false; end
end
-- Hier nur noch 31-Tage-Monate übrig.
if Date.d > 31 then return false; end
return true;
end
--
local function Run(Args)
local T_F = {"Januar","Februar", "März", "April", "Mai","Juni", "Juli", "August","September","Oktober","November","Dezember","Jänner"}
local T_M = {"Jan.","Feb.", "Mrz", "Apr.", "Mai","Jun.", "Jul.", "Aug.","Sep.","Okt.","Nov.","Dez.","Jän."}
local T_S = {"Jan.","Feb.", "März", "Apr.", "Mai","Juni", "Juli", "Aug.","Sep.","Okt.","Nov.","Dez.","Jän."}
local Text = "";
local AT = false;
local NBSP = false;
local LINK = false;
local VCHR = "";
local STIL = 'F';
local IsOk = true
local Tbl = {}
local SortIt = false;
if mw.ustring.lower(Args[2] or "") == "nbsp" or mw.ustring.lower(Args[3] or "") == "nbsp" or mw.ustring.lower(Args[4] or "") == "nbsp" then NBSP = true; end
if mw.ustring.lower(Args[2] or "") == "link" or mw.ustring.lower(Args[3] or "") == "link" or mw.ustring.lower(Args[4] or "") == "link" then LINK = true; end
if mw.ustring.upper(Args[2] or "") == "M" or mw.ustring.upper(Args[3] or "") == "M" or mw.ustring.upper(Args[4] or "") == "M" then STIL = 'M'; end
if mw.ustring.upper(Args[2] or "") == "S" or mw.ustring.upper(Args[3] or "") == "S" or mw.ustring.upper(Args[4] or "") == "S" then STIL = 'S'; end
if mw.ustring.lower(Args['AT'] or "") == "ja" then AT = true; end
if mw.ustring.lower(Args['Sort'] or "") ~= "" then SortIt = true; end
IsOk, Tbl = Split(Args[1])
if Tbl.y == 'x' then
Text = '<span class="error">[[Vorlage:FormatDate]]: Ungültiger Wert für Jahr!</span>'
return Text
end
if Tbl.m > 12 or Tbl.m < 0 then
Text = '<span class="error">[[Vorlage:FormatDate]]: Ungültiger Wert für Monat!</span>'
return Text
end
if Tbl.y <= 0 then
Tbl.y = 1 - Tbl.y
VCHR = " v. Chr.";
end
if Tbl.d > 0 then
if CheckDate(Tbl) then
Text = tostring(Tbl.d) .. '. '
else
Text = '<span class="error">[[Vorlage:FormatDate]]: Ungültiges Datum!'.. table.concat(Tbl,'.')..'</span>'
return Text
end
end
if Tbl.m > 0 then
if LINK then
if Tbl.d == 0 then
Linkziel =T_F[Tbl.m]
else
Linkziel = tostring(Tbl.d) .. ". " .. T_F[Tbl.m]
end
end
if AT and Tbl.m == 1 then
Tbl.m = 13
end
if STIL == 'M' then
Text = Text .. T_M[Tbl.m]
elseif STIL == 'S' then
Text = Text .. T_S[Tbl.m]
else
Text = Text .. T_F[Tbl.m]
end
if LINK then
Text = "[[" .. Linkziel .. "|" .. Text .. "]]"
end
if NBSP then
Text = Text .. " "
else
Text = Text .. " "
end
end
if LINK then
Text = Text .. "[[" .. tostring(Tbl.y) .. VCHR .. "]]"
else
Text = Text .. tostring(Tbl.y) .. VCHR
end
if SortIt then
if Tbl.m == 13 then Tbl.m = 1 end
if tonumber(Tbl.y) and tonumber(Tbl.m) and tonumber(Tbl.d) then
local Numstr = string.format('%d%2.2d%2.2d',5000+Tbl.y,Tbl.m,Tbl.d)
local SortTag='<span style="display:none" class="sortkey">' .. Numstr .. '</span>'
Text = SortTag .. Text
end
end
return Text
end
--
function p.Execute(frame)
local FR = frame:getParent()
return Run(FR.args)
end
function p.Sort(frame)
local FR = frame:getParent()
FR.args.Sort='1'
return Run(FR.args)
end
return p