Module:Women in Red event
Module:Women in Red event has various functions that use the list of WikiProject Women in Red events stored at Wikipedia:WikiProject Women in Red/events. These are used in
- Template:WikiProject Women in Red,
- Template:WIR meetup header,
- Template:WIR category
- Template:Women in Red navigation
and elsewhere.
Usage
main function
{{#invoke:Women in Red event|main|event|field}}
Given an event number, reads one of the fields (event, year, month, type, image, series). For example:
{{#invoke:Women in Red event|main|294|name}}
gives "Education"{{#invoke:Women in Red event|main|7|year}}
gives "Lua error at line 66: attempt to index local 'ret' (a number value)."{{#invoke:Women in Red event|main|293|series}}
gives "#1day1woman"
A third optional parameter, allows you to specify a default value if none is defined. For example:
{{#invoke:Women in Red event|main|291|type|edit-a-thon}}
gives "edit-a-thon" because there is notype
value defined for 291.
A |hash=no
option allows you to remove the # character from the output (this is sometimes useful because this character can upset the formatting of a page and it is not possible to have this character in a page name). For example:
{{#invoke:Women in Red event|main|293|series|hash=no}}
gives "1day1woman"
name function
{{#invoke:Women in Red event|name|event}}
Given an event number, returns the name or the series of the event. If the both the name and the series are defined, then it will prepend the series with a colon. For example:
{{#invoke:Women in Red event|name|294}}
gives "Education"{{#invoke:Women in Red event|name|7}}
gives "Black women: History"{{#invoke:Women in Red event|name|236}}
gives "Alphabet run: C & D"
text function
{{#invoke:Women in Red event|text|event}}
Produces a piped link to the event page followed by the date, for use in the project banner. For example:
{{#invoke:Women in Red event|text|291}}
gives "Women who died: 2023 edit-a-thon from December 2023 to January 2024"
date function
{{#invoke:Women in Red event|date|event|sentence|abbrev}}
Produces a formatted date (including month and year) of the event. For example:
{{#invoke:Women in Red event|date|210}}
gives "October–December 2021"
This function takes two optional parameters:
|sentence=
- if set to "yes" then the date will be expressed as a sentence using the words "from" and "to", e.g. "from October to December 2021"|abbrev=
- if set to "yes" then the names of the months will be abbreviated, e.g. "Oct–Dec 2021"
Both of these options may be used simultaneously, but the output is slightly awkward, e.g. "from Oct to Dec 2021"
findLatest function
{{#invoke:Women in Red event|findLatest|add}}
Shows the latest event number to be defined (currently 329), ignoring the quasi event numbers "2017" and "2018". For example
{{#invoke:Women in Red event|findLatest}}
gives "329"
An optional parameter |add=
can be used to add or subtract numbers to the latest. For example
{{#invoke:Women in Red event|findLatest|add=1}}
gives "330"{{#invoke:Women in Red event|findLatest|add=-5}}
gives "324"
list function
{{#invoke:Women in Red event|list|first|last|latest|meetup|logo|series|name|date|template|wrapper|category}}
Produce a table of events, for various purposes. The following parameters are recognised.
|first=
,|last=
- specify the first and/or last event to show in the list.
For example {{#invoke:Women in Red event|list|first=52|last=55}}
produces
Meetup | Name | Date |
---|---|---|
52 | Women in peace | Aug 2017 |
53 | Canadian women | Aug 2017 |
54 | Hispanic & Latina women | Sep 2017 |
55 | Olympic women | Sep 2017 |
|latest=
- to show a specified number of the latest events. In this case|first=
and|last=
will be ignored.
For example, {{#invoke:Women in Red event|list|latest=3}}
produces
Meetup | Name | Date |
---|---|---|
327 | #1day1woman | 2025 |
328 | Alphabet run: A & B | Jan 2025 |
329 | Internet personalities | Jan 2025 |
Columns
The columns of the table can be customised by setting various parameters to yes
or no
.
|meetup=
- shows or hides a column with the meetup number. By default this column is shown. If a background colour is defined then it will be used in this cell.|logo=
- enables a column to show the logo associated with each event.|series=
- enables a column to show the series (if applicable) of each event.|name=
- enables a column to show the name of each event, and a link to the meetup page. This will be shown by default.|date=
- shows or hides a column which displays the date of each event. Shown by default.|template=
- column to show the syntax for the template using the shortcut {{WIR}}|wrapper=
(deprecated) - column to show the wrapper template for each event. These are no longer in general use.|category=
- enables a column which links to the category for articles created by each event, along with the population of that category.
If any other columns are required, please ask one of the module's maintainers.
Examples
The table currently shown on Wikipedia talk:WikiProject Women in Red/events is produced by the syntax {{#invoke:Women in Red event|list|logo=yes|series=yes|wrapper=yes|category=yes}}
.
The table currently shown on Template:WikiProject Women in Red/doc is produced by the syntax {{#invoke:Women in Red event|list|latest=10|template=yes}}
which produces the following:
Meetup | Name | Date | Template |
---|---|---|---|
320 | Women in archaeology | Oct 2024 | {{WIR|320}} |
321 | Asian women | Nov 2024 | {{WIR|321}} |
322 | Geofocus: Islands Q–Z | Nov 2024 | {{WIR|322}} |
323 | Women in engineering | Nov 2024 | {{WIR|323}} |
324 | Women who died: 2024 | Dec 2024 – Jan 2025 | {{WIR|324}} |
325 | Religion | Dec 2024 | {{WIR|325}} |
326 | Music | 2025 | {{WIR|326}} |
327 | #1day1woman | 2025 | {{WIR|327}} |
328 | Alphabet run: A & B | Jan 2025 | {{WIR|328}} |
329 | Internet personalities | Jan 2025 | {{WIR|329}} |
event_list_by_year function
{{#invoke:Women in Red event|event_list_by_year|year}}
Produces a list of all past events in a particular year, for use in Template:Women in Red navigation.
For example, {{#invoke:Women in Red event|event_list_by_year|2023}}
produces:
- INITIATIVES:
- Peace and Diplomacy
- #1day1woman EDIT-A-THONS:
- Folklore
- Women who died: 2023
- Jan:
- Feb:
- Mar:
- Apr:
- May:
- Jun:
- Jul:
- Aug:
- Sep:
- Oct:
- Nov:
- Dec:
current_events function
{{#invoke:Women in Red event|current_events|year|month}}
Produces a list of current, upcoming, recently completed and ongoing events, for navigational purposes at the top of meetup pages. The display on a certain month and year can be specified by using the parameters:
year
- specify the 4-digit year, e.g.|year=2022
month
- specify the month as a number between 1-12. If the year is specified then the month will default to 1, i.e. January.
The labels in front of the boxes can be customised with the following parameters:
recent
current
ongoing
upcoming
Examples
{{#invoke:Women in Red event|current_events}}
produces:
Recently completed: | |
January 2025: | |
Ongoing initiatives: | |
Upcoming events: |
{{#invoke:Women in Red event|current_events|year=2023|month=2|ongoing=Still happening|upcoming=Coming up}}
produces:
Recently completed: | |
February 2023: | |
Still happening: | |
Coming up: |
events function
{{#invoke:Women in Red event|events}}
Produces a list of current, upcoming and recently completed events, for use on Wikipedia:WikiProject Women in Red/Events. It has a number of optional parameters:
monthly
- include a section for edit-a-thons in the current month. This parameter defines the heading, e.g.|monthly=Happening now
ongoing
- include a section for ongoing initiatives or contests. This parameter defines the heading, e.g.|ongoing=Ongoing initiatives
upcoming
- include a section for upcoming events. This parameter defines the heading, e.g.|upcoming=Coming up
recent
- include a section for recently completed events (i.e. events in the previous month). This parameter defines the heading, e.g.|recent=Recently completed
past
- include a section for all past events (except recently completed). This parameter defines the heading, e.g.|past=Past events
category_header function
{{#invoke:Women in Red event|category_header}}
Used by Template:WIR category to produce a header for various categories. Please see that template's documentation.
addDateCategories function
{{#invoke:Women in Red event|addDateCategories|event}}
Used by Template:WIR meetup header to add appropriate categories to meetup pages. This function takes the event number as the first positional parameter.
- For all events, an annual category such as Category:WikiProject Women in Red in 2025 is added.
- If the event spans a single calendar month, then a monthly category such as Category:Wikipedia meetups in January 2025 is added.
- If the event spans more than one calendar month, then an annual category such as Category:Wikipedia meetups in 2025 is added.
Example
{{#invoke:Women in Red event|addDateCategories|300}}
produces the categories Category:WikiProject Women in Red in 2024 and Category:Wikipedia meetups in March 2024.
pinterest function
{{#invoke:Women in Red event|pinterest|event}}
Generates a link to Pinterest collection based on the date of the event.
The link is of the form https://www.pinterest.com/wikiwomeninred/MONTH-YEAR-editathons
where MONTH
and YEAR
are replaced with the relevant month and year. For annual events, the month of January is used.
Example
{{#invoke:Women in Red event|pinterest|319}}
produces October-2024-editathons
require('strict')
local p = {}
local data = mw.loadJsonData('Wikipedia:WikiProject Women in Red/events')
local currentDate = os.date('*t')
local lang = mw.getContentLanguage()
local frame = mw.getCurrentFrame()
local args = frame.args
local yesno = require('Module:Yesno')
local format_date = function(_date)
local month = _date.month or 0
return _date.year*100+month
end
local relativeMonths = function(_date)
local last_month = {year=_date.year, month=_date.month-1}
if _date.month==1 then
last_month = {year=_date.year-1, month=12}
end
local next_month = {year=_date.year, month=_date.month+1}
if _date.month==12 then
next_month = {year=_date.year+1, month=1}
end
return {
current = format_date(_date),
last = format_date(last_month),
next = format_date(next_month)
}
end
local relative_month = relativeMonths(currentDate)
local monthName = function(month, abbrev)
local monthcode = month<10 and ('0'..tostring(month)) or tostring(month)
local timestamp = '2024' .. monthcode .. '01000000'
local _format = abbrev and 'M' or 'F'
return lang:formatDate(_format, timestamp)
end
local _findLatest = function()
local _max = 1
for n, _ in pairs(data) do
local val = tonumber(n) or 0
if val<1000 and val>_max then
_max = val
end
end
return _max
end
p.findLatest = function()
return _findLatest() + (tonumber(args.add) or 0)
end
local value = function(event, field, default)
local data = data[tonumber(event)]
if data and data[field] then
return data[field]
else
return default
end
end
p.main = function()
local ret = value(args[1], args[2], args[3])
if args.hash=='no' then
ret = ret:gsub('#', '')
end
if ret and ret:sub(1,1)=='#' then -- prevent # character from starting a list
ret = mw.text.nowiki(ret)
end
return ret
end
local getDates = function(event, endDefaultsToStart)
local _start = value(event, 'start') or {
month = value(event, 'month'),
year = value(event, 'year')
}
local _end = value(event, 'end')
if not _end and endDefaultsToStart then
_end = _start
end
return _start, _end
end
local _date = function(event, sentence, abbrev)
local _start, _end = getDates(event)
local ret = ''
if sentence then
ret = _end and 'from ' or 'in '
end
ret = ret .. (_start.month and monthName(_start.month, abbrev) or '')
if not _end or _start.year~=_end.year then
ret = ret .. (_start.month and ' ' or '') .. tostring(_start.year)
end
if _end then
local to
if sentence then
to = ' to '
else
if _start.year==_end.year then
to = '–' -- en dash
else
to = ' – ' -- spaced en dash
end
end
ret = ret .. to .. monthName(_end.month, abbrev) .. ' ' .. tostring(_end.year)
end
local sortkey = os.time{
year = _start.year or 0,
month = _start.month or 1,
day = _start.month and 2 or 1
}
return ret, sortkey
end
p.date = function(frame)
local date, _ = _date(args[1], yesno(frame.args.sentence or 'false'), yesno(frame.args.abbrev or 'false'))
return date
end
local _name = function(meetup)
local series = value(meetup, 'series')
local name = value(meetup, 'name')
local out = series or ''
if series and name then
out = out .. ': '
end
out = out .. (name or '')
return out
end
p.name = function()
return mw.text.nowiki(_name(args[1]))
end
p.nested = function()
-- Function to produce year for nested display in project banner
local year = value(args[1], 'year')
if not year and value(args[1], 'start') and value(args[1], 'start').year==value(args[1], 'end').year then
year = value(args[1], 'start').year
end
return _name(args[1]) .. (year and (' (' .. year .. ')') or '')
end
p.text = function()
local meetup = args[1]
return '[[Wikipedia:WikiProject Women in Red/Meetup/' .. meetup
.. '|' .. _name(meetup)
.. ' ' .. value(meetup, 'type', 'edit-a-thon')
.. ']] '
.. _date(meetup, true, false)
end
local showDate = function(meetup)
local date, sortkey = _date(meetup, false, true)
return mw.html.create('td'):attr('data-sort-value', sortkey):wikitext(date):done()
end
local link = function(n, name)
local label = name and _name(n) or n
return '[[Wikipedia:WikiProject Women in Red/Meetup/' .. n .. '|' .. label .. ']]'
end
local buildTable = function(option, show)
local meetupCell = function(n)
return mw.html.create('th')
:css('background-color', value(n, 'background') and ('#' .. value(n, 'background')))
:css('text-align', 'center')
:wikitext(n)
:done()
end
local total = 0
option.meetup = true
option.name = true
option.date = true
local header = mw.html.create('tr')
local cols = 0
for _, col in ipairs({'meetup', 'logo', 'series', 'name', 'date', 'template', 'wrapper', 'category'}) do
if option[col] then
cols = cols + 1
header:tag('th'):wikitext(lang:ucfirst(col)):done()
end
end
local rows = {}
for n, event in pairs(data) do
if not show or show(n, event) then
local row = mw.html.create('tr')
:node(meetupCell(n))
if option.logo then
local logo = event.image and '[[File:' .. event.image .. '|50px]]'
row:tag('td'):wikitext(logo):done()
end
if option.series then
local series = event.series and '[[:Category:WikiProject Women in Red ' .. event.series:gsub('#', '') .. ' articles|' .. event.series .. ']]' or ''
row:tag('td'):wikitext(series):done()
end
local name = option.series and event.name or _name(n)
local link = '[[Wikipedia:WikiProject Women in Red/Meetup/' .. n .. '|' .. name .. ']]'
row:tag('td'):wikitext(link):done()
:node(showDate(n))
if option.template then
local template = frame:extensionTag('code', '{{WIR|' .. n .. '}}')
row:tag('td'):css('text-align', 'center'):wikitext(template):done()
end
if option.wrapper then
row:tag('td')
:css('text-align', 'center')
:wikitext('{{[[:Template:WIR-' .. n .. '|WIR-' .. n .. ']]}}')
:done()
end
if option.category then
local cat = 'WikiProject Women in Red meetup ' .. n .. ' articles'
local url = mw.uri.fullUrl(':Category:' .. cat, {
action = 'edit',
preload = 'Template:WIR category/preload',
summary = 'Create meetup category for Women in Red'
})
local pagesInCat = mw.site.stats.pagesInCategory(cat)
total = total + pagesInCat
local catText = '[[' .. ':Category:' .. cat .. '|' .. pagesInCat .. ']]'
if pagesInCat==0 and not mw.title.new(':Category:' .. cat).exists then
catText = catText .. ' ([' .. tostring(url) .. ' create])'
end
row:tag('td')
:css('text-align', 'center')
:wikitext(catText)
:done()
end
table.insert(rows, tostring(row))
end
end
local footer
if option.category then
footer = mw.html.create('tr')
:tag('th'):attr('colspan', cols-1):wikitext('Total'):done()
:tag('th'):css('text-align', 'center'):wikitext(tostring(total)):done()
end
return mw.html.create('table')
:addClass('wikitable'):addClass('sortable')
:node(header)
:node(table.concat(rows))
:node(footer)
end
p.list = function()
local first = tonumber(args.first) or 1
local last = tonumber(args.last) or 9999
if args.latest then
last = _findLatest()
first = last - tonumber(args.latest) + 1
end
local option = {}
for key, value in pairs(args) do
option[key] = yesno(value)
end
return buildTable(
option,
function(n, _) return n>=first and n<=last end
)
end
local eventStatus = function(event, _date)
--function to decide whether an event is upcoming, current, ongoing, recently completed or past
local month = relative_month
if _date then
month = relativeMonths(_date)
end
local _start = format_date(event['start'] or {
year = event.year,
month = event.month or 1
})
local _end = format_date(event['end'] or {
year = event.year,
month = event.month or 12
})
if _end<month.last then -- event ended before previous month
return 'past'
elseif _end==month.last then -- event ended on previous month
return 'recent'
elseif _start==month.current then -- event has started on current month
return 'current'
elseif _start==month.next then -- event starts after current month
return 'upcoming'
elseif _start<month.current then -- event starts before current month
return 'ongoing'
end
end
local searchEvents = function(_date)
local events = {current = {}, recent = {}, ongoing = {}, upcoming = {}, past = {}}
for n, event in pairs(data) do
local status = eventStatus(event, _date)
if status then
table.insert(events[status], n)
end
end
table.sort(events.past, function(a, b) return a > b end)
return events
end
p.current_events = function(frame)
local _date = currentDate
if frame.args.year and frame.args.year~='' then
_date = {
year = tonumber(frame.args.year),
month = tonumber(frame.args.month) or 1
}
end
local mClickableButton = require('Module:Clickable button').main
local button = function(text, colour)
return mClickableButton{
[1] = text,
color = 'white',
style = colour and ('background-color: #' .. colour)
}
end
local links = function(text, events, extra)
local list = {}
if events[1] or extra then
for _, n in ipairs(events) do
table.insert(list, button(
'[[Wikipedia:WikiProject Women in Red/Meetup/' .. n .. '|' .. _name(n) .. ']]',
value(n, 'background')
) .. ' ')
end
if extra then
table.insert(list, button(extra))
end
return mw.html.create('tr')
:tag('td'):wikitext(text .. ': '):done()
:tag('td'):wikitext(table.concat(list)):done()
end
end
local events = searchEvents(_date)
local ret = mw.html.create('table')
:node(links(frame.args.recent or 'Recently completed', events.recent))
:node(links(frame.args.current or monthName(_date.month) .. ' ' .. _date.year, events.current))
:node(links(frame.args.ongoing or 'Ongoing initiatives', events.ongoing))
:node(links(frame.args.upcoming or 'Upcoming events', events.upcoming, '[[Wikipedia:WikiProject Women in Red/Ideas|Ideas]]'))
return tostring(ret)
end
p.events = function()
-- function to produce automated list of events on Wikipedia:WikiProject Women in Red/Events
local ret = mw.html.create('div')
local ec = searchEvents()
local links = function(class)
if not ec[class] or not args[class] then
return nil
end
ret:tag('h3'):wikitext(args[class]):done()
if ec[class][1] then
ret:tag('ul')
for _, n in ipairs(ec[class]) do
local date2 = _date(n, false, false)
if date2==tostring(tonumber(date2)) then
date2 = date2 .. ' year-long ' .. value(n, 'type', 'editathon')
end
ret:tag('li'):wikitext(date2 .. ': ' .. link(n, true)):done()
end
else
ret:tag('p'):css('font-style', 'italic'):wikitext('None to display.'):done()
end
end
links('ongoing')
links('current')
links('recent')
links('upcoming')
links('past')
return tostring(ret)
end
p.event_list = function()
-- function to produce bulleted list of events for Template:Women in Red navigation
local ec = searchEvents()
local class = args[1]
if not ec[class] then
return nil
end
local ret = mw.html.create('ul')
for _, n in ipairs(ec[class]) do
ret:tag('li'):wikitext(link(n, true)):done()
end
return tostring(ret)
end
p.event_list_by_year = function()
-- function to produce bulleted list of past events for Template:Women in Red navigation
local ret = mw.html.create('ul')
local year = args[1] and tonumber(args[1]) or 2023
local events = {}
for n, event in ipairs(data) do
if (event.year==year or (event.start and event.start.year==year)) and eventStatus(event)=='past' then
local type = event.type or 'edit-a-thon'
if not events[type] then
events[type] = {}
end
local month = value(n, 'month', 0)
if not events[type][month] then
events[type][month] = {}
end
table.insert(events[type][month], n)
end
end
for type, eventsOfType in pairs(events) do
ret:wikitext(lang:uc(type)..'S: ')
for _, n in ipairs(eventsOfType[0] or {}) do
ret:tag('li'):wikitext(link(n, true)):done()
end
for month = 1, 12 do
if eventsOfType[month] then
local sublist = mw.html.create('ul')
for _, n in ipairs(eventsOfType[month]) do
sublist:tag('li'):wikitext(link(n, true)):done()
end
ret:tag('li'):wikitext(monthName(month, true) .. ': '):node(sublist):done()
end
end
end
return tostring(ret)
end
local meetupHeader = function(n)
local text = 'This category contains talk pages of articles which were created or improved during the <b>[[Wikipedia:WikiProject Women in Red/Meetup/'
.. n .. '|' .. _name(n) .. ' ' .. value(n, 'type', 'edit-a-thon') .. ']]</b> hosted by the [[Wikipedia:WikiProject Women in Red|Women in Red project]] '
.. _date(n, true, false) .. '. It is automatically populated by '
.. frame:expandTemplate{title = 'tlx', args = {
[1] = 'WikiProject Women in Red',
[2] = n
}} .. '.'
.. '[[Category:WikiProject Women in Red articles by meetup|' .. n .. ']]'
local _start, _end = getDates(n, true)
for year = _start.year, _end.year do
text = text .. '[[Category:WikiProject Women in Red ' .. year .. ' articles|' .. n .. ']]'
end
if value(n, 'series') then
text = text .. '[[Category:WikiProject Women in Red ' .. value(n, 'series'):gsub('#', '') .. ' articles|' .. n .. ']]'
end
local empty = mw.site.stats.pagesInCategory('WikiProject Women in Red meetup ' .. n .. ' articles')==0
local future = false
if _start.year>currentDate.year then
future = true
elseif _start.year==currentDate.year then
if _start.month and _start.month>=currentDate.month then
future = true
end
end
return text, value(n, 'image', 'Women in Red logo.svg'), empty and future
end
local collapse = function(title, text)
return frame:expandTemplate{title = 'Collapsed top', args = {
bg = 'transparent',
width = '80%',
[1] = title
}} .. text .. '</table></div>'
end
local yearHeader = function(year)
local inYear = function(_, event)
if event.start and event['end'] then
return event.start.year<=year and event['end'].year>=year
else
return event.year==year
end
end
return 'This category contains talk pages of articles which were created or improved in '
.. year .. ' as part of the [[Wikipedia:WikiProject Women in Red|Women in Red project]]. The category is automatically populated by '
.. frame:expandTemplate{title = 'tlx', args = {
[1] = 'WikiProject Women in Red',
[2] = 'year=' .. year
}} .. '.' .. collapse(
'Articles improved during ' .. year,
tostring(buildTable(
{category = true},
inYear
))
) .. '[[Category:WikiProject Women in Red in ' .. year .. '|Articles]]'
.. '[[Category:WikiProject Women in Red articles by year|' .. year .. ']]'
end
local seriesHeader = function(series)
return 'This category contains talk pages of articles which were created or improved as part of the ' .. series
.. ' series of meetups hosted by the [[Wikipedia:WikiProject Women in Red|Women in Red project]].'
.. collapse(
'Articles improved during ' .. series .. ' events',
tostring(buildTable(
{category = true},
function(_, event) return event.series==series end
))
) .. '[[Category:WikiProject Women in Red articles by series|' .. series .. ']]'
end
p.category_header = function()
local page = mw.title.getCurrentTitle().text
local n = page:match('WikiProject Women in Red meetup (%d+) articles')
local year = page:match('WikiProject Women in Red (%d+) articles')
local series = page:match('WikiProject Women in Red (.+)')
local text, image, emptyCat, categorySeriesNavigation = '', 'Women in Red logo.svg', false, false
if n then
text, image, emptyCat = meetupHeader(n)
categorySeriesNavigation = true
elseif year then
text = yearHeader(tonumber(year))
categorySeriesNavigation = true
elseif series then
text = seriesHeader(series:gsub('%sarticles', ''):gsub('1day1woman', '#1day1woman'))
end
emptyCat = emptyCat and frame:expandTemplate{
title = 'Possibly empty category',
args = {[1] = 'This category should be populated soon.'}
} or ''
return frame:expandTemplate{title = 'cmbox', args = {
image = '[[File:' .. image .. '|40px]]',
text = text
}} .. (categorySeriesNavigation and frame:expandTemplate{title = 'Category series navigation'} or '')
.. frame:expandTemplate{title = 'CatAutoTOC'}
.. emptyCat
end
p.addDateCategories = function()
local n = args[1]
local test = yesno(args.test)
local cats = {}
local makeCat = function(cat, key)
local key2 = key and not test and ('|' .. key) or ''
table.insert(cats, '[['
.. (test and ':' or '')
.. 'Category:' .. cat
.. key2 .. ']]')
end
local _start, _end = getDates(n, true)
for year = _start.year, _end.year do
makeCat('WikiProject Women in Red in ' .. year, n)
end
if _start.month and format_date(_start)==format_date(_end) then -- event starts and ends on same month
makeCat('Wikipedia meetups in ' .. monthName(_start.month) .. ' ' .. _start.year)
else -- event spans more than one month, so just use yearly categories
for year = _start.year, _end.year do
makeCat('Wikipedia meetups in ' .. year)
end
end
return table.concat(cats)
end
p.pinterest = function()
-- Function to generate the correct link to pinterest based on the month of the start of the event
local _start = getDates(frame.args[1])
local month = monthName(_start.month or 1)
local label = month .. '-' .. _start.year .. '-editathons'
return '[https://www.pinterest.com/wikiwomeninred/' .. label .. ' ' .. label .. ']'
end
return p