summaryrefslogtreecommitdiff
path: root/app/graphql/types/timelog_type.rb
blob: 3a060518cd97b558151faf64988a491bc6714e1c (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
# frozen_string_literal: true

module Types
  class TimelogType < BaseObject
    graphql_name 'Timelog'

    connection_type_class(Types::TimeTracking::TimelogConnectionType)

    authorize :read_issuable

    expose_permissions Types::PermissionTypes::Timelog

    field :id,
          GraphQL::Types::ID,
          null: false,
          description: 'Internal ID of the timelog.'

    field :spent_at,
          Types::TimeType,
          null: true,
          description: 'Timestamp of when the time tracked was spent at.'

    field :time_spent,
          GraphQL::Types::Int,
          null: false,
          description: 'Time spent displayed in seconds.'

    field :user,
          Types::UserType,
          null: false,
          description: 'User that logged the time.'

    field :issue,
          Types::IssueType,
          null: true,
          description: 'Issue that logged time was added to.'

    field :merge_request,
          Types::MergeRequestType,
          null: true,
          description: 'Merge request that logged time was added to.'

    field :note,
          Types::Notes::NoteType,
          null: true,
          description: 'Note where the quick action was executed to add the logged time.'

    field :summary, GraphQL::Types::String,
          null: true,
          description: 'Summary of how the time was spent.'

    def user
      Gitlab::Graphql::Loaders::BatchModelLoader.new(User, object.user_id).find
    end

    def issue
      Gitlab::Graphql::Loaders::BatchModelLoader.new(Issue, object.issue_id).find
    end

    def spent_at
      object.spent_at || object.created_at
    end
  end
end