dynamic_fieldsets 0.0.16 → 0.1.0
Sign up to get free protection for your applications and to get access to all the features.
- data/.rdebugrc +3 -0
- data/.rspec +1 -0
- data/CHANGELOG +7 -0
- data/Gemfile +17 -8
- data/Gemfile.lock +77 -60
- data/README.rdoc +1 -1
- data/VERSION +1 -1
- data/app/controllers/dynamic_fieldsets/fields_controller.rb +5 -4
- data/app/helpers/dynamic_fieldsets_helper.rb +48 -131
- data/app/models/dynamic_fieldsets.rb +2 -0
- data/app/models/dynamic_fieldsets/checkbox_field.rb +29 -0
- data/app/models/dynamic_fieldsets/date_field.rb +37 -0
- data/app/models/dynamic_fieldsets/datetime_field.rb +36 -0
- data/app/models/dynamic_fieldsets/dependency.rb +1 -1
- data/app/models/dynamic_fieldsets/dependency_clause.rb +1 -1
- data/app/models/dynamic_fieldsets/dependency_group.rb +1 -1
- data/app/models/dynamic_fieldsets/field.rb +170 -42
- data/app/models/dynamic_fieldsets/field_default.rb +3 -3
- data/app/models/dynamic_fieldsets/field_html_attribute.rb +1 -1
- data/app/models/dynamic_fieldsets/field_option.rb +1 -1
- data/app/models/dynamic_fieldsets/field_record.rb +1 -1
- data/app/models/dynamic_fieldsets/fieldset.rb +36 -1
- data/app/models/dynamic_fieldsets/fieldset_associator.rb +9 -34
- data/app/models/dynamic_fieldsets/fieldset_child.rb +43 -24
- data/app/models/dynamic_fieldsets/instruction_field.rb +35 -0
- data/app/models/dynamic_fieldsets/multiple_select_field.rb +43 -0
- data/app/models/dynamic_fieldsets/radio_field.rb +27 -0
- data/app/models/dynamic_fieldsets/select_field.rb +16 -0
- data/app/models/dynamic_fieldsets/text_field.rb +14 -0
- data/app/models/dynamic_fieldsets/textarea_field.rb +40 -0
- data/app/views/dynamic_fieldsets/fields/_form.html.erb +50 -52
- data/app/views/dynamic_fieldsets/fields/edit.html.erb +5 -2
- data/app/views/dynamic_fieldsets/fields/index.html.erb +1 -1
- data/app/views/dynamic_fieldsets/fields/new.html.erb +3 -1
- data/app/views/dynamic_fieldsets/fields/show.html.erb +1 -1
- data/app/views/dynamic_fieldsets/fieldsets/_child.html.erb +1 -1
- data/app/views/dynamic_fieldsets/form_partials/_checkbox_field.html.erb +8 -0
- data/app/views/dynamic_fieldsets/form_partials/_date_field.html.erb +1 -0
- data/app/views/dynamic_fieldsets/form_partials/_datetime_field.html.erb +1 -0
- data/app/views/dynamic_fieldsets/form_partials/_input_footer.html.erb +1 -0
- data/app/views/dynamic_fieldsets/form_partials/_input_header.html.erb +7 -0
- data/app/views/dynamic_fieldsets/form_partials/_instruction_field.html.erb +1 -0
- data/app/views/dynamic_fieldsets/form_partials/_multiple_select_field.html.erb +1 -0
- data/app/views/dynamic_fieldsets/form_partials/_radio_field.html.erb +8 -0
- data/app/views/dynamic_fieldsets/form_partials/_select_field.html.erb +1 -0
- data/app/views/dynamic_fieldsets/form_partials/_text_field.html.erb +1 -0
- data/app/views/dynamic_fieldsets/form_partials/_textarea_field.html.erb +1 -0
- data/app/views/dynamic_fieldsets/shared/_javascript_watcher.html.erb +8 -8
- data/app/views/dynamic_fieldsets/show_partials/_show_incomplete.html.erb +1 -0
- data/app/views/dynamic_fieldsets/show_partials/_show_incomplete_footer.html.erb +2 -0
- data/app/views/dynamic_fieldsets/show_partials/_show_incomplete_header.html.erb +1 -0
- data/app/views/dynamic_fieldsets/show_partials/_show_instruction.html.erb +1 -0
- data/app/views/dynamic_fieldsets/show_partials/_show_multiple_answers.html.erb +13 -0
- data/app/views/dynamic_fieldsets/show_partials/_show_single_answer.html.erb +8 -0
- data/autotest/discover.rb +2 -0
- data/dynamic_fieldsets.gemspec +74 -20
- data/lib/dynamic_fieldsets/config.rb +45 -0
- data/lib/dynamic_fieldsets/dynamic_fieldsets_in_model.rb +38 -63
- data/lib/dynamic_fieldsets/field_with_field_options.rb +58 -0
- data/lib/dynamic_fieldsets/field_with_multiple_answers.rb +89 -0
- data/lib/dynamic_fieldsets/field_with_single_answer.rb +84 -0
- data/lib/dynamic_fieldsets/railtie.rb +6 -1
- data/lib/generators/dynamic_fieldsets/install_generator.rb +3 -3
- data/lib/generators/dynamic_fieldsets/templates/config.rb +15 -0
- data/lib/generators/dynamic_fieldsets/templates/migrations/install_migration.rb +1 -1
- data/spec/dummy/config/initializers/dynamic_fieldsets.rb +15 -0
- data/spec/dummy/db/migrate/20120213211033_create_dynamic_fieldsets_tables.rb +1 -1
- data/spec/dummy/db/schema.rb +1 -1
- data/spec/dummy/features/step_definitions/field_steps.rb +4 -4
- data/spec/dummy/features/step_definitions/fieldset_children_steps.rb +2 -2
- data/spec/dummy/features/step_definitions/javascript_steps.rb +7 -7
- data/spec/dynamic_fieldsets_helper_spec.rb +278 -312
- data/spec/dynamic_fieldsets_in_model_spec.rb +2 -2
- data/spec/field_with_field_options_spec.rb +49 -0
- data/spec/field_with_multiple_answers_spec.rb +50 -0
- data/spec/field_with_single_answer_spec.rb +51 -0
- data/spec/models/checkbox_field_spec.rb +19 -0
- data/spec/models/date_field_spec.rb +24 -0
- data/spec/models/datetime_field_spec.rb +24 -0
- data/spec/models/dependency_clause_spec.rb +7 -8
- data/spec/models/dependency_group_spec.rb +27 -30
- data/spec/models/dependency_spec.rb +8 -9
- data/spec/models/field_default_spec.rb +19 -14
- data/spec/models/field_html_attribute_spec.rb +3 -4
- data/spec/models/field_option_spec.rb +8 -9
- data/spec/models/field_record_spec.rb +8 -9
- data/spec/models/field_spec.rb +195 -94
- data/spec/models/fieldset_associator_spec.rb +39 -41
- data/spec/models/fieldset_child_spec.rb +99 -47
- data/spec/models/fieldset_spec.rb +25 -29
- data/spec/models/instruction_field_spec.rb +38 -0
- data/spec/models/multiple_select_field_spec.rb +31 -0
- data/spec/models/radio_field_spec.rb +21 -0
- data/spec/models/text_field_spec.rb +19 -0
- data/spec/models/textarea_field_spec.rb +39 -0
- data/spec/support/field_helper.rb +1 -1
- metadata +106 -28
@@ -0,0 +1,58 @@
|
|
1
|
+
module DynamicFieldsets
|
2
|
+
# Adds methods to a model extending DynamicFieldsets::Field so that it works with field options
|
3
|
+
# when saving and accessing data
|
4
|
+
module FieldWithFieldOptions
|
5
|
+
def self.included(base)
|
6
|
+
base.extend ClassMethods
|
7
|
+
end
|
8
|
+
|
9
|
+
module ClassMethods
|
10
|
+
def acts_as_field_with_field_options(args = {})
|
11
|
+
validate :at_least_one_field_option
|
12
|
+
include DynamicFieldsets::FieldWithFieldOptions::InstanceMethods
|
13
|
+
end
|
14
|
+
end
|
15
|
+
|
16
|
+
module InstanceMethods
|
17
|
+
|
18
|
+
# Collects the field records for the field so they can be used on the front end
|
19
|
+
# These are only the currently saved values in the database, don't worry
|
20
|
+
# about defaults here
|
21
|
+
#
|
22
|
+
# Converts the ids into field option names for :name part of the return hash
|
23
|
+
#
|
24
|
+
# @return [Array] An array of field record values
|
25
|
+
def collect_field_records_by_fsa_and_fsc(fsa, fsc)
|
26
|
+
records = DynamicFieldsets::FieldRecord.where(:fieldset_associator_id => fsa.id, :fieldset_child_id => fsc.id)
|
27
|
+
return records.collect do |r|
|
28
|
+
{
|
29
|
+
:value => r.value,
|
30
|
+
:name => DynamicFieldsets::FieldOption.find(r.value.to_i).name
|
31
|
+
}
|
32
|
+
end
|
33
|
+
end
|
34
|
+
|
35
|
+
# given a value hash for a field, return the part that needs to be shown on the show page
|
36
|
+
def get_value_for_show(value)
|
37
|
+
value[:name]
|
38
|
+
end
|
39
|
+
|
40
|
+
def uses_field_options?
|
41
|
+
true
|
42
|
+
end
|
43
|
+
|
44
|
+
# validation for field options
|
45
|
+
def at_least_one_field_option
|
46
|
+
if self.field_options.empty?
|
47
|
+
self.errors.add(:field_options, "This field must have options")
|
48
|
+
end
|
49
|
+
end
|
50
|
+
|
51
|
+
# @return [FieldOptions] Returns all field options that are enabled
|
52
|
+
def options
|
53
|
+
return self.field_options.reject{ |option| !option.enabled }
|
54
|
+
end
|
55
|
+
end
|
56
|
+
end
|
57
|
+
end
|
58
|
+
|
@@ -0,0 +1,89 @@
|
|
1
|
+
module DynamicFieldsets
|
2
|
+
module FieldWithMultipleAnswers
|
3
|
+
def self.included(base)
|
4
|
+
base.extend ClassMethods
|
5
|
+
end
|
6
|
+
|
7
|
+
module ClassMethods
|
8
|
+
def acts_as_field_with_multiple_answers(args = {})
|
9
|
+
include DynamicFieldsets::FieldWithMultipleAnswers::InstanceMethods
|
10
|
+
end
|
11
|
+
end
|
12
|
+
|
13
|
+
module InstanceMethods
|
14
|
+
|
15
|
+
def show_partial_locals(args)
|
16
|
+
output = super(args)
|
17
|
+
output[:values] = args[:values].collect { |value| get_value_for_show(value) }
|
18
|
+
return output
|
19
|
+
end
|
20
|
+
|
21
|
+
# Updates the field records for the field based on the given values
|
22
|
+
#
|
23
|
+
# Manages multiple records
|
24
|
+
#
|
25
|
+
# @param [DynamicFieldsets::FieldsetAssociator] fsa The associator the value is attached to
|
26
|
+
# @param [DynamicFieldsets::FieldsetChild] fieldset_child The fieldset child for the value
|
27
|
+
# @param [Array or String] value The new values inputted by the user from the form
|
28
|
+
def update_field_records(fsa, fieldset_child, values)
|
29
|
+
# make sure values is an array in case the input from the form is bad
|
30
|
+
throw "Form value type mismatch error: The value from the form must be Array for #{self.inspect}." unless values.is_a?(Array)
|
31
|
+
|
32
|
+
# create new records if the values are not in the db
|
33
|
+
values.each do |value|
|
34
|
+
if fieldset_child.field_records.select{ |record| record.value == value }.empty?
|
35
|
+
DynamicFieldsets::FieldRecord.create!( :fieldset_associator_id => fsa.id,
|
36
|
+
:fieldset_child_id => fieldset_child.id,
|
37
|
+
:value => value)
|
38
|
+
end
|
39
|
+
end
|
40
|
+
|
41
|
+
# remove records in the db that are not in the input values
|
42
|
+
# note that if a record is updated, it is treated as a creation and deletion instead of a single update
|
43
|
+
fieldset_child.field_records.each do |record|
|
44
|
+
if !values.include?(record.value)
|
45
|
+
record.destroy
|
46
|
+
end
|
47
|
+
end
|
48
|
+
end
|
49
|
+
|
50
|
+
# Gets the first field record matching the parameters
|
51
|
+
#
|
52
|
+
# @param [DynamicFieldsets::FieldsetAssociator] fsa The associator
|
53
|
+
# @param [DynamicFieldsets::FieldsetChild] fsc The fieldset child
|
54
|
+
# @return [Array] An array of field records
|
55
|
+
def get_values_using_fsa_and_fsc(fsa, fsc)
|
56
|
+
collect_field_records_by_fsa_and_fsc(fsa, fsc)
|
57
|
+
end
|
58
|
+
|
59
|
+
# @return [String] Default multiple answer partial filename
|
60
|
+
def show_partial
|
61
|
+
"/dynamic_fieldsets/show_partials/show_multiple_answers"
|
62
|
+
end
|
63
|
+
|
64
|
+
# Returns a list of values for the form
|
65
|
+
#
|
66
|
+
# Only returns the :value part of the input
|
67
|
+
#
|
68
|
+
# @param [Array] values A list of values for the field already saved to the database
|
69
|
+
# @return [Array] An array of field option values saved in the db, or the defaults if none are in the db
|
70
|
+
def values_or_defaults_for_form(values)
|
71
|
+
if values.nil? || values.empty?
|
72
|
+
if field_defaults.length == 0
|
73
|
+
return []
|
74
|
+
else
|
75
|
+
return collect_default_values
|
76
|
+
end
|
77
|
+
else
|
78
|
+
return values.collect { |v| v[:value] }
|
79
|
+
end
|
80
|
+
end
|
81
|
+
|
82
|
+
# @return [Array] Alias for field_defaults
|
83
|
+
def defaults
|
84
|
+
return self.field_defaults if options?
|
85
|
+
return nil
|
86
|
+
end
|
87
|
+
end
|
88
|
+
end
|
89
|
+
end
|
@@ -0,0 +1,84 @@
|
|
1
|
+
module DynamicFieldsets
|
2
|
+
module FieldWithSingleAnswer
|
3
|
+
def self.included(base)
|
4
|
+
base.extend ClassMethods
|
5
|
+
end
|
6
|
+
|
7
|
+
module ClassMethods
|
8
|
+
def acts_as_field_with_single_answer(args = {})
|
9
|
+
include DynamicFieldsets::FieldWithSingleAnswer::InstanceMethods
|
10
|
+
end
|
11
|
+
end
|
12
|
+
|
13
|
+
module InstanceMethods
|
14
|
+
|
15
|
+
def show_partial_locals(args)
|
16
|
+
output = super(args)
|
17
|
+
output[:value] = get_value_for_show(args[:value])
|
18
|
+
return output
|
19
|
+
end
|
20
|
+
|
21
|
+
# Updates the field records for the field based on the given values
|
22
|
+
#
|
23
|
+
# Saves or updates a single field record
|
24
|
+
#
|
25
|
+
# @param [DynamicFieldsets::FieldsetAssociator] fsa The associator the value is attached to
|
26
|
+
# @param [DynamicFieldsets::FieldsetChild] fieldset_child The fieldset child for the value
|
27
|
+
# @param [Array or String] value The new values inputted by the user from the form
|
28
|
+
def update_field_records(fsa, fieldset_child, value)
|
29
|
+
# make sure the value is a string in case the input from the form is bad
|
30
|
+
throw "Form value type mismatch error: The value from the form must be String for #{self.inspect}." unless value.is_a?(String)
|
31
|
+
|
32
|
+
# retrieve record
|
33
|
+
field_record = DynamicFieldsets::FieldRecord.where(:fieldset_associator_id => fsa.id, :fieldset_child_id => fieldset_child.id).first
|
34
|
+
if field_record.nil?
|
35
|
+
# create record
|
36
|
+
DynamicFieldsets::FieldRecord.create!(
|
37
|
+
:fieldset_associator_id => fsa.id,
|
38
|
+
:fieldset_child_id => fieldset_child.id,
|
39
|
+
:value => value)
|
40
|
+
else
|
41
|
+
# update record
|
42
|
+
field_record.value = value
|
43
|
+
field_record.save
|
44
|
+
end
|
45
|
+
end
|
46
|
+
|
47
|
+
# Gets the first field record matching the parameters
|
48
|
+
#
|
49
|
+
# @param [DynamicFieldsets::FieldsetAssociator] fsa The associator
|
50
|
+
# @param [DynamicFieldsets::FieldsetChild] fsc The fieldset child
|
51
|
+
# @return [String] The first field record
|
52
|
+
def get_values_using_fsa_and_fsc(fsa, fsc)
|
53
|
+
collect_field_records_by_fsa_and_fsc(fsa, fsc).first
|
54
|
+
end
|
55
|
+
|
56
|
+
# @return [String] Default single answer partial filename
|
57
|
+
def show_partial
|
58
|
+
"/dynamic_fieldsets/show_partials/show_single_answer"
|
59
|
+
end
|
60
|
+
|
61
|
+
# @return [String] Alias for field_defaults.first
|
62
|
+
def default
|
63
|
+
return self.field_defaults.first
|
64
|
+
end
|
65
|
+
|
66
|
+
# Returns a list of values for the form
|
67
|
+
#
|
68
|
+
# @param [String] value A value for the field already saved to the database
|
69
|
+
# @return [String] A field option saved in the db, or the default if value is blank
|
70
|
+
def value_or_default_for_form(value)
|
71
|
+
if value.nil? || value[:value].nil?
|
72
|
+
if field_defaults.length == 0
|
73
|
+
return ""
|
74
|
+
else
|
75
|
+
return collect_default_values.first
|
76
|
+
end
|
77
|
+
else
|
78
|
+
value[:value]
|
79
|
+
end
|
80
|
+
end
|
81
|
+
end
|
82
|
+
end
|
83
|
+
end
|
84
|
+
|
@@ -1,6 +1,5 @@
|
|
1
1
|
require 'rails'
|
2
2
|
|
3
|
-
# no configuration yet
|
4
3
|
require 'dynamic_fieldsets/config'
|
5
4
|
|
6
5
|
module DynamicFieldsets
|
@@ -8,6 +7,12 @@ module DynamicFieldsets
|
|
8
7
|
initializer 'dynamic_fieldsets' do |app|
|
9
8
|
require 'dynamic_fieldsets/dynamic_fieldsets_in_model'
|
10
9
|
ActiveRecord::Base.send :include, DynamicFieldsets::DynamicFieldsetsInModel
|
10
|
+
require 'dynamic_fieldsets/field_with_field_options'
|
11
|
+
ActiveRecord::Base.send :include, DynamicFieldsets::FieldWithFieldOptions
|
12
|
+
require 'dynamic_fieldsets/field_with_multiple_answers'
|
13
|
+
ActiveRecord::Base.send :include, DynamicFieldsets::FieldWithMultipleAnswers
|
14
|
+
require 'dynamic_fieldsets/field_with_single_answer'
|
15
|
+
ActiveRecord::Base.send :include, DynamicFieldsets::FieldWithSingleAnswer
|
11
16
|
end
|
12
17
|
end
|
13
18
|
end
|
@@ -15,7 +15,7 @@ module DynamicFieldsets
|
|
15
15
|
|
16
16
|
desc <<DESC
|
17
17
|
Description:
|
18
|
-
Copies over migrations and config for the
|
18
|
+
Copies over migrations and config for the dynamic fieldsets system.
|
19
19
|
DESC
|
20
20
|
|
21
21
|
# Implement the required interface for Rails::Generators::Migration.
|
@@ -30,9 +30,9 @@ DESC
|
|
30
30
|
end
|
31
31
|
|
32
32
|
# Creates the config file
|
33
|
-
#
|
33
|
+
# Mostly commented out until the config actually has information
|
34
34
|
def copy_config_file
|
35
|
-
|
35
|
+
copy_file "config.rb", "config/initializers/dynamic_fieldsets.rb"
|
36
36
|
end
|
37
37
|
|
38
38
|
# Creates the migration
|
@@ -0,0 +1,15 @@
|
|
1
|
+
DynamicFieldsets.configure do |config|
|
2
|
+
# If cache classes is off, this field needs to be set. Otherwise, rails issues
|
3
|
+
# can cause the single table inheritance to fail. This is due to the object
|
4
|
+
# space getting reset after every request. In production and test environemnts,
|
5
|
+
# this information will not be used because the object space will be complete.
|
6
|
+
# config.available_field_types = [ "DynamicFieldsets::CheckboxField", "DynamicFieldsets::"DateField", "DynamicFieldsets::"DatetimeField", "DynamicFieldsets::InstructionField", "DynamicFieldsets::MultipleSelectField", "DynamicFieldsets::RadioField", "DynamicFieldsets::SelectField", "DynamicFieldsets::TextField", "DynamicFieldsets::TextareaField" ]
|
7
|
+
|
8
|
+
# This should correspond to the beginning of the id for the fields for on the form
|
9
|
+
# For example: fsa-8
|
10
|
+
# config.form_fieldset_associator_prefix = "fsa-"
|
11
|
+
|
12
|
+
# This should correspond to the beginning of the field section of form inputs
|
13
|
+
# For example: fsa-8[field-7]
|
14
|
+
# config.form_field_prefix = "field-"
|
15
|
+
end
|
@@ -35,7 +35,7 @@ class <%= migration_class_name %> < ActiveRecord::Migration
|
|
35
35
|
create_table :dynamic_fieldsets_fields do |t|
|
36
36
|
t.string :name
|
37
37
|
t.string :label, :required => true
|
38
|
-
t.string :
|
38
|
+
t.string :type, :required => true
|
39
39
|
t.boolean :required, :default => false
|
40
40
|
t.boolean :enabled, :default => true
|
41
41
|
|
@@ -0,0 +1,15 @@
|
|
1
|
+
DynamicFieldsets.configure do |config|
|
2
|
+
# If cache classes is off, this field needs to be set. Otherwise, rails issues
|
3
|
+
# can cause the single table inheritance to fail. This is due to the object
|
4
|
+
# space getting reset after every request. In production and test environemnts,
|
5
|
+
# this information will not be used because the object space will be complete.
|
6
|
+
# config.available_field_types = [ "DynamicFieldsets::CheckboxField", "DynamicFieldsets::"DateField", "DynamicFieldsets::"DatetimeField", "DynamicFieldsets::InstructionField", "DynamicFieldsets::MultipleSelectField", "DynamicFieldsets::RadioField", "DynamicFieldsets::SelectField", "DynamicFieldsets::TextField", "DynamicFieldsets::TextareaField" ]
|
7
|
+
|
8
|
+
# This should correspond to the beginning of the id for the fields for on the form
|
9
|
+
# For example: fsa-8
|
10
|
+
# config.form_fieldset_associator_prefix = "fsa-"
|
11
|
+
|
12
|
+
# This should correspond to the beginning of the field section of form inputs
|
13
|
+
# For example: fsa-8[field-7]
|
14
|
+
# config.form_field_prefix = "field-"
|
15
|
+
end
|
@@ -35,7 +35,7 @@ class CreateDynamicFieldsetsTables < ActiveRecord::Migration
|
|
35
35
|
create_table :dynamic_fieldsets_fields do |t|
|
36
36
|
t.string :name
|
37
37
|
t.string :label, :required => true
|
38
|
-
t.string :
|
38
|
+
t.string :type, :required => true
|
39
39
|
t.boolean :required, :default => false
|
40
40
|
t.boolean :enabled, :default => true
|
41
41
|
|
data/spec/dummy/db/schema.rb
CHANGED
@@ -84,7 +84,7 @@ ActiveRecord::Schema.define(:version => 20120213211033) do
|
|
84
84
|
create_table "dynamic_fieldsets_fields", :force => true do |t|
|
85
85
|
t.string "name"
|
86
86
|
t.string "label"
|
87
|
-
t.string "
|
87
|
+
t.string "type"
|
88
88
|
t.boolean "required", :default => false
|
89
89
|
t.boolean "enabled", :default => true
|
90
90
|
t.datetime "created_at"
|
@@ -2,7 +2,7 @@ Given /^a field exists$/ do
|
|
2
2
|
@field = DynamicFieldsets::Field.create(
|
3
3
|
:name => "Test field",
|
4
4
|
:label => "Test field",
|
5
|
-
:
|
5
|
+
:type => "textfield",
|
6
6
|
:enabled => true,
|
7
7
|
:required => true)
|
8
8
|
end
|
@@ -26,14 +26,14 @@ end
|
|
26
26
|
Then /^I should see that field listed$/ do
|
27
27
|
@field = DynamicFieldsets::Field.last
|
28
28
|
page.should have_content(@field.name)
|
29
|
-
page.should have_content(@field.
|
29
|
+
page.should have_content(@field.type)
|
30
30
|
end
|
31
31
|
|
32
32
|
Then /^I should see the data for that field$/ do
|
33
33
|
@field = DynamicFieldsets::Field.last
|
34
34
|
page.should have_content(@field.name)
|
35
35
|
page.should have_content(@field.label)
|
36
|
-
page.should have_content(@field.
|
36
|
+
page.should have_content(@field.type)
|
37
37
|
page.should have_content(@field.enabled)
|
38
38
|
page.should have_content(@field.required)
|
39
39
|
|
@@ -63,5 +63,5 @@ end
|
|
63
63
|
|
64
64
|
Then /^I should not see that field listed$/ do
|
65
65
|
page.should_not have_content(@field.name)
|
66
|
-
page.should_not have_content(@field.
|
66
|
+
page.should_not have_content(@field.type)
|
67
67
|
end
|
@@ -19,7 +19,7 @@ def create_child_field(parent, order_num = 1)
|
|
19
19
|
child_field = DynamicFieldsets::Field.create(
|
20
20
|
:name => "Child Field",
|
21
21
|
:label => "Child Field",
|
22
|
-
:
|
22
|
+
:type => "textfield",
|
23
23
|
:enabled => true,
|
24
24
|
:required => true)
|
25
25
|
DynamicFieldsets::FieldsetChild.create(:fieldset => parent, :child => child_field, :order_num => order_num)
|
@@ -55,7 +55,7 @@ end
|
|
55
55
|
Then /^I should see the child field information$/ do
|
56
56
|
@child_field = DynamicFieldsets::Field.last
|
57
57
|
page.should have_content(@child_field.name)
|
58
|
-
page.should have_content(@child_field.
|
58
|
+
page.should have_content(@child_field.type)
|
59
59
|
end
|
60
60
|
|
61
61
|
Then /^I should see the child fieldset information$/ do
|
@@ -19,7 +19,7 @@ def create_textfield(parent, order_num = 1)
|
|
19
19
|
child_field = DynamicFieldsets::Field.create(
|
20
20
|
:name => "Child Field",
|
21
21
|
:label => "Child Field",
|
22
|
-
:
|
22
|
+
:type => "textfield",
|
23
23
|
:enabled => true,
|
24
24
|
:required => true)
|
25
25
|
DynamicFieldsets::FieldsetChild.create(:fieldset => parent, :child => child_field, :order_num => order_num)
|
@@ -30,7 +30,7 @@ def create_radio(parent, order_num = 1)
|
|
30
30
|
child_field = DynamicFieldsets::Field.create(
|
31
31
|
:name => "Child Field",
|
32
32
|
:label => "Child Field",
|
33
|
-
:
|
33
|
+
:type => "radio",
|
34
34
|
:enabled => true,
|
35
35
|
:required => true,
|
36
36
|
:field_options => [DynamicFieldsets::FieldOption.create(
|
@@ -47,7 +47,7 @@ def create_textarea(parent, order_num = 1)
|
|
47
47
|
child_field = DynamicFieldsets::Field.create(
|
48
48
|
:name => "Child Field",
|
49
49
|
:label => "Child Field",
|
50
|
-
:
|
50
|
+
:type => "textarea",
|
51
51
|
:enable => true,
|
52
52
|
:required => true)
|
53
53
|
DynamicFieldsets::FieldsetChild.create(:fieldset => parent, :child => child_field, :order_num => order_num)
|
@@ -58,7 +58,7 @@ def create_checkbox(parent, order_num = 1)
|
|
58
58
|
child_field = DynamicFieldsets::Field.create(
|
59
59
|
:name => "Child Field",
|
60
60
|
:label => "Child Field",
|
61
|
-
:
|
61
|
+
:type => "checkbox",
|
62
62
|
:enable => true,
|
63
63
|
:required => true,
|
64
64
|
:field_options => [DynamicFieldsets::FieldOption.create(
|
@@ -75,7 +75,7 @@ def create_select(parent, order_num = 1)
|
|
75
75
|
child_field = DynamicFieldsets::Field.create(
|
76
76
|
:name => "Child Field",
|
77
77
|
:label => "Child Field",
|
78
|
-
:
|
78
|
+
:type => "select",
|
79
79
|
:enable => true,
|
80
80
|
:required => true,
|
81
81
|
:field_options => [DynamicFieldsets::FieldOption.create(
|
@@ -92,7 +92,7 @@ def create_multi_select(parent, order_num = 1)
|
|
92
92
|
child_field = DynamicFieldsets::Field.create(
|
93
93
|
:name => "Child Field",
|
94
94
|
:label => "Child Field",
|
95
|
-
:
|
95
|
+
:type => "multiple_select",
|
96
96
|
:enable => true,
|
97
97
|
:required => true,
|
98
98
|
:field_options => [DynamicFieldsets::FieldOption.create(
|
@@ -111,7 +111,7 @@ def create_instruction(parent, order_num = 2)
|
|
111
111
|
child_field = DynamicFieldsets::Field.create(
|
112
112
|
:name => "Dependent Field",
|
113
113
|
:label => "Dependent Field",
|
114
|
-
:
|
114
|
+
:type => "instruction",
|
115
115
|
:enable => true,
|
116
116
|
:required => true
|
117
117
|
)
|