Gem source code Demo source code
Author: Bogdan Gusiev

User Grid (basic) Time Entry Grid (advanced)

Time Entries Grid


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