Users (Basic) Time Sheets (Advanced) Issues (API)

Developer Project Company Report hours
Jeanne Witting vitae eum pariatur
Google
65.0
Jewell Kreiger vitae eum pariatur
Google
49.0
Jewell Swaniawski vitae eum pariatur
Google
62.0
Joelle Hodkiewicz vitae eum pariatur
Google
42.0
Johnny Spinka vitae eum pariatur
Google
74.0
Jon Lindgren vitae eum pariatur
Google
54.0
Juliana Hauck vitae eum pariatur
Google
95.0
Kaye Greenfelder vitae eum pariatur
Google
71.0
Kellie Cassin vitae eum pariatur
Google
31.0
Lesia Hyatt vitae eum pariatur
Google
45.0
Li Considine vitae eum pariatur
Google
49.0
Lillie Hamill vitae eum pariatur
Google
45.0
Lynell Stamm vitae eum pariatur
Google
64.0
Malvina Zulauf vitae eum pariatur
Google
92.0
Marna Ritchie vitae eum pariatur
Google
32.0
Maryanna Medhurst vitae eum pariatur
Google
45.0
Micheal Jenkins vitae eum pariatur
Google
62.0
Milagros Lemke vitae eum pariatur
Google
95.0
Mi Prosacco vitae eum pariatur
Google
43.0
Myriam Von vitae eum pariatur
Google
59.0
Myrtle O'Conner vitae eum pariatur
Google
90.0
Nelson Leannon vitae eum pariatur
Google
37.0
Ophelia Hermiston vitae eum pariatur
Google
86.0
Palmira Fay vitae eum pariatur
Google
104.0
Pearlie McGlynn vitae eum pariatur
Google
64.0

Grid:

class TimeEntriesGrid < ApplicationGrid

  #
  # Scope
  #

  scope do
    User.select(
      "users.name",
      "projects.name as project_name",
      "accounts.name as account_name",
      "sum(time_entries.hours) as report_hours"
    ).joins(
      time_entries: {project: :account}
    ).group("projects.name", "users.name", "accounts.name").
    order("users.name")
  end


  #
  # Filters
  #

  filter(
    :project_id, :enum,
    :select => :project_id_select,
    :multiple => true,
    :include_blank => false
  ) do |value|
    self.where(:time_entries => {:project_id => value})
  end


  filter(
    :year, :enum,
    :select => :year_select,
    :include_blank => false,
    :default => lambda {Date.today.year}
  ) do |value|
    self.where([
      "extract(year from time_entries.date) = ?",
      value.to_i
    ])
  end

  filter(
    :month, :enum,
    :select => :month_select,
    :include_blank => false,
    :default => lambda {Date.today.month}
  ) do |value|

    self.where([
      "extract(month from time_entries.date) = ?",
      value.to_i
    ])
  end


  #
  # Columns
  #

  column(:user_name, :header => "Developer", :order => "users.name") do
    self.name
  end
  column(:project_name, :header => "Project", :order => "projects.name")
  column(
    :account_name,
    :header => "Company",
    :order => "accounts.name",
  ) do |model|
    format(model.account_name) do
      render :partial => "time_entries/company", :locals => {:model => model}
    end
  end

  column(:report_hours, order: "sum(time_entries.hours)")

  protected

  def year_select
    TimeEntry.all.any? ? (TimeEntry.minimum(:date).year..TimeEntry.maximum(:date).year) : []
  end
  def month_select
    Date::MONTHNAMES[1..12].enum_for(:each_with_index).collect {|name, index| [name, index + 1]}
  end

  def project_id_select
    Project.all.map {|p| [p.name, p.id]}
  end
end

Controller:

class TimeEntriesController < ApplicationController

  def index
    @time_entries_grid = TimeEntriesGrid.new(params[:g]) do |scope|
      scope.page(params[:page] )
    end
  end
end

View:

.grid-index-grid
  %div{class: 'overflow-x-auto p-4'}
    = datagrid_form_with model: @time_entries_grid, url: time_entries_path
    %br/
    = datagrid_table(@time_entries_grid)
    = paginate @time_entries_grid.assets, window: 2
  %div
    = render :partial => "shared/source", :object => @time_entries_grid