Module:Date Stuff: Difference between revisions

From Stiles Wiki
Jump to navigation Jump to search
No edit summary
No edit summary
Tag: Manual revert
 
(77 intermediate revisions by the same user not shown)
Line 1: Line 1:
local p = {}
local p = {}
local args = {}


--Takes a string and splits it based on a specified delimiter
function p.date(frame)
local orgiArgs = frame.args
local args = {}
for k, v in pairs(orgiArgs) do
v = v:match('^%s*(.-)%s*$')
if v ~= '' then
args[k] = v
end
end
return p._date(args)
end
 
function p.age(frame)
local orgiArgs = frame.args
local args = {}
if orgiArgs[1] == "{{{1}}}" or orgiArgs[2] == "{{{2}}}" or orgiArgs[4] == "{{{3}}}" then
return error("Missing a parameter")
end
for k, v in pairs(orgiArgs) do
v = v:match('^%s*(.-)%s*$')
if v ~= '' then
args[k] = v
end
end
return p._age(args)
end
 
--Splits a string based on specified delimiter
function Split(s, delimiter)
function Split(s, delimiter)
   result = {};
   result = {};
Line 11: Line 37:
end
end


function convertDate(date)
--Takes a short form date and converts it to a long form, and marks if it is only a year, or a month and year
function convertShortDate(shortDate, calendar)
   --In place of a long if elseif, I've put all the months into a single variable, with each in its numerical place.
   --In place of a long if elseif, I've put all the months into a single variable, with each in its numerical place.
   monthNames = {"Miry", "Ozdary", "Rydust", "Iptust", "Tosey", "Iverly", "Eohe", "Kasgust", "Andust", "Bepry", "Nindust", "Tymust", "Ekage", "Aphly", "Asust", "Syranust"}
   --This also allows us to add other calendars here
   --Splits the date
  if calendar == "Solandria" then
   date = Split(date, "-")
    monthNames = {"Miry", "Ozdary", "Rydust", "Iptust", "Tosey", "Iverly", "Eohe", "Kasgust", "Andust", "Bepry", "Nindust", "Tymust", "Ekage", "Aphly", "Asust", "Syranust"}
   --Saves the month part of the variable into a seperate month variable
   elseif calendar == "Eberron" then
   month = tonumber(date[1])
  monthNames = {"Zarantyr", "Olarune", "Therendor", "Eyre", "Dravago", "Nymm", "Lharvion", "Barrakas", "Rhann", "Sypheros", "Aryth", "Vult"}
  elseif calendar == "Forgotten Realms" then
  monthNames = {"Hammer", "Alturiak", "Ches", "Tarsakh", "Mirtul", "Kythorn", "Flamerule", "Eleasis", "Eleint", "Marpenoth", "Uktar", "Nightal"}
   elseif calendar == "IRL" then
  monthNames = {"January", "February", "March", "April", "May", "June", "July", "August", "September", "October", "November", "December"}
  end
 
   --Takes the provided variable and seperates it out into a table
  --Also marks if it is only a year or a month and year
   local shortDate = Split(shortDate, "-")
    
    
   --Takes the month variable and converts it to its text counterpart
   if shortDate[2] == nil then
  month = monthNames[month]
    dateTable = {nil, nil, nil, tonumber(shortDate[1]), "year"}
    
   elseif shortDate[3] == nil then
  --Checks to see if the month is a valid number
     dateTable = {monthNames[tonumber(shortDate[1])], tonumber(shortDate[1]), nil, tonumber(shortDate[2]), "month-year"}
  if month == nil then
  else
     error("Invalid month")
    dateTable = {monthNames[tonumber(shortDate[1])], tonumber(shortDate[1]), tonumber(shortDate[2]), tonumber(shortDate[3]), "month-day-year"}
   end
   end
 
   return dateTable
  --Takes the text month variable and adds it to the day and year variable with a comma
  date = month.." "..date[2]..", "..date[3]
 
   return date
end
end
 


--Takes a short date and converts it to a long date (12-18-392 to Tymust 18, 392)
--Writes that date based on what is given.
function p.solandria(frame)
function writeDate(dateTable)
   --Sets date variable to the first frame argument
  if dateTable[5] == "year" then
  date = frame.args[1]
    return dateTable[4]
  elseif dateTable[5] == "month-year" then
    return dateTable[1].." ("..dateTable[2]..") "..dateTable[4]
   elseif dateTable[5] == "month-day-year" then
    return dateTable[1].." ("..dateTable[2]..") "..dateTable[3]..", "..dateTable[4]
  end
end


  --Calls the convert date function to convert short date to long date
--Converts a short from date to a long from date using the specified calendar
  date = convertDate(date)
function p._date(args)
 
   return writeDate(convertShortDate(args[1], args[2]))
   return date
end
end




--Calculates an age based on two given dates
--Calculates a persons age using the specified calendar
function p.solandriaBirthDateAge(frame)
function p._age(args)
   --Sets the date variables based on passed through arguments
   local birthDate = convertShortDate(args[1], args[4])
  birthDate = frame.args[1]
   local secondDate = convertShortDate(args[2], args[4])
   currentDate = frame.args[2]
   local status = args[3]
 
    
   --Converts the first given date to a long date
   --Checks which math formula to use, based on how much of the date there is.
   convertedDate = convertDate(birthDate)
   if birthDate[5] == "year" or secondDate == "year" then
 
    age = math.floor(secondDate[4] - birthDate[4])
   --Splits the first date given
   elseif birthDate[5] == "month-year" or secondDate == "month-year" then
   birthDate = Split(birthDate, "-")
    if birthDate[2] <= secondDate[2] then
  --Saves the parts of the first date given into seperate month day year variables
      age = math.floor(secondDate[4] - birthDate[4])
  birthMonth = birthDate[1]
    elseif birthDate[2] > secondDate[2] then
  birthDay = birthDate[2]
      age = math.floor(secondDate[4] - birthDate[4] - 1)
   birthYear = birthDate[3]
    end
 
   elseif birthDate[5] == "month-day-year" or secondDate == "month-day-year" then
  --Splits the second date given
    if birthDate[2] < secondDate[2] then
  currentDate = Split(currentDate, "-")
      age = math.floor(secondDate[4] - birthDate[4])
  --Saves the parts of the second date given into seperate month day year variables
    elseif birthDate[2] == secondDate[2] then
  currentMonth = currentDate[1]
      if birthDate[3] <= secondDate[3] then
  currentDay = currentDate[2]
        age = math.floor(secondDate[4] - birthDate[4])
  currentYear = currentDate[3]
      elseif birthDate[3] > secondDate[3] then
 
        age = math.floor(secondDate[4] - birthDate[4] - 1)
   --Compares the second and first date month to determine which age calculation to use
      end
  if currentMonth > birthMonth then
     elseif birthDate[2] > secondDate[2] then
    age = math.floor(currentYear - birthYear)
       age = math.floor(secondDate[4] - birthDate[4] - 1)
  elseif currentMonth == birthMonth then
    if currentDay >= birthDay then
      age = math.floor(currentYear - birthYear)
    elseif currentDay < birthDay then
      age = math.floor(currentYear - birthYear - 1)
     else
       error("Something went wrong")
     end
     end
  elseif currentMonth < birthMonth then
    age = math.floor(currentYear - birthYear - 1)
  else
    error("Something went wrong")
   end
   end
 
 
   --Takes the first date and adds the age to the end
   --Determines if age or aged is required
   dateAge = convertedDate.." (age "..age..")"
   if status == "alive" then
   return dateAge
    local longDate = writeDate(birthDate)
    return longDate.." (age "..age..")"
   elseif status == "dead" then
    return writeDate(secondDate).." (aged "..age..")"
  end
end
end


return p
return p

Latest revision as of 20:04, 31 May 2022

Documentation for this module may be created at Module:Date Stuff/doc

local p = {}

function p.date(frame)
	local orgiArgs = frame.args
	local args = {}
	for k, v in pairs(orgiArgs) do
		v = v:match('^%s*(.-)%s*$')
		if v ~= '' then
			args[k] = v
		end
	end
	return p._date(args)
end

function p.age(frame)
	local orgiArgs = frame.args
	local args = {}
	if orgiArgs[1] == "{{{1}}}" or orgiArgs[2] == "{{{2}}}" or orgiArgs[4] == "{{{3}}}" then
		return error("Missing a parameter")
	end
	for k, v in pairs(orgiArgs) do
		v = v:match('^%s*(.-)%s*$')
		if v ~= '' then
			args[k] = v
		end
	end
	return p._age(args)
end

--Splits a string based on specified delimiter
function Split(s, delimiter)
  result = {};
  for match in (s..delimiter):gmatch("(.-)"..delimiter) do
    table.insert(result, match);
  end
  return result;
end

--Takes a short form date and converts it to a long form, and marks if it is only a year, or a month and year
function convertShortDate(shortDate, calendar)
  --In place of a long if elseif, I've put all the months into a single variable, with each in its numerical place.
  --This also allows us to add other calendars here
  if calendar == "Solandria" then
    monthNames = {"Miry", "Ozdary", "Rydust", "Iptust", "Tosey", "Iverly", "Eohe", "Kasgust", "Andust", "Bepry", "Nindust", "Tymust", "Ekage", "Aphly", "Asust", "Syranust"}
  elseif calendar == "Eberron" then
  	monthNames = {"Zarantyr", "Olarune", "Therendor", "Eyre", "Dravago", "Nymm", "Lharvion", "Barrakas", "Rhann", "Sypheros", "Aryth", "Vult"}
  elseif calendar == "Forgotten Realms" then
  	monthNames = {"Hammer", "Alturiak", "Ches", "Tarsakh", "Mirtul", "Kythorn", "Flamerule", "Eleasis", "Eleint", "Marpenoth", "Uktar", "Nightal"}
  elseif calendar == "IRL" then
  	monthNames = {"January", "February", "March", "April", "May", "June", "July", "August", "September", "October", "November", "December"}
  end

  --Takes the provided variable and seperates it out into a table
  --Also marks if it is only a year or a month and year
  local shortDate = Split(shortDate, "-")
  
  if shortDate[2] == nil then
    dateTable = {nil, nil, nil, tonumber(shortDate[1]), "year"}
  elseif shortDate[3] == nil then
    dateTable = {monthNames[tonumber(shortDate[1])], tonumber(shortDate[1]), nil, tonumber(shortDate[2]), "month-year"}
  else
    dateTable = {monthNames[tonumber(shortDate[1])], tonumber(shortDate[1]), tonumber(shortDate[2]), tonumber(shortDate[3]), "month-day-year"}
  end
  return dateTable
end

--Writes that date based on what is given.
function writeDate(dateTable)
  if dateTable[5] == "year" then
    return dateTable[4]
  elseif dateTable[5] == "month-year" then
    return dateTable[1].." ("..dateTable[2]..") "..dateTable[4]
  elseif dateTable[5] == "month-day-year" then
    return dateTable[1].." ("..dateTable[2]..") "..dateTable[3]..", "..dateTable[4]
  end
end

--Converts a short from date to a long from date using the specified calendar
function p._date(args)
  return writeDate(convertShortDate(args[1], args[2]))
end


--Calculates a persons age using the specified calendar
function p._age(args)
  local birthDate = convertShortDate(args[1], args[4])
  local secondDate = convertShortDate(args[2], args[4])
  local status = args[3]
  
  --Checks which math formula to use, based on how much of the date there is.
  if birthDate[5] == "year" or secondDate == "year" then
    age = math.floor(secondDate[4] - birthDate[4])
  elseif birthDate[5] == "month-year" or secondDate == "month-year" then
    if birthDate[2] <= secondDate[2] then
      age = math.floor(secondDate[4] - birthDate[4])
    elseif birthDate[2] > secondDate[2] then
      age = math.floor(secondDate[4] - birthDate[4] - 1)
    end
  elseif birthDate[5] == "month-day-year" or secondDate == "month-day-year" then
    if birthDate[2] < secondDate[2] then
      age = math.floor(secondDate[4] - birthDate[4])
    elseif birthDate[2] == secondDate[2] then
      if birthDate[3] <= secondDate[3] then
        age = math.floor(secondDate[4] - birthDate[4])
      elseif birthDate[3] > secondDate[3] then
        age = math.floor(secondDate[4] - birthDate[4] - 1)
      end
    elseif birthDate[2] > secondDate[2] then
      age = math.floor(secondDate[4] - birthDate[4] - 1)
    end
  end
  
  --Determines if age or aged is required
  if status == "alive" then
    local longDate = writeDate(birthDate)
    return longDate.." (age "..age..")"
  elseif status == "dead" then
    return writeDate(secondDate).." (aged "..age..")"
  end
end

return p