No commit activity in last 3 years
No release in over 3 years
adds getter and setters for an existing attribute to covnert between seconds, minutes, hours, and days
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Development

Runtime

~> 4.0.3
 Project Readme

#ActsAsDuration

Say you have an attribute in your ActiveRecord model called total_minutes. Simply add acts_as_duration :total_minutes and you'll automatically get the following converter getter/setter methods:

total_seconds
total_seconds=
total_hours
total_hours=
total_days
total_days=
total_hhmmss
total_hhmmss=

Note: the getter methods will always return a Float (except hhmmss, which returns a String). The setter methods will accept an Integer, String, or Float.

Note: the base attribute name should contain either 'seconds', 'minutes', 'hours', 'days', or 'hhmmss' otherwise the gem can't know the base unit.

Alternatively, you can specify the unit like this: acts_as_duration :total_consumed, attr_unit: :minutes

#Example

class Foo < ActiveRecord::Base
  attr_accessor :total_minutes
  acts_as_duration :total_minutes  
end

foo = Foo.new(total_minutes: 400)
foo.total_minutes
# 400
foo.total_seconds
# 24000.0
foo.total_seconds = 1500
# 1500
foo.total_minutes
# 25.0

## You also have a hhmmss method!
foo.total_hhmmss = "24:12:34"
# "24:12:34"
foo.total_days
# 1.01
foo.total_hours
# 24.21
foo.total_hhmmss = "48"
# "48"
foo.total_days
# 2.0

Arguments

You can call it on multiple attributes at once and include options at the end.

acts_as_duration :total_minutes, :completed_days, read_only: true

####Options: attr_unit: Either :seconds, :minutes, :hours, :days, or :hhmmss. Specify the unit of the base attribute (not necessary if it's already part of the attribute name like e.g. total_seconds)

read_only: true or false. If true, will only create the getter method and not the setter

This project rocks and uses MIT-LICENSE.