active_scaffold 3.1.12 → 3.1.13
Sign up to get free protection for your applications and to get access to all the features.
- data/lib/active_scaffold/bridges/record_select/helpers.rb +1 -1
- data/lib/active_scaffold/bridges/record_select/helpers.rb~ +6 -20
- data/lib/active_scaffold/extensions/active_association_reflection.rb +1 -1
- data/lib/active_scaffold/extensions/active_association_reflection.rb~ +22 -0
- data/lib/active_scaffold/version.rb +1 -1
- metadata +5 -4
@@ -49,7 +49,7 @@ class ActiveScaffold::Bridges::RecordSelect
|
|
49
49
|
|
50
50
|
def active_scaffold_record_select_autocomplete(column, options)
|
51
51
|
record_select_options = active_scaffold_input_text_options(options).merge(
|
52
|
-
:controller =>
|
52
|
+
:controller => active_scaffold_controller_for(@record.class).controller_path
|
53
53
|
)
|
54
54
|
html = record_select_autocomplete(options[:name], @record, record_select_options)
|
55
55
|
html = self.class.field_error_proc.call(html, self) if @record.errors[column.name].any?
|
@@ -33,17 +33,10 @@ class ActiveScaffold::Bridges::RecordSelect
|
|
33
33
|
params.merge!({column.association.primary_key_name => ''})
|
34
34
|
end
|
35
35
|
|
36
|
-
record_select_options = active_scaffold_input_text_options(
|
37
|
-
:controller => remote_controller
|
38
|
-
:id => options[:id],
|
39
|
-
:class => options[:class].gsub(/update_form/, '')
|
36
|
+
record_select_options = active_scaffold_input_text_options(options).merge(
|
37
|
+
:controller => remote_controller
|
40
38
|
)
|
41
39
|
record_select_options.merge!(column.options)
|
42
|
-
if options['data-update_url']
|
43
|
-
record_select_options[:onchange] = %|function(id, label) {
|
44
|
-
ActiveScaffold.update_column(null, "#{options['data-update_url']}", #{options['data-update_send_form'].to_json}, "#{options[:id]}", id);
|
45
|
-
}|
|
46
|
-
end
|
47
40
|
|
48
41
|
html = if multiple
|
49
42
|
record_multi_select_field(options[:name], value || [], record_select_options)
|
@@ -55,18 +48,11 @@ class ActiveScaffold::Bridges::RecordSelect
|
|
55
48
|
end
|
56
49
|
|
57
50
|
def active_scaffold_record_select_autocomplete(column, options)
|
58
|
-
|
59
|
-
|
60
|
-
:
|
61
|
-
:class => options[:class].gsub(/update_form/, '')
|
51
|
+
remote_controller = active_scaffold_controller_for(column.association.klass).controller_path
|
52
|
+
record_select_options = active_scaffold_input_text_options(options).merge(
|
53
|
+
:controller => remote_controller
|
62
54
|
)
|
63
|
-
|
64
|
-
record_select_options[:onchange] = %|function(id, label) {
|
65
|
-
ActiveScaffold.update_column(null, "#{options['data-update_url']}", #{options['data-update_send_form'].to_json}, "#{options[:id]}", id);
|
66
|
-
}|
|
67
|
-
end
|
68
|
-
|
69
|
-
html = record_select_autocomplete(options[:name], value, record_select_options)
|
55
|
+
html = record_select_autocomplete(options[:name], @record, record_select_options)
|
70
56
|
html = self.class.field_error_proc.call(html, self) if @record.errors[column.name].any?
|
71
57
|
html
|
72
58
|
end
|
@@ -5,7 +5,7 @@
|
|
5
5
|
ActiveRecord::Reflection::AssociationReflection.class_eval do
|
6
6
|
def klass_with_sti(*opts)
|
7
7
|
sti_col = klass.inheritance_column
|
8
|
-
if (h = opts.first).is_a? Hash and (passed_type = ( h[sti_col] || h[sti_col.to_sym] )) and (new_klass = active_record.send(:compute_type, passed_type)) < klass
|
8
|
+
if sti_col and (h = opts.first).is_a? Hash and (passed_type = ( h[sti_col] || h[sti_col.to_sym] )) and (new_klass = active_record.send(:compute_type, passed_type)) < klass
|
9
9
|
new_klass
|
10
10
|
else
|
11
11
|
klass
|
@@ -0,0 +1,22 @@
|
|
1
|
+
# Bugfix: building an sti model from an association fails
|
2
|
+
# https://rails.lighthouseapp.com/projects/8994-ruby-on-rails/tickets/6306-collection-associations-build-method-not-supported-for-sti
|
3
|
+
# https://github.com/rails/rails/issues/815
|
4
|
+
# https://github.com/rails/rails/pull/1686
|
5
|
+
ActiveRecord::Reflection::AssociationReflection.class_eval do
|
6
|
+
def klass_with_sti(*opts)
|
7
|
+
sti_col = klass.inheritance_column
|
8
|
+
if (h = opts.first).is_a? Hash and (passed_type = ( h[sti_col] || h[sti_col.to_sym] )) and (new_klass = active_record.send(:compute_type, passed_type)) < klass
|
9
|
+
new_klass
|
10
|
+
else
|
11
|
+
klass
|
12
|
+
end
|
13
|
+
end
|
14
|
+
def build_association(*opts, &block)
|
15
|
+
self.original_build_association_called = true
|
16
|
+
klass_with_sti(*opts).new(*opts, &block)
|
17
|
+
end
|
18
|
+
def create_association(*opts, &block)
|
19
|
+
self.original_build_association_called = true
|
20
|
+
klass_with_sti(*opts).create(*opts, &block)
|
21
|
+
end
|
22
|
+
end
|
metadata
CHANGED
@@ -1,13 +1,13 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: active_scaffold
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
hash:
|
4
|
+
hash: 25
|
5
5
|
prerelease:
|
6
6
|
segments:
|
7
7
|
- 3
|
8
8
|
- 1
|
9
|
-
-
|
10
|
-
version: 3.1.
|
9
|
+
- 13
|
10
|
+
version: 3.1.13
|
11
11
|
platform: ruby
|
12
12
|
authors:
|
13
13
|
- Many, see README
|
@@ -15,7 +15,7 @@ autorequire:
|
|
15
15
|
bindir: bin
|
16
16
|
cert_chain: []
|
17
17
|
|
18
|
-
date: 2011-12-
|
18
|
+
date: 2011-12-21 00:00:00 Z
|
19
19
|
dependencies:
|
20
20
|
- !ruby/object:Gem::Dependency
|
21
21
|
version_requirements: &id001 !ruby/object:Gem::Requirement
|
@@ -348,6 +348,7 @@ files:
|
|
348
348
|
- lib/active_scaffold/extensions/reverse_associations.rb~
|
349
349
|
- lib/active_scaffold/extensions/routing_mapper.rb~
|
350
350
|
- lib/active_scaffold/extensions/unsaved_associated.rb~
|
351
|
+
- lib/active_scaffold/extensions/active_association_reflection.rb~
|
351
352
|
- lib/active_scaffold/paginator.rb
|
352
353
|
- lib/active_scaffold/responds_to_parent.rb
|
353
354
|
- lib/active_scaffold/version.rb
|