X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/d3cb9460f0a30f9602508bed7507c906b8a6d91d..b6f73f7acffa9b2f37c78826ff6cee89987a7edc:/apps/workbench/app/controllers/application_controller.rb diff --git a/apps/workbench/app/controllers/application_controller.rb b/apps/workbench/app/controllers/application_controller.rb index 751b494bf4..c7575176de 100644 --- a/apps/workbench/app/controllers/application_controller.rb +++ b/apps/workbench/app/controllers/application_controller.rb @@ -164,11 +164,23 @@ class ApplicationController < ActionController::Base def find_objects_for_index @objects ||= model_class @objects = @objects.filter(@filters).limit(@limit).offset(@offset) + @objects.fetch_multiple_pages(false) end def render_index respond_to do |f| - f.json { render json: @objects } + f.json { + if params[:partial] + @next_page_href = next_page_href(partial: params[:partial], filters: @filters.to_json) + render json: { + content: render_to_string(partial: "show_#{params[:partial]}", + formats: [:html]), + next_page_href: @next_page_href + } + else + render json: @objects + end + } f.html { if params[:tab_pane] render_pane params[:tab_pane] @@ -244,7 +256,9 @@ class ApplicationController < ActionController::Base elsif request.method.in? ['GET', 'HEAD'] render else - redirect_to params[:return_to] || @object + redirect_to (params[:return_to] || + polymorphic_url(@object, + anchor: params[:redirect_to_anchor])) end } f.js { render } @@ -308,16 +322,11 @@ class ApplicationController < ActionController::Base @new_resource_attrs ||= {} @new_resource_attrs.reject! { |k,v| k.to_s == 'uuid' } @object ||= model_class.new @new_resource_attrs, params["options"] + if @object.save - respond_to do |f| - f.json { render json: @object.attributes.merge(href: url_for(action: :show, id: @object)) } - f.html { - redirect_to @object - } - f.js { render } - end + show else - self.render_error status: 422 + render_error status: 422 end end