module AdminData module ApplicationHelper def get_sort_order(column) if column == @sort_by_column_name && @sort_order == 'desc' "#{column} asc" else "#{column} desc" end end def get_sort_title_with_url(column, klass) order = get_sort_order(column) link_to column_title(klass, column), search_path(:klass => klass, :query => params[:query], :sortby => order) end def get_sort_class(column) sort_class = 'sortable' if column == @sort_by_column_name sort_class << ' ' + @sort_css end sort_class end def parent_layout(layout) content_for(:layout, self.output_buffer) self.output_buffer = render(:file => "layouts/#{layout}") end def column_title(klass, column) AdminData.config.column_headers[klass.name].try(:fetch,column.intern, nil) || column end # AdminData.config.columns_order might not list all the columns of a given table. However # the listed columns should be at the front in the order mentioned. Primary key will also # be the first column. Consumer might define a new column name that is not listed a column. # def columns_order(klass) columns_symbol = klass.columns.map {|e| e.name.intern} # created_at and updated_at should be at the very end by default if columns_symbol.include? :created_at columns_symbol = (columns_symbol - [:created_at]) + [:created_at] end if columns_symbol.include? :updated_at columns_symbol = (columns_symbol - [:updated_at]) + [:updated_at] end if requested_order = AdminData.config.columns_order[klass.name] primary_key = klass.send(:primary_key).intern order = [primary_key] + requested_order order.uniq! # add the columns not covered by user at the end of the list sorted_columns = order + (columns_symbol - order) sorted_columns.map(&:to_s) else columns_symbol.map(&:to_s) end end def total_records_info(klass) '(Total ' + pluralize(klass.count, 'record') + ' )' end def search_result_title(total_num_of_children, records) output = [] if params[:base] label = params[:base].camelize + ' ID ' + params[:model_id] output << link_to(label, admin_data_path(:klass => params[:base], :id => params[:model_id])) output << 'has' output << pluralize(total_num_of_children, params[:klass]) elsif !params[:query].blank? || params[:adv_search] output << 'Search result:' output << pluralize(records.total_entries, 'record') output << 'found' else output << 'All ' output << params[:klass].camelize output << 'records' end output.join(' ').html_safe end def column_native(klass, column) klass.send(:columns).select {|r| r.instance_variable_get('@name') == column}.first || column end def has_one(model, klass) tmp = ActiveRecordUtil.new(klass).declared_has_one_association_names tmp.inject('') do |output, ho| begin label = ho if model.send(ho) output << link_to(label, admin_data_path(:klass => ho.underscore, :id => model.send(ho))) else output << label end rescue => e Rails.logger.debug Util.exception_info(e) end output end end def has_many_data(model, klass) array = ActiveRecordUtil.new(klass).declared_has_many_association_names.map do |m| begin count = model.send(m.intern).count label = m.to_s + '(' + count.to_s + ')' output = label if count > 0 has_many_klass_name = ActiveRecordUtil.new(model.class).klass_for_association_type_and_name(:has_many, m).name.underscore output = link_to(label, search_path( :klass => has_many_klass_name, :children => m, :base => klass.name.underscore, :model_id => model.id)) end rescue => e Rails.logger.debug Util.exception_info(e) end output end array.join(', ') end def belongs_to_data(model, klass) ActiveRecordUtil.new(klass).declared_belongs_to_association_names.map do |assoc_name| begin output = assoc_name if belongs_to_record = model.send(assoc_name) output = link_to(assoc_name, admin_data_path(:klass => belongs_to_record.class.name.underscore, :id => belongs_to_record.id)) end rescue => e Rails.logger.info Util.exception_info(e) end output end.join(', ') end def habtm_data(model, klass) ActiveRecordUtil.new(klass).declared_habtm_association_names.map do |assoc_name| begin count = model.send(assoc_name.intern).count label = assoc_name + '(' + count.to_s + ')' output = label if count > 0 then has_many_klass_name = ActiveRecordUtil.new(model.class).klass_for_association_type_and_name(:has_and_belongs_to_many, assoc_name).name.underscore output = link_to(label, search_path( :klass => has_many_klass_name, :children => assoc_name, :base => klass.name.underscore, :model_id => model.id)) end rescue => e Rails.logger.info Util.exception_info(e) end output end.join(', ') end def breadcrum(&block) render(:partial => '/admin_data/shared/breadcrum', :locals => {:data => capture(&block)}) end def form_field(klass, model, col, f) html = [] column_value = model.send(col.name) if klass.serialized_attributes.has_key?(col.name) return Util.get_serialized_value(html,column_value) end if col.primary html << model.new_record? ? '(auto)' : model.id elsif get_reflection_for_column(klass, col) && AdminData.config.display_assoc?( klass.name ) form_field_for_association_records(klass, col, f, html) else handle_column_type(col, html, model, column_value, f) end end def form_field_for_association_records(klass, col, f, html) begin reflection = get_reflection_for_column(klass, col) # in some edge cases following code throws exception. investigating .. options = reflection.options if options.keys.include?(:polymorphic) && options.fetch(:polymorphic) build_text_field(html, f, col) else ref_klass = reflection.klass association_name = ref_klass.columns.map(&:name).include?('name') ? :name : ref_klass.primary_key all_for_dropdown = ref_klass.all(:order => "#{association_name} asc") html << f.collection_select(col.name, all_for_dropdown, :id, association_name, :include_blank => true) end html.join rescue Exception => e Rails.logger.info Util.exception_info(e) 'could not retrieve' # returning nil end end def form_field_for_habtm_records(klass, model, f, html) begin html = [] ActiveRecordUtil.new(klass).delcared_habtm_association_names.each do |k| assoc_klass = Util.get_class_name_for_habtm_association(model, k) html << "