Skip to content
yairgo edited this page Sep 14, 2010 · 63 revisions

actions global local

The components of ActiveScaffold (e.g. Create, Update, Delete, Show) are called actions. This setting lets you define which ones are active. Only actions present in this list will be configurable. Only actions present in this list will be mixed into your controllers.

Examples:


config.actions = [:create, :update, :show]
config.actions.exclude :create
config.actions.add :delete
config.actions.swap :search, :live_search

action_links global local

If you want to tie ActiveScaffold to a custom action, or to some other page or controller or site or whatever, you can create your own action link. This setting is just for your custom action link: the action links used by various action components are editable within the configuration for that action component (e.g. config.create.link). See API: Action Link for details on the per-link options.

Examples:


  1. Add an action link (with options)
    config.action_links.add ‘get_pdf’, :label => ‘Download PDF
  1. You can look up and modify action links by searching by the :action attribute
    config.action_links[‘get_pdf’].label = ‘Save PDF
  1. Quick-add (doesn’t accept options)
    config.action_links << ‘print_pdf’
  1. NOTE: if you want to edit a “native” link, you can find it on the proper config object
    config.show.link.label = ‘Display Record’

columns local

The columns setting is a collection of metadata about attributes of your model. Columns in here may be simple attributes, virtual fields (fields with just an accessor on the model), or associations. See API: Column for details on per-column configuration.

WARNING FOR VERSION 1.0: redefining this collection via config.columns = [...] may have unexpected consequences! Any column used by ActiveScaffold on this controller for anything should exist in this collection. If you want to remove a particular column from use in a particular action, then use the appropriate config.#{action}.columns collection (e.g. config.list.columns).

As of version 1.1, adding and removing columns from this collection will add/remove the columns from all components (create, update, list, etc.).

Examples:


  1. Add a column (virtual, probably)
    config.columns.add :first_and_last_name
    config.columns << :name_spelled_backwards
  1. Edit a column (options described below)
    config.columns[:first_and_last_name].label = ‘Full Name’
  1. Remove a column from Create, Update, List, etc. (version 1.1+)
    config.columns.exclude :sekret_field

config.list.columns, config.create.columns, config.update.columns inherit from config.columns

By default, config.columns contains all of the columns for your model, including primary key, foreign key identifiers, created/updated_on/at, etc. These other fields

config.list.columns, config.create.columns, and config.update.columns inherit their columns from config.columns. However, by default, some columns are excluded by default: foreign key identifiers such as `user_id`, the `id` column, and the `created/updated_at/on` fields.

(this section removable for v1.1)

formats

Active scaffold supports html, js, json, yaml, and xml formats by default. If you need to add another mime type for your controller you can do it here. The format is then added to the default formats.

Examples:


  1. Add a column (virtual, probably)
    config.formats << :pdf
    or
    config.formats = [:pdf]

Real, Association, and Virtual Columns

The minimum requirement for an ActiveScaffold column is an accessor on the model. If the accessor is named the same as a database attribute, then it’s a “real” column. If the accessor is named the same as an association, then it’s an “association” column (these accessors are a special type of virtual column created and managed by ActiveRecord, e.g. @user.user_group). Otherwise it’s a “virtual” column.

In general, ActiveScaffold’s default column set will include one column for every database attribute and one column for every association. If you want to use virtual columns (which can be very handy), you’ll need to add them in yourself.

Examples:


class User < ActiveRecord::Base
  1. defining an association will also create an association column with the same name
    has_and_belongs_to_many :roles
  1. create an accessor that can be used as a virtual column
    def first_and_last_name
    “#{self.first_name} #{self.last_name}”
    end
    end

class UserController < ApplicationController
active_scaffold :users do |config|

  1. In the List view, we’ll combine two fields into one by hiding two “real” fields and adding one “virtual” field.
    config.list.columns.exclude :first_name, :last_name
    config.list.columns << :first_and_last_name
  1. If you want to customize the metadata on the virtual field, you need to add it to the main columns object.
    config.columns << :first_and_last_name
    config.columns[:first_and_last_name].label = ‘Full Name’
    end
    end

dhtml_history global v1.1

The DHTML History is javascript designed to save the state of the page in the URL, so that if someone refreshes or bookmarks the page, the page can return to the way it was. If this is causing problems for you, or you just don’t like the overhead, you can disable the dhtml history altogether.


class ApplicationController < ActionController::Base
  ActiveScaffold.set_defaults do |config|
    # disables dhtml history globally
    config.dhtml_history = false
  end
end

frontend global local

ActiveScaffold is skinnable by creating and using different frontends. These frontends can package up completely different javascript, stylesheets, images, language files, and partials. They are a powerful way of potentially changing the entire UI for ActiveScaffold to blend with your design. Any partial called for by the ActiveScaffold code that is not provided by a frontend will fallback to using the partial from the default frontend.

When more frontends are shipped with ActiveScaffold, or when you have written your own, you can decide which frontend to use either globally or on a per-controller basis.

Examples:


config.frontend = :shiny_new_frontend

ignore_columns global

If your database schema has special fields that should just be ignored by ActiveScaffold, you can define a global blacklist here. This is meant to be used on the ApplicationController. If you want to exclude columns in some specific scaffold, use the config.#{action}.columns.exclude method.

Examples:


config.ignore_columns = [:created_at, :updated_at, :lock_version]
config.ignore_columns.add :is_deleted

label local

This is a string giving a base name for the entire scaffold. This base name will be extended appropriately by actions, unless those actions have explicitely defined their own labels. For example, if might set config.label = 'Customers', and then the Create action would have a label like “Create Customer”. This label makes the most sense as a plural noun describing the records in the collection.

Examples:


config.label = 'Customers'

theme global local

For each frontend there may by a set of available themes: different look and feels for the same underlying UI (frontend). Themes are entirely CSS based.

Examples:


config.theme = :default
config.theme = :blue # AjaxScaffold look with a blue header

active_scaffold_controller_for override method

This class method accepts an ActiveRecord::Base klass and returns an ActionController::base klass (a constant, not a string). We use the method to link controllers together (like for API: Nested), and to find configuration of associated models (like for API: Subforms). The default behavior is to try and search for a singular or plural version of #{model}Controller within the namespace of the current controller. If this doesn’t work for you, maybe because you have your own convention or because you have one controller that doesn’t match up, you can override active_scaffold_controller_for to define your own search pattern.

Example:


class ApplicationController < ActionController::base
protected
def self.active_scaffold_controller_for(klass)
return FooController if klass == Bar
return “#{klass}ScaffoldController”.constantize rescue super
end

end

Clone this wiki locally