BigW Consortium Gitlab

time_trackable.rb 1.76 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11
# == TimeTrackable concern
#
# Contains functionality related to objects that support time tracking.
#
# Used by Issue and MergeRequest.
#

module TimeTrackable
  extend ActiveSupport::Concern

  included do
12
    attr_reader :time_spent, :time_spent_user
13 14 15 16 17

    alias_method :time_spent?, :time_spent

    default_value_for :time_estimate, value: 0, allows_nil: false

18 19 20
    validates :time_estimate, numericality: { message: 'has an invalid format' }, allow_nil: false
    validate  :check_negative_time_spent

21
    has_many :timelogs, dependent: :destroy # rubocop:disable Cop/ActiveRecordDependent
22 23
  end

24 25 26 27
  def spend_time(options)
    @time_spent = options[:duration]
    @time_spent_user = options[:user]
    @original_total_time_spent = nil
28

29
    return if @time_spent == 0
30

31
    if @time_spent == :reset
32 33 34 35 36
      reset_spent_time
    else
      add_or_subtract_spent_time
    end
  end
37
  alias_method :spend_time=, :spend_time
38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59

  def total_time_spent
    timelogs.sum(:time_spent)
  end

  def human_total_time_spent
    Gitlab::TimeTrackingFormatter.output(total_time_spent)
  end

  def human_time_estimate
    Gitlab::TimeTrackingFormatter.output(time_estimate)
  end

  private

  def reset_spent_time
    timelogs.new(time_spent: total_time_spent * -1, user: @time_spent_user)
  end

  def add_or_subtract_spent_time
    timelogs.new(time_spent: time_spent, user: @time_spent_user)
  end
60 61 62 63 64 65 66 67 68 69 70 71

  def check_negative_time_spent
    return if time_spent.nil? || time_spent == :reset

    # we need to cache the total time spent so multiple calls to #valid?
    # doesn't give a false error
    @original_total_time_spent ||= total_time_spent

    if time_spent < 0 && (time_spent.abs > @original_total_time_spent)
      errors.add(:time_spent, 'Time to subtract exceeds the total time spent')
    end
  end
72
end