Gem source code Demo source code
Author: Bogdan Gusiev

User Grid (basic) Time Entry Grid (advanced)

Time Entries Grid


Developer Project Report hours
Shane Glover quibusdam sed sit 98.0
Tami Gibson animi aperiam tenetur 97.0
Shara Labadie repudiandae officiis qui 97.0
Felisa Jaskolski repudiandae officiis qui 97.0
Wen Daniel eum amet quia 96.0
Tamika Cronin odio velit repudiandae 96.0
Royce Spencer repudiandae officiis qui 96.0
Almeta Adams repudiandae officiis qui 95.0
Winfred Franecki quibusdam sed sit 95.0
Grace Kris repudiandae officiis qui 95.0
Dania Crona saepe hic temporibus 95.0
Kellie Cassin doloribus hic corporis 94.0
Cathey Prohaska saepe hic temporibus 94.0
Malvina Zulauf repudiandae officiis qui 94.0
Terisa Ruecker saepe hic temporibus 94.0
Claudette Hagenes animi aperiam tenetur 94.0
Dania Crona perspiciatis totam perferendis 94.0
Huong McKenzie repudiandae officiis qui 93.0
Elsa Goodwin doloribus hic corporis 92.0
Kellie Cassin vitae eum pariatur 92.0
Joelle Hodkiewicz saepe hic temporibus 92.0
Maryanna Medhurst suscipit consectetur beatae 92.0
Juliana Hauck animi aperiam tenetur 91.0
Shane Glover odio velit repudiandae 91.0
Pearlie McGlynn quibusdam sed sit 91.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>