debian-mirror-gitlab/lib/api/entities/issuable_time_stats.rb

27 lines
918 B
Ruby
Raw Normal View History

2020-03-13 15:44:24 +05:30
# frozen_string_literal: true
module API
module Entities
class IssuableTimeStats < Grape::Entity
format_with(:time_tracking_formatter) do |time_spent|
Gitlab::TimeTrackingFormatter.output(time_spent)
end
2023-03-04 22:38:38 +05:30
expose :time_estimate, documentation: { type: 'integer', example: 12600 }
expose :total_time_spent, documentation: { type: 'integer', example: 3600 }
expose :human_time_estimate, documentation: { type: 'string', example: '3h 30m' }
2020-03-13 15:44:24 +05:30
with_options(format_with: :time_tracking_formatter) do
2023-03-04 22:38:38 +05:30
expose :total_time_spent, as: :human_total_time_spent, documentation: { type: 'string', example: '1h' }
2020-03-13 15:44:24 +05:30
end
# rubocop: disable CodeReuse/ActiveRecord
def total_time_spent
# Avoids an N+1 query since timelogs are preloaded
2022-05-07 20:08:51 +05:30
object.timelogs.sum(&:time_spent)
2020-03-13 15:44:24 +05:30
end
# rubocop: enable CodeReuse/ActiveRecord
end
end
end