Skip to content
scambra edited this page Sep 14, 2010 · 28 revisions
  • I’m using ActiveScaffold, but it looks like a regular scaffold (ugly). Why?
  • 500 Internal Error? That’s not helpful!
  • My associated models look like #. How can I change that?
  • Those subforms are slick, but I want to turn them off. How can I simplify associations on the form?
  • How can I add autocompletion to the form?
  • ActiveScaffold is complaining about a Malformed Constraint. What should I check?
  • I’ve got a table with lots of associations, and my database is choking. Why? What can I do?
  • I’m adding stuff to params[:record] but ActiveScaffold doesn’t use it. Why?
  • I need to customize the CSS (or JavaScript). How should I?

I’m using ActiveScaffold, but it looks like a regular scaffold (ugly). Why?

First thing to check is that you’re including the stylesheet in your layout. Refer back to the steps in Getting Started to see how to include the stylesheet. And you should check the page source, too, to make sure the <style> tag is in there.

If you’ve got that, then check the views directory for your controller. If you’re using a PostsController, then check app/views/posts. Delete (or move) all views out if this directory. There’s a chance you may have run Rails’ built-in scaffold generator, and those views and partials are overriding ActiveScaffold’s own.

Still not working? Come ask in the forums, and mention that you’ve already checked this FAQ.

500 Internal Error? That’s not helpful!

Yeah, you’re right, it’s not really. This error message is designed to walk a fine line between being useful for developers and for end-users, kind of like Gmail’s error messages. The trick here is to know, as a developer, that a 500 response means that an exception happened in your code. Check out the last bit of logs/development.log right after you see a 500 response, and you’ll get to see the actual error.

My associated models look like #. How can I change that?

You want to define a to_label method for your model.


class User < ActiveRecord::Base
  def to_label
    "User: #{username}"
  end
end

Those subforms are slick, but I want to turn them off. How can I simplify associations on the form?
The ui_type = :select option lets you switch the form interface from the standard subform setup to a simple select setup. This configuration can be set per-column.
class UsersController < ApplicationController
active_scaffold :users do |config|

  1. users will no longer be able to create/edit Roles from the Users forms
    config.columns[:roles].ui_type = :select
    end
    end

How can I add autocompletion to the form?
Use a form override to insert all the javascript necessary. Here’s an example from a user in the Google Group, using a partial:


Identity Type
<%= text_field_tag ‘record[identity_type]’, record[:identity_type]%> <div class="auto_complete" id="identity_type_autocomplete_<%=record
[:id]%>" style=“{height: 80px;}”>

<%= javascript_tag(“new Autocompleter.Local(‘record[identity_type]’,
‘identity_type_autocomplete_#{@record[:id]}’,
[‘User’, ‘Group’, ‘AdminUser’],
{fullSearch: true, frequency: 0, minChars: 1});”) -%>

ActiveScaffold is complaining about a Malformed Constraint. What should I check?
If you are noticing this when trying to open a nested scaffold, the first thing to check is that you have your associations set up in both directions. For instance, if a UserGroup has_many Users, then make sure that a User belongs_to a UserGroup. If that doesn’t fix your problem then take another look at your associations – is there a clear “reverse” association? For example, consider the following setup:
class Project < ActiveRecord::Base
has_many :projects_users
has_many :administrators, :through => :projects_users, :source =>
:user, :conditions => “projects_users.role_type = 3”
has_many :managers, :through => :projects_users, :source => :user,
:conditions => “projects_users.role_type = 2”
has_many :workers, :through => :projects_users, :source => :user,
:conditions => “projects_users.role_type = 1”
end

class User < ActiveRecord::Base
belongs_to :organization
has_many :projects_users
has_many :projects, :through => :projects_users, :source => :project
end
This setup may not work as well when ActiveScaffold is trying to nest Projects for a given User. In order to nest successfully, ActiveScaffold needs to know what the reverse association is. In this case the Project doesn’t have a clear single link to the User model – it has three specialized associations. To remedy the situation, you should add:
class Project < ActiveRecord::Base
has_many :users, :through => :projects_users, :source => :user

end

I’ve got a table with lots of associations, and my database is choking. Why? What can I do?
ActiveScaffold attempts to utilize eager loading when displaying the list, under the assumption that every association column will need to display something about the associated records. If this is too much, you have two options:
1. Remove some association columns from the list (e.g. config.list.columns.exclude :association_column)
2. Disable the eager loading for some association columns by setting config.columns[:association_column].includes = nil

I’m adding stuff to params[:record] but ActiveScaffold doesn’t use it. Why?
ActiveScaffold doesn’t just apply the whole params[:record] hash. Instead, it whitelists fields it expects from the form. Which is to say, if ActiveScaffold didn’t know that role_id was supposed to be on the form, it will ignore the params[:record][:role_id] entry. If it didn’t work this way, then URL hackers could submit extra data and do all kinds of fun things including privilege escalation.
If you need to apply your own data to the record before its gets saved, what you should do instead is define before_create_save(record) or before_update_save(record) on your controller. ActiveScaffold will check for these methods and pass them the record object so you can do common things like attach the current user as the record’s owner.

I need to customize the CSS (or JavaScript). What’s the best way?
Don’t edit the ActiveScaffold files in public/! These files are automatically copied from vendor/plugins/active_scaffold every time the server starts, to make sure you’re using the latest code. Instead, treat them the same way you’d treat the rest of the ActiveScaffold code – override them somewhere else, or use Piston and edit the original file in vendor/plugins/active_scaffold.
For example, if you want to customize the CSS, create public/stylesheets/active_scaffold_overrides.css and include that file in your layout by placing <%= stylesheet_link_tag ‘active_scaffold_overrides’ > after the <%= active_scaffold_includes >.

Clone this wiki locally