မဝ်ဂျူ:One page calendar
Documentation for this module may be created at မဝ်ဂျူ:One page calendar/doc
require ('strict');
local getArgs = require ('Module:Arguments').getArgs
-- sequence to hold abbreviated month names where first-of-month is on day
local first_day_t = { -- lang_object:formatDate ('L', 'YYYY-01-01') + 1 returns 1 (Sunday) to 7 (Saturday)
{}, -- table of months that begin on sunday
{}, -- table of months that begin on monday
{}, -- tuesday
{}, -- wednesday
{}, -- thursday
{}, -- friday
{}, -- saturday
}
local subheader_rows_t = { -- will get abbreviated month names for each of the days of the week
{}, -- these are the first three 'subheader' rows at the top of the wikitable; top
{}, -- middle
{}, -- bottom
}
local week_day_names_t = { -- for i18n though Help:Extension:ParserFunctions##time says day names rarely internationalized
['sun_t'] = {}, -- holds calculated weekday names: [1]=<abbreviated>, [2]=<long>, [3]=<abbr title="<long>"><addreviated></abbr>
['mon_t'] = {}, -- if your MediaWiki does not have weekday names for your language, these tables can be filled manually
['tue_t'] = {},
['wed_t'] = {},
['thu_t'] = {},
['fri_t'] = {},
['sat_t'] = {},
}
local row_format_str = '|| %s || %s || %s || %s || %s || %s || %s '; -- format string for the three subheader rows
local weekday_rows_fmt_t = { -- format strings for weekday wikitable rows
'| 1 || 8 || 15 || 22 || 29 || %s || %s || %s || %s || %s || %s || %s',
'| 2 || 9 || 16 || 23 || 30 || %s || %s || %s || %s || %s || %s || %s',
'| 3 || 10 || 17 || 24 || 31 || %s || %s || %s || %s || %s || %s || %s',
'| 4 || 11 || 18 || 25 || || %s || %s || %s || %s || %s || %s || %s',
'| 5 || 12 || 19 || 26 || || %s || %s || %s || %s || %s || %s || %s',
'| 6 || 13 || 20 || 27 || || %s || %s || %s || %s || %s || %s || %s',
'| 7 || 14 || 21 || 28 || || %s || %s || %s || %s || %s || %s || %s',
}
local caption_fmt = 'Calendar for year with 1 %s on a %s'; -- first %s is 'January' in local language; second %s is day name in local language
--[[--------------------------< M A I N >----------------------------------------------------------------------
{{#invoke:Sandbox/trappist the monk/calendar|main|year=}}
supported parameters are:
|year= the year for which this calendar is rendered; defaults to current year
|lang-tag= language in which this calendar is rendered; defaults to wiki's own language
|table-style= css style string suitable for use in an html style="" attribute; no quotes; defaults to empty string
|caption= a caption that replaces the default caption
]]
local function main (frame)
local args_t = getArgs (frame);
args_t['table-style'] = (args_t['table-style'] and ' style="' .. args_t['table-style'] .. '"') or ''; -- if not set, empty string for concatenation; applies to whole table
local lang_object;
if args_t['lang-tag'] then
lang_object = mw.language.new (args_t['lang-tag']); -- get a language object for the language specified by |lang-tag=
else
lang_object = mw.language.getContentLanguage(); -- get a language object for the local wiki language
end
if not week_day_names_t.sun_t[1] then -- if empty auto fill; otherwise assume that tables have been filled manually at a local wiki
for i, day in ipairs ({'sun_t', 'mon_t', 'tue_t', 'wed_t', 'thu_t', 'fri_t', 'sat_t'}) do -- sequence values are used as indexes into week_day_names_t
local long = lang_object:formatDate ('l', '2022-05-0' .. i); -- 2022-05-01 is known to be a Sunday; calculate day names for the rest of the week
local abbreviated = lang_object:formatDate ('D', '2022-05-0' .. i); -- 2022-05-01 is known to be a Sun; calculate abbreviated day names for the rest of the week
week_day_names_t[day][1] = abbreviated; -- abbreviated day names: Sun, Mon, etc in local wiki language
week_day_names_t[day][2] = long; -- full day names: Sunday, Monday, etc in local wiki language
week_day_names_t[day][3] = table.concat ({'<abbr title="', long, '">', abbreviated, '</abbr>'});
end
end
local year = (args_t.year and args_t.year) or lang_object:formatDate ('Y'); -- get year from |year=; current year else TODO: get year from article title?
local jan_1_day = lang_object:formatDate ('l', year .. '-01-01'); -- get day name for day on which 1 January <year> occurs; for day name in table caption
local jan_1_mon = lang_object:formatDate ('F', year .. '-01-01'); -- i18n: get month name for <year>-01-01; for month name in table caption
for m=1, 12 do
local month_abbr = lang_object:formatDate ('M', year .. '-' .. m); -- get abbreviated month name
local day_number = lang_object:formatDate ('w', year .. '-' .. m .. '-01') + 1; -- returns a value 0-6; +1 offset makes 1-7 to index into first_day_t lua sequence
table.insert (first_day_t[day_number], month_abbr); -- add abbreviated month name to appropriate day number sequence
end
for row=1, 3 do -- for each of the three 'month' subheader rows
for day=1, 7 do -- and for each day of the week in that row
if first_day_t[day][row] then -- if first of the month occurs on <day>
table.insert (subheader_rows_t[row], first_day_t[day][row]); -- insert abreviated month name
else
table.insert (subheader_rows_t[row], ''); -- insert empty string else
end
end
end
local out_t = {}; -- components of the output go here
local caption = (args_t.caption and args_t.caption) or string.format (caption_fmt, jan_1_mon, jan_1_day);
table.insert (out_t, '{| class="wikitable"' .. args_t['table-style'] .. '\n|+ ' .. caption); -- open wikitable
table.insert (out_t, table.concat ({'! colspan="12" | ', year})); -- common column header holds year value from |year= or current year
for i, row_t in ipairs (subheader_rows_t) do -- for each of the three 'month' subheader rows
if 1 == i then -- first of these rows has rowspan and colspan styling
table.insert (out_t, string.format ('| colspan="5" rowspan="3" |Date ' .. row_format_str, row_t[1], row_t[2], row_t[3], row_t[4], row_t[5], row_t[6], row_t[7]));
else -- the others have no styling
table.insert (out_t, string.format (row_format_str, row_t[1], row_t[2], row_t[3], row_t[4], row_t[5], row_t[6], row_t[7]));
end
end
-- append static day numbers and weekday rows
table.insert (out_t, string.format (weekday_rows_fmt_t[1],
week_day_names_t.sun_t[3], week_day_names_t.mon_t[3], week_day_names_t.tue_t[3], week_day_names_t.wed_t[3], week_day_names_t.thu_t[3], week_day_names_t.fri_t[3], week_day_names_t.sat_t[3]));
table.insert (out_t, string.format (weekday_rows_fmt_t[2],
week_day_names_t.mon_t[3], week_day_names_t.tue_t[1], week_day_names_t.wed_t[1], week_day_names_t.thu_t[1], week_day_names_t.fri_t[1], week_day_names_t.sat_t[1], week_day_names_t.sun_t[1]));
table.insert (out_t, string.format (weekday_rows_fmt_t[3],
week_day_names_t.tue_t[3], week_day_names_t.wed_t[1], week_day_names_t.thu_t[1], week_day_names_t.fri_t[1], week_day_names_t.sat_t[1], week_day_names_t.sun_t[1], week_day_names_t.mon_t[1]));
table.insert (out_t, string.format (weekday_rows_fmt_t[4],
week_day_names_t.wed_t[3], week_day_names_t.thu_t[1], week_day_names_t.fri_t[1], week_day_names_t.sat_t[1], week_day_names_t.sun_t[1], week_day_names_t.mon_t[1], week_day_names_t.tue_t[1]));
table.insert (out_t, string.format (weekday_rows_fmt_t[5],
week_day_names_t.thu_t[3], week_day_names_t.fri_t[1], week_day_names_t.sat_t[1], week_day_names_t.sun_t[1], week_day_names_t.mon_t[1], week_day_names_t.tue_t[1], week_day_names_t.wed_t[1]));
table.insert (out_t, string.format (weekday_rows_fmt_t[6],
week_day_names_t.fri_t[3], week_day_names_t.sat_t[1], week_day_names_t.sun_t[1], week_day_names_t.mon_t[1], week_day_names_t.tue_t[1], week_day_names_t.wed_t[1], week_day_names_t.thu_t[1]));
table.insert (out_t, string.format (weekday_rows_fmt_t[7],
week_day_names_t.sat_t[3], week_day_names_t.sun_t[1], week_day_names_t.mon_t[1], week_day_names_t.tue_t[1], week_day_names_t.wed_t[1], week_day_names_t.thu_t[1], week_day_names_t.fri_t[1]));
table.insert (out_t, '|}'); -- close wikitable
return table.concat (out_t, '\n|-\n'); -- make a big string and done
end
--[[--------------------------< E X P O R T S >----------------------------------------------------------------
]]
return {
main = main
}