Gem source code Demo source code
Author: Bogdan Gusiev

User Grid (basic) Time Entry Grid (advanced)

Time Entries Grid


Developer Project Report hours
Alex Legros eum amet quia 88.0
Vivien Murray animi aperiam tenetur 88.0
Sylvester Hane vitae eum pariatur 88.0
Joelle Hodkiewicz odio velit repudiandae 88.0
Rossana Schneider repudiandae officiis qui 88.0
Dania Crona suscipit consectetur beatae 88.0
Alex Legros saepe hic temporibus 88.0
Blake Hoppe saepe hic temporibus 88.0
Myrtle O'Conner saepe hic temporibus 87.0
Grace Kris saepe hic temporibus 87.0
Jarvis Ryan odio velit repudiandae 87.0
Maryanna Medhurst repudiandae officiis qui 87.0
Raquel Runolfsson animi aperiam tenetur 87.0
Almeta Adams saepe hic temporibus 87.0
Tess Nikolaus vitae eum pariatur 86.0
Juliana Hauck eum amet quia 86.0
Jarvis Ryan quibusdam sed sit 86.0
Elida Zulauf quibusdam sed sit 86.0
Jamie Stehr eum amet quia 86.0
Lesia Hyatt vitae eum pariatur 86.0
Dania Crona doloribus hic corporis 85.0
Desmond Murray saepe hic temporibus 85.0
Shane Glover repudiandae officiis qui 85.0
German Murphy saepe hic temporibus 85.0
Adrienne Eichmann vitae eum pariatur 85.0

Grid:

class TimeEntriesGrid < BaseGrid

  #
  # 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 => lambda {Project.all.map {|p| [p.name, p.id]}},
    :multiple => true,
    :include_blank => false
  ) do |value|
    self.where(:time_entries => {:project_id => value})
  end


  filter(:year, :enum,
         :select => lambda { TimeEntry.all.any? ? (TimeEntry.minimum(:date).year..TimeEntry.maximum(:date).year) : []},
    :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 => Date::MONTHNAMES[1..12].enum_for(:each_with_index).collect {|name, index| [name, index + 1]},
         :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)")

end

Controller:

class TimeEntriesController < ApplicationController

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

View:


<h3>Time Entries Grid</h3>


<div class="left">
  <%= datagrid_form_for @time_entries_grid, url: time_entries_path %>
  <br/>

  <%= datagrid_table(@time_entries_grid) %>
  <%= paginate @time_entries_grid.assets %>

</div>

<div class="right">
  <%= render :partial => "shared/source", :object => @time_entries_grid %>
</div>