Gem source code Demo source code
Author: Bogdan Gusiev

User Grid (basic) Time Entry Grid (advanced)

Time Entries Grid


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