Sha256: 490b314639507268853debd4dc3e9637205e0b22d61007bfff5e8346e9639a7c
Contents?: true
Size: 1.61 KB
Versions: 1
Compression:
Stored size: 1.61 KB
Contents
class EffectiveLogsDatatable < Effective::Datatable datatable do order :updated_at col :updated_at, label: 'Date' col :id, visible: false if attributes[:user] == false # Do not include else col :user, search: :string end unless attributes[:status] == false col :status, search: { collection: EffectiveLogging.statuses } end col :associated_type, search: { as: :string } col :associated_id, search: { as: :integer }, visible: false, label: 'Associated Id' col :associated_to_s, search: { as: :string }, label: 'Associated' col :message do |log| log.message.gsub("\n", '<br>') end col :logs_count, visible: false col :details, visible: false, sort: false do |log| tableize_hash(log.details.except(:email)) end unless attributes[:actions] == false actions_col partial: 'admin/logs/actions', partial_as: :log end end # A nil attributes[:log_id] means give me all the top level log entries # If we set a log_id then it's for sub logs collection do scope = Effective::Log.deep.where(parent_id: attributes[:log_id]) if attributes[:for] user_ids = Array(attributes[:for]) scope = scope.where('user_id IN (?) OR (associated_id IN (?) AND associated_type = ?)', user_ids, user_ids, 'User') end if attributes[:associated_id] && attributes[:associated_type] scope = scope.where(associated_id: attributes[:associated_id], associated_type: attributes[:associated_type]) end if attributes[:associated] scope = scope.where(associated: attributes[:associated]) end scope end end
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
effective_logging-3.1.0 | app/datatables/effective_logs_datatable.rb |