diff options
| author | Luc Donnet | 2018-05-31 11:39:40 +0200 |
|---|---|---|
| committer | GitHub | 2018-05-31 11:39:40 +0200 |
| commit | 3642e0741c96cf4855dc7731a22ac0b9fabea5f4 (patch) | |
| tree | d754f0abc83d261c0f2057e5be56914e7486dd02 /app/helpers | |
| parent | 255c8c3a86f86f64eb04a2e8ed7e036f56d505d0 (diff) | |
| parent | c49242a8a51f16635f67acd850b3bbcd6ad2ac5e (diff) | |
| download | chouette-core-3642e0741c96cf4855dc7731a22ac0b9fabea5f4.tar.bz2 | |
Merge pull request #592 from af83/7159-netex-exports
7159 Update options for netex exports
Diffstat (limited to 'app/helpers')
| -rw-r--r-- | app/helpers/exports_helper.rb | 37 |
1 files changed, 31 insertions, 6 deletions
diff --git a/app/helpers/exports_helper.rb b/app/helpers/exports_helper.rb index 4de539b73..cc6fc3046 100644 --- a/app/helpers/exports_helper.rb +++ b/app/helpers/exports_helper.rb @@ -4,12 +4,37 @@ module ExportsHelper import_status status end - def export_option_input form, export, attr, option_def, type - opts = { required: option_def[:required], input_html: {value: export.try(attr) || option_def[:default_value]}, as: option_def[:type], selected: export.try(attr) || option_def[:default_value]} - opts[:collection] = option_def[:collection] if option_def.has_key?(:collection) - opts[:collection] = export.instance_exec(&option_def[:collection]) if option_def[:collection].is_a?(Proc) - opts[:label] = t "activerecord.attributes.export.#{type.name.demodulize.underscore}.#{attr}" - form.input attr, opts + def export_option_input form, export, attr, option_def, type, referentials + if !!option_def[:depends_on_referential] + out = "" + referentials.each do |referential| + out += content_tag :div, class: "slave", data: {master: "[name='export[referential_id]']", value: referential.id} do + _opts = {depends_on_referential: false, collection: option_def[:collection].call(referential)}.reverse_update(option_def) + export_option_input form, export, attr, _opts, type, referentials + end + end + out.html_safe + else + opts = { required: option_def[:required], input_html: {value: export.try(attr) || option_def[:default_value]}, as: option_def[:type], selected: export.try(attr) || option_def[:default_value]} + + if option_def.has_key?(:collection) + if option_def[:collection].is_a?(Array) && !option_def[:collection].first.is_a?(Array) + opts[:collection] = option_def[:collection].map{|k| [export.class.tmf("#{type.name.demodulize.underscore}.#{attr}_collection.#{k}"), k]} + else + opts[:collection] = option_def[:collection] + end + opts[:collection] = export.instance_exec(&option_def[:collection]) if option_def[:collection].is_a?(Proc) + end + opts[:label] = export.class.tmf("#{type.name.demodulize.underscore}.#{attr}") + opts[:input_html]['data-select2ed'] = true if opts[:collection] + out = form.input attr, opts + if option_def[:depends] + out = content_tag :div, class: "slave", data: {master: "[name='export[#{option_def[:depends][:option]}]']", value: option_def[:depends][:value]} do + out + end.html_safe + end + out + end end def export_message_content message |
