X-Git-Url: http://git.osdn.net/view?a=blobdiff_plain;f=app%2Fcontrollers%2Fpanels_controller.rb;h=c0cd0cfcd30a5ad89cff27a846e8b2c0c1888555;hb=2bd8e046bbbdd6d620af0637c3291cc7d787b0c5;hp=82475e99cf4f7ae1719193dea823cb84f50bfcfb;hpb=46ddebc32f7409dc749f83c710aba9a345381165;p=pettanr%2Fpettanr.git diff --git a/app/controllers/panels_controller.rb b/app/controllers/panels_controller.rb index 82475e99..c0cd0cfc 100644 --- a/app/controllers/panels_controller.rb +++ b/app/controllers/panels_controller.rb @@ -1,51 +1,45 @@ class PanelsController < ApplicationController - before_filter :authenticate_author!, :only => [:index, :show, :create, :update, :destroy] + layout 'test' if MagicNumber['test_layout'] + before_filter :authenticate_user!, :only => [:index, :show, :new, :edit, :create, :update, :destroy] + before_filter :authenticate_author, :only => [:index, :show, :new, :edit, :create, :update, :destroy] before_filter :authenticate_admin!, :only => [:list, :browse] - private - - def treat_param panel - panel.author_id = current_author.id - end - public # GET /panels # GET /panels.json def index - @panels = Panel.find(:all, :include => [:comic, :author], :order => 'updated_at', :limit => 20) + @page = Panel.page params[:page] + @page_size = Panel.page_size params[:page_size] + @panels = Panel.list(@page, @page_size) respond_to do |format| format.html # index.html.erb - format.json { render :json => @panels.to_json( - :include => [:comic, :author] - ) } + format.json { render text: Panel.list_as_json_text(@panels) } end end # GET /panels/1 # GET /panels/1.json def show - @panel = Panel.find(params[:id], include: [:comic, :panel_pictures => :resource_picture, :balloons => :speaches])# only: [:width, :height]) + @panel = Panel.show(params[:id], @author) respond_to do |format| format.html # show.html.erb - format.json { - render :json => @panel.to_json(include: { - :comic => {}, :panel_pictures => {:include => :image}, :fukidashis => {:include => :serifus} - }) - } + format.json { render json: @panel.panel_elements_as_json } format.jsonp { - render :json => "callback(" + @panel.to_json(include: { - :comic => {}, :panel_pictures => {:include => :image}, :fukidashis => {:include => :serifus} - }) + ");" + render :json => "callback(" + @panel.panel_elements_as_json + ");" } -# format.json { render :json => @frame.to_json(include: { -# :comic => {:only => :title}, :panel_pictures => {:include => {:image => {:only => [:width]}},:only => [:width, :height, :z, :image_id]} -# }, only: [:border]) } end end + def count + @panel = {:count => Panel.visible_count} + respond_to do |format| + format.json { render json: @panel.to_json } + end + end + def list @panels = Panel.all :order => 'updated_at' @@ -63,22 +57,42 @@ class PanelsController < ApplicationController end end + def new + @panel = Panel.new + @panel.supply_default + + respond_to do |format| + format.html # new.html.erb + format.js + format.json { render json: @panel.panel_elements_as_json } + end + end + + def edit + @panel = Panel.edit(params[:id], @author) + respond_to do |format| + format.html + format.js + end + end + # POST /panels # POST /panels.json def create - @panel = Panel.new(params[:panel]) - treat_param @panel - @comic = Comic.find @panel.comic_id - + @panel = Panel.new + @panel.supply_default + jsn = nil + if params[:json] + jsn = JSON.parse_no_except(params[:json]) + end + @prm = params[:panel] || jsn respond_to do |format| - Panel.transaction do - if @panel.vdt_save - format.html { redirect_to @panel, notice: 'Panel was successfully created.' } - format.json { render json: @panel, status: :created, location: @panel } - else - format.html { render action: "new" } - format.json { render json: @panel.errors, status: :unprocessable_entity } - end + if @panel.store @prm, @author + format.html { redirect_to @panel, notice: 'Panel was successfully created.' } + format.json { render json: @panel.panel_elements_as_json, status: :created, location: @panel } + else + format.html { render action: "new" } + format.json { render json: @panel.errors, status: :unprocessable_entity } end end end @@ -86,58 +100,32 @@ class PanelsController < ApplicationController # PUT /panels/1 # PUT /panels/1.json def update - @panel = Panel.find(params[:id]) - if @panel.own? current_author - respond_to do |format| - Panel.transaction do - if params[:panel][:t] and params[:panel][:t].to_i != @panel.t - @panel.move_to params[:panel][:t].to_i - end - if @panel.update_attributes(params[:panel]) - format.html { redirect_to @panel, notice: 'Panel was successfully updated.' } - format.json { head :ok } - else - format.html { render action: "edit" } - format.json { render json: @panel.errors, status: :unprocessable_entity } - end - end + @panel = Panel.edit(params[:id], @author) + jsn = nil + if params[:json] + jsn = JSON.parse(params[:json]) + end + @prm = params[:panel] || jsn + respond_to do |format| + if @panel.store @prm, @author + format.html { redirect_to @panel, notice: 'Panel was successfully updated.' } + format.json { head :ok } + else + format.html { render action: "edit" } + format.json { render json: @panel.errors, status: :unprocessable_entity } end - else - format.html { render action: "edit" } - format.json { render json: @panel.errors, status: :unprocessable_entity } end end # DELETE /panels/1 # DELETE /panels/1.json def destroy - @panel = Panel.find(params[:id]) - if @panel.own? current_author - respond_to do |format| - Panel.transaction do - @panel.destroy_and_shorten - format.html { redirect_to panels_url } - format.json { head :ok } - end - end - else - format.html { render action: "edit" } - format.json { render json: @panel.errors, status: :unprocessable_entity } - end - end - - def move - @panel = Panel.find(params[:id]) - @new_seq = params[:panel][:t].to_i + @panel = Panel.edit(params[:id], @author) respond_to do |format| Panel.transaction do - if @panel.move_to(@new_t) - format.html { redirect_to @panel, notice: 'Panel was successfully moved.' } - format.json { head :ok } - else - format.html { render action: "show" } - format.json { render json: @panel.errors, status: :unprocessable_entity } - end + @panel.destroy + format.html { redirect_to panels_url } + format.json { head :ok } end end end