scinote-web/app/datatables/organization_users_datatable.rb
2017-01-11 15:50:11 +01:00

88 lines
2.7 KiB
Ruby

class OrganizationUsersDatatable < AjaxDatatablesRails::Base
include InputSanitizeHelper
def_delegator :@view, :link_to
def_delegator :@view, :update_user_organization_path
def_delegator :@view, :destroy_user_organization_html_path
def initialize(view, org, user)
super(view)
@org = org
@user = user
end
def sortable_columns
@sortable_columns ||= [
"User.full_name",
"User.email",
"UserOrganization.created_at",
"User.confirmed_at",
"UserOrganization.role"
]
end
def searchable_columns
@searchable_columns ||= [
"User.full_name",
"User.email",
"UserOrganization.created_at"
]
end
# A hack that overrides the new_search_contition method default behavior of the ajax-datatables-rails gem
# now the method checks if the column is the created_at and generate a custom SQL to parse
# it back to the caller method
def new_search_condition(column, value)
model, column = column.split('.')
model = model.constantize
formated_date = (I18n.t 'time.formats.datatables_date').gsub!(/^\"|\"?$/, '')
if column == 'created_at'
casted_column = ::Arel::Nodes::NamedFunction.new('CAST',
[ Arel.sql("to_char( users.created_at, '#{ formated_date }' ) AS VARCHAR") ] )
else
casted_column = ::Arel::Nodes::NamedFunction.new('CAST',
[model.arel_table[column.to_sym].as(typecast)])
end
casted_column.matches("%#{value}%")
end
private
# Returns json of current samples (already paginated)
def data
records.map do |record|
{
'DT_RowId': record.id,
'0': escape_input(record.user.full_name),
'1': escape_input(record.user.email),
'2': I18n.l(record.created_at, format: :full),
'3': record.user.active_status_str,
'4': record.role_str,
'5': ApplicationController.new.render_to_string(
partial: "users/settings/organizations/user_dropdown.html.erb",
locals: {
user_organization: record,
update_role_path: update_user_organization_path(record, format: :json),
destroy_uo_link: link_to(
I18n.t("users.settings.organizations.edit.user_dropdown.remove_label"),
destroy_user_organization_html_path(record, format: :json),
remote: true,
data: { action: "destroy-user-organization" }
),
user: @user
}
)
}
end
end
# Query database for records (this will be later paginated and filtered)
# after that "data" function will return json
def get_raw_records
UserOrganization
.includes(:user)
.references(:user)
.where(organization: @org)
.distinct
end
end