Module:WeeklyEvent: Difference between revisions

From Noisebridge
Jump to navigation Jump to search
Mcint (talk | contribs)
update for "next" to properly reflect "cur"rent week
Tag: Reverted
Mcint (talk | contribs)
remove next & s/this/next/
 
(4 intermediate revisions by the same user not shown)
Line 3: Line 3:
local function d(fmt, rel)
local function d(fmt, rel)
   return mw.getContentLanguage():formatDate(fmt, rel)
   return mw.getContentLanguage():formatDate(fmt, rel)
end
local function exists(t)
  local title = mw.title.new(t)
  return title and title.exists
end
end


function p.links(frame)
function p.links(frame)
   local args   = frame:getParent().args
   local args = frame:getParent().args
   local prefix = args.prefix or 'Meeting Notes'
   local prefix   = args.prefix   or 'Meeting Notes'
   local joiner = args.joiner or ' '
   local joiner   = args.joiner   or ' '
   local weekday = args.weekday or 'Tuesday'
   local weekday = args.weekday or 'Tuesday'
 
   local t_next   = args.text_next or 'Next week' -- 'This week'
  -- show segment iff arg PROVIDED (nil => omit); blank string allowed
   local t_prev   = args.text_prev or 'Last week'
   local t_prev   = args.text_prev  -- label for last occurrence
   local t_cur    = args.text_this  -- label for upcoming occurrence (semantic "this" == next weekday)
  local t_next   = args.text_next  -- label for occurrence after upcoming
   local preload  = args.preload
   local preload  = args.preload
  local t_create = args.create_text -- label for create link; requires preload too


   -- Semantics:
   local nextdate = d('Y m d', 'this ' .. weekday) -- 'this ' arg expected & needed
  -- prev = last weekday
  -- cur  = next weekday (the one you're about to write)
  -- next = weekday after cur
   local prevdate = d('Y m d', 'last ' .. weekday)
   local prevdate = d('Y m d', 'last ' .. weekday)
  local curdate  = d('Y m d', 'next ' .. weekday)
  local nextdate = d('Y m d', 'next ' .. weekday .. ' + 7 days')


  local nextTitle = table.concat({prefix, nextdate}, joiner)
   local prevTitle = table.concat({prefix, prevdate}, joiner)
   local prevTitle = table.concat({prefix, prevdate}, joiner)
  local curTitle  = table.concat({prefix, curdate}, joiner)
  local nextTitle = table.concat({prefix, nextdate}, joiner)


   local parts = {}
   local latestTitle, latestText
   local function add_link(title, label)
  --if exists(thisTitle) then
     table.insert(parts, string.format('[[%s|%s]]', title, label or ''))
  --  latestTitle, latestText = thisTitle, t_next
  -- elseif
   if exists(prevTitle) then
    latestTitle, latestText = prevTitle, t_prev
  end
 
  -- build inline wikitext
  local out = ''
 
  if latestTitle then
     out = out .. string.format('[[%s|%s]]', latestTitle, latestText)
  else
    out = out .. "''no recent page''"
   end
   end


   if t_prev ~= nil then add_link(prevTitle, t_prev) end
   out = out .. ' · ' ..
  if t_cur  ~= nil then add_link(curTitle, t_cur)  end
        string.format('[[%s|%s]]', nextTitle, t_next)
  if t_next ~= nil then add_link(nextTitle, t_next) end


  -- Create link targets the upcoming occurrence (curTitle), not the later one.
   if preload then
   if preload and preload ~= '' and t_create ~= nil then
     local url = mw.uri.canonicalUrl(nextTitle, { action='edit', preload=preload })
     local url = mw.uri.canonicalUrl(curTitle, { action='edit', preload=preload })
     out = out .. ' · ' ..
     table.insert(parts, string.format('[%s %s]', tostring(url), t_create))
          string.format('[%s create next]', tostring(url))
   end
   end


   local out = mw.text.trim(table.concat(parts, ' · '))
   --[[
  return frame:preprocess(out)
  ]]
  -- no leading/trailing whitespace
 
  out = mw.text.trim(out)


  -- force inline rendering; content is parsed as wikitext inside a <span>
   return frame:extensionTag{
   return frame:extensionTag{
     name = 'span',
     name = 'span',
     content = out,
     content = out,
     args = { class = 'weekly-event-inline' }
     args = { class = 'weekly-event-inline' } -- optional
   }
   }
end
end


return p
return p

Latest revision as of 18:40, 23 February 2026

docs

mw:Extension:Scribunto

mw:Module:Arguments

https://dev.fandom.com/wiki/Lua_reference_manual/Scribunto_libraries

https://en.wikipedia.org/wiki/Wikipedia:Comparable_Lua_functions_to_wikitext


local p = {}

local function d(fmt, rel)
  return mw.getContentLanguage():formatDate(fmt, rel)
end

local function exists(t)
  local title = mw.title.new(t)
  return title and title.exists
end

function p.links(frame)
  local args = frame:getParent().args
  local prefix   = args.prefix   or 'Meeting Notes'
  local joiner   = args.joiner   or ' '
  local weekday  = args.weekday  or 'Tuesday'
  local t_next   = args.text_next or 'Next week' -- 'This week'
  local t_prev   = args.text_prev or 'Last week'
  local preload  = args.preload

  local nextdate = d('Y m d', 'this ' .. weekday) -- 'this ' arg expected & needed
  local prevdate = d('Y m d', 'last ' .. weekday)

  local nextTitle = table.concat({prefix, nextdate}, joiner)
  local prevTitle = table.concat({prefix, prevdate}, joiner)

  local latestTitle, latestText
  --if exists(thisTitle) then
  --  latestTitle, latestText = thisTitle, t_next
  -- elseif
  if exists(prevTitle) then
    latestTitle, latestText = prevTitle, t_prev
  end

  -- build inline wikitext
  local out = ''

  if latestTitle then
    out = out .. string.format('[[%s|%s]]', latestTitle, latestText)
  else
    out = out .. "''no recent page''"
  end

  out = out .. ' · ' ..
        string.format('[[%s|%s]]', nextTitle, t_next)

  if preload then
    local url = mw.uri.canonicalUrl(nextTitle, { action='edit', preload=preload })
    out = out .. ' · ' ..
          string.format('[%s create next]', tostring(url))
  end

  --[[
  return frame:preprocess(out)
  ]]
  -- no leading/trailing whitespace

  out = mw.text.trim(out)

  -- force inline rendering; content is parsed as wikitext inside a <span>
  return frame:extensionTag{
    name = 'span',
    content = out,
    args = { class = 'weekly-event-inline' } -- optional
  }
end

return p