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

Developer Project Company Report hours
Adrienne Eichmann odio velit repudiandae
Apple
49.0
Alex Legros odio velit repudiandae
Apple
110.0
Alise Rolfson odio velit repudiandae
Apple
27.0
Almeta Adams odio velit repudiandae
Apple
79.0
Arnita Smith odio velit repudiandae
Apple
62.0
Ashleigh Kris odio velit repudiandae
Apple
47.0
Awilda Schumm odio velit repudiandae
Apple
53.0
Benita Thompson odio velit repudiandae
Apple
83.0
Beverlee Auer odio velit repudiandae
Apple
67.0
Blake Hoppe odio velit repudiandae
Apple
90.0
Bok Wolf odio velit repudiandae
Apple
43.0
Bong Witting odio velit repudiandae
Apple
40.0
Bridgett Reilly odio velit repudiandae
Apple
61.0
Brigid McLaughlin odio velit repudiandae
Apple
62.0
Britney Ruecker odio velit repudiandae
Apple
43.0
Carlota Gottlieb odio velit repudiandae
Apple
105.0
Cathey Prohaska odio velit repudiandae
Apple
70.0
Cherly Kovacek odio velit repudiandae
Apple
83.0
Claudette Hagenes odio velit repudiandae
Apple
47.0
Clifton Hintz odio velit repudiandae
Apple
74.0
Crissy Brekke odio velit repudiandae
Apple
47.0
Cristopher Dooley odio velit repudiandae
Apple
47.0
Dahlia Hilll odio velit repudiandae
Apple
70.0
Dania Crona odio velit repudiandae
Apple
38.0
Deja Corkery odio velit repudiandae
Apple
82.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