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 | 
