1 module UserBlocksHelper
3 # returns a translated string representing the status of the
4 # user block (i.e: whether it's active, what the expiry time is)
5 def block_status(block)
7 # if the block hasn't expired yet show the date, if the user just needs to login show that
9 if block.ends_at > Time.now.getutc
10 I18n.t("user_blocks.helper.time_future_and_until_login", :time => friendly_date(block.ends_at)).html_safe
12 I18n.t("user_blocks.helper.until_login")
15 I18n.t("user_blocks.helper.time_future", :time => friendly_date(block.ends_at)).html_safe
18 # the max of the last update time or the ends_at time is when this block finished
19 # either because the user viewed the block (updated_at) or it expired or was
21 last_time = [block.ends_at, block.updated_at].max
22 I18n.t("user_blocks.helper.time_past", :time => friendly_date_ago(last_time)).html_safe
26 def block_duration_in_words(duration)
27 parts = ActiveSupport::Duration.build(duration).parts
29 I18n.t("user_blocks.helper.block_duration.hours", :count => parts[:hours])
30 elsif duration < 1.week
31 I18n.t("user_blocks.helper.block_duration.days", :count => parts[:days])
32 elsif duration < 1.month
33 I18n.t("user_blocks.helper.block_duration.weeks", :count => parts[:weeks])
34 elsif duration < 1.year
35 I18n.t("user_blocks.helper.block_duration.months", :count => parts[:months])
37 I18n.t("user_blocks.helper.block_duration.years", :count => parts[:years])