diff --git a/README.md b/README.md index 98b8e44..563829a 100644 --- a/README.md +++ b/README.md @@ -20,7 +20,7 @@ $ gem install user_defined_fields ## Usage -#### Migrations +### Migrations To install the database table necessary to support user defined fields, use the following command: ```bash @@ -49,5 +49,31 @@ class AddUserDefinedFieldsToMyModel < ActiveRecord::Migration[7.0] end ``` +### Components + +User defined fields can be configured one of two ways: At the application level, or at the model level. + +##### Application Level +If configured at the application level, each record in the specified table will contain the same user defined fields. + +For example: You could define `first_name` and `last_name` fields for all of the `people` records. Anytime a user is editing a a person form, the `first_name` and `last_name` fields will be available as inputs. + +```jsx + +``` + +##### Model Level +If configured at the model level, records can contain different fields dependent on a parent record. + +For example: You could define a `location` field for `resources` that belong to Project A, then define a `project_stage` field for `resources` that belong to Project B. On the edit for for Project A, only the `location` field will be available. On the edit form for Project B, only the `project_stage` field will be available. + +```jsx + +``` + ## License The gem is available as open source under the terms of the [MIT License](https://opensource.org/licenses/MIT). diff --git a/app/controllers/user_defined_fields/user_defined_fields_controller.rb b/app/controllers/user_defined_fields/user_defined_fields_controller.rb index b18cc88..e7bc859 100644 --- a/app/controllers/user_defined_fields/user_defined_fields_controller.rb +++ b/app/controllers/user_defined_fields/user_defined_fields_controller.rb @@ -1,5 +1,23 @@ module UserDefinedFields class UserDefinedFieldsController < ApplicationController search_attributes :table_name, :column_name + + protected + + def apply_filters(query) + query = super + + query = filter_defineable(query) + + query + end + + private + + def filter_defineable(query) + return query unless params[:defineable_id].present? && params[:defineable_type].present? + + query.where(defineable_id: params[:defineable_id], defineable_type: params[:defineable_type]) + end end end