I am probably missing something out, and here is my problem.
I have a form to submit images and I want the form to use AJAX, but on submit it responds to the HTML format instead of the JS. Why does the POST request doesn't use the JS format?? I also use carrierwave to upload the files.
In my controllers mission_slides_controller.rb
def new
  @account = Account.find(params[:account_id])
  @mission = Mission.find(params[:mission_id])
  @mission_slides = MissionSlide.where('mission_id = ?', @mission.id)
  slides = MissionSlide.where('mission_id = ?', @mission.id)
  @mission_slide = MissionSlide.new
  if slides.size < 1
    @mission_slide.position = 1
  else
    @mission_slide.position = slides.last.position+1
  end
  respond_to do |format|
    format.html # new.html.erb
    format.js
    format.json { render json: @mission_slide }
  end
end
def create
  @mission_slide = MissionSlide.new(params[:mission_slide])
  @account = Account.find(params[:account_id])
  @mission = Mission.find(params[:mission_id])
  respond_to do |format|
    if @mission_slide.save
      format.html { redirect_to user_account_path(current_user, @account), notice: 'Mission slide was successfully created.' }
      format.json { render json: @mission_slide, status: :created, location: @mission_slide }
      format.js
    else
      format.html { render action: "new" }
      format.json { render json: @mission_slide.errors, status: :unprocessable_entity }
      format.js
    end
  end
end
In my controllers _form.html.erb
<div class="slides">
    <h4>Current slides</h4>
    <%= render 'mission_slides' %>
</div>
<%= form_for([current_user, @account, @mission, @mission_slide], :remote => true, :multipart => true) do |f| %>
    <%= render :partial => "layouts/form_messages", :locals => {:model_name => @mission_slide, :heading => t('errors.template.header', :count => @mission_slide.errors.size, :model => @mission_slide.class) } %>
    <%= f.hidden_field :mission_id, :value => @mission.id %>
    <div class="form-group required mission_slide_name">
        <div>
            <%= f.label :name, :class => "control-label required-label" %>
            <div>
                <%= f.text_field :name, :class => "form-control", :placeholder => "Slide Name" %>
            </div>
        </div>
    </div>
    <div class="form-group required mission_slide_image">
        <div>
            <%= f.label :image, :class => "control-label required-label" %>
            <div>
                <%= f.file_field :image, :class => "form-control" %>
            </div>
        </div>
    </div>
    <div class="form-group required mission_slide_position">
        <div>
            <%= f.label :position, :class => "control-label required-label" %>
            <div>
                <%= f.number_field :position, :class => "form-control" %>
            </div>
        </div>
    </div>
    <div class="form-group">
        <div>
            <%= f.submit "Add slide", :class => "btn btn-blue" %>
        </div>
    </div>
<% end %>
and I also created a JS partial for the CREATE action create.js.erb
var container = $("#current_slides")
    <% if @mission_slide.errors.present? %>
        $("#new_mission_slide").prepend("<%= escape_javascript render :partial => "layouts/form_messages", :locals => {:model_name => @mission_slide, :heading => t('errors.template.header', :count => @mission_slide.errors.size, :model => @mission_slide.class) } %>");
    <% else %>
        $('form[id*="new_mission_slide"]').replaceWith('<%= escape_javascript render("form") %>')
        $container.append(@mission_slide)
    <% end %>
thank you for your wise insights
 
    