module EffectiveDatatablesHelper def render_datatable(datatable, opts = {}, &block) datatable.view = self locals = {:style => :full, :filterable => true, :sortable => true, :table_class => 'table-bordered table-striped'}.merge(opts) render :partial => 'effective/datatables/datatable', :locals => locals.merge(:datatable => datatable) end def render_simple_datatable(datatable, opts = {}) datatable.view = self datatable.per_page = :all locals = {:style => :simple, :filterable => false, :sortable => false, :table_class => 'table-bordered table-striped sorting-hidden'}.merge(opts) render :partial => 'effective/datatables/datatable', :locals => locals.merge(:datatable => datatable) end def render_datatable_header_cell(form, name, opts, filterable = true) return content_tag(:p, opts[:label] || name) if filterable == false case opts[:filter][:type] when :string, :text, :number form.input name, :label => false, :required => false, :as => :string, :placeholder => (opts[:label] || name), :input_html => { :name => nil, :autocomplete => 'off', :data => {'column-name' => opts[:name], 'column-index' => opts[:index]} } when :select, :boolean if opts[:filter][:values].respond_to?(:call) opts[:filter][:values] = opts[:filter][:values].call() if opts[:filter][:values].kind_of?(ActiveRecord::Relation) || (opts[:filter][:values].kind_of?(Array) && opts[:filter][:values].first.kind_of?(ActiveRecord::Base)) opts[:filter][:values] = opts[:filter][:values].map { |obj| [obj.to_s, obj.id] } end end form.input name, :label => false, :required => false, :as => :select, :collection => opts[:filter][:values], :include_blank => (opts[:label] || name.titleize), :input_html => { :name => nil, :autocomplete => 'off', :data => {'column-name' => opts[:name], 'column-index' => opts[:index]} } else content_tag(:p, opts[:label] || name) end end def datatable_non_sortable(datatable, sortable = true) [].tap do |nonsortable| datatable.table_columns.values.each_with_index { |options, x| nonsortable << x if options[:sortable] == false || sortable == false } end.to_json() end def datatable_non_visible(datatable) [].tap do |nonvisible| datatable.table_columns.values.each_with_index do |options, x| visible = (options[:visible].respond_to?(:call) ? datatable.instance_exec(&options[:visible]) : options[:visible]) nonvisible << x if visible == false end end.to_json() end def datatable_default_order(datatable) [ if datatable.default_order.present? index = (datatable.table_columns.values.find { |options| options[:name] == datatable.default_order.keys.first.to_s }[:index] rescue nil) [index, datatable.default_order.values.first] if index.present? end || [0, 'asc'] ].to_json() end def datatable_widths(datatable) datatable.table_columns.values.map { |options| {'sWidth' => options[:width]} if options[:width] }.to_json() end def datatable_column_classes(datatable) [].tap do |classes| datatable.table_columns.values.each_with_index do |options, x| classes << {:className => options[:class], :targets => [x]} if options[:class].present? end end.to_json() end def datatable_column_names(datatable) datatable.table_columns.values.map { |options| {:name => options[:name], :targets => options[:index] } }.to_json() end def datatables_admin_path? @datatables_admin_path ||= ( path = request.path.to_s.downcase.chomp('/') + '/' referer = request.referer.to_s.downcase.chomp('/') + '/' (attributes[:admin_path] || referer.include?('/admin/') || path.include?('/admin/')) rescue false ) end # TODO: Improve on this def datatables_active_admin_path? attributes[:active_admin_path] rescue false end end