Gem source code Demo source code
Author: Bogdan Gusiev

User Grid (basic) Time Entry Grid (advanced)

Time Entries Grid


Developer Project Report hours
Milagros Lemke vitae eum pariatur 95.0
Jamison Hagenes suscipit consectetur beatae 95.0
Milagros Lemke animi aperiam tenetur 95.0
Shannon Botsford saepe hic temporibus 95.0
Deja Corkery repudiandae officiis qui 94.0
Jeanne Witting saepe hic temporibus 94.0
Micheal Jenkins animi aperiam tenetur 94.0
Maryanna Medhurst animi aperiam tenetur 94.0
Ashleigh Kris suscipit consectetur beatae 94.0
Eleonore Wisozk eum amet quia 93.0
Sylvester Hane repudiandae officiis qui 93.0
Tami Gibson saepe hic temporibus 93.0
Rossana Schneider saepe hic temporibus 93.0
Pearlie McGlynn perspiciatis totam perferendis 92.0
Awilda Schumm saepe hic temporibus 92.0
Grace Kris doloribus hic corporis 92.0
Winfred Franecki doloribus hic corporis 92.0
Lesia Hyatt saepe hic temporibus 92.0
Elida Zulauf saepe hic temporibus 92.0
Wen Daniel suscipit consectetur beatae 92.0
Dona Gutkowski quibusdam sed sit 92.0
Cathey Prohaska quibusdam sed sit 92.0
Malvina Zulauf vitae eum pariatur 92.0
Benita Thompson perspiciatis totam perferendis 91.0
Sixta Bashirian suscipit consectetur beatae 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>