OSDN Git Service

t#31470:create pager
[pettanr/pettanr.git] / app / controllers / panels_controller.rb
index d35751c..e664820 100644 (file)
 class PanelsController < ApplicationController
-  before_filter :authenticate_author!, :except => [:index, :show]
-
-  private
-  
-  def treat_param panel
-    panel.author_id = current_author.id
+  layout 'test' if MagicNumber['test_layout']
+  if MagicNumber['run_mode'] == 0
+    before_filter :authenticate_user, :only => [:new, :edit, :create, :update, :destroy, :catch]
+    before_filter :authenticate_author, :only => [:new, :edit, :create, :update, :destroy, :catch]
+  else
+    before_filter :authenticate_reader, :only => [:index, :show]
+    before_filter :authenticate_user, :only => [:new, :edit, :create, :update, :destroy, :catch]
+    before_filter :authenticate_author, :only => [:new, :edit, :create, :update, :destroy, :catch]
   end
-  
+  before_filter :authenticate_admin!, :only => [:list, :browse]
+
   public
   
-  # GET /panels
-  # GET /panels.json
   def index
-    @panels = Panel.all :order => 'updated_at'
+    @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 }
+      format.html {
+        @paginate = Panel.list_paginate(@page, @page_size)
+      }
+      format.json { render text: Panel.list_as_json_text(@panels) }
+      format.atom 
+      format.rss { render :layout => false }
     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], [@user, @admin])
 
     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.html {
+        if @author
+          @new_comics = Comic.mylist(@author, 0, 5)
+          @fresh_comics = Story.mylist(@author, 0, 5).map {|s| s.comic}
+        end
       }
+      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
+  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'
+
+    respond_to do |format|
+      format.html { render layout: 'system' }
+      format.json { render json: @panels }
+    end
+  end
+
+  def browse
+    @panel = Panel.find(params[:id])
+
+    respond_to do |format|
+      format.html { render layout: 'system' }
+    end
   end
 
-  # GET /panels/new
-  # GET /panels/new.json
   def new
     @panel = Panel.new
+    @panel.supply_default
 
     respond_to do |format|
-      format.html # new.html.erb
-      format.json { render json: @panel }
+      format.html
+      format.js
+      format.json { render json: @panel.panel_elements_as_json }
     end
   end
 
-  # GET /panels/1/edit
   def edit
-    @panel = Panel.find(params[:id])
+    @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
+        flash[:notice] = I18n.t('flash.notice.created', :model => Panel.model_name.human)
+        format.html { redirect_to @panel }
+        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
 
-  # 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][:seqno] and params[:panel][:seqno].to_i != @panel.seqno
-            @panel.move_to params[:panel][:seqno].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
+        flash[:notice] = I18n.t('flash.notice.updated', :model => Panel.model_name.human)
+        format.html { redirect_to @panel }
+        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][:seqno].to_i
+    @panel = Panel.edit(params[:id], @author)
     respond_to do |format|
       Panel.transaction do
-        if @panel.move_to(@new_seq)
-          format.html { redirect_to @panel, notice: 'Panel was successfully moved.' }
+        if @panel.destroy_with_elements
+          flash[:notice] = I18n.t('flash.notice.destroyed', :model => Panel.model_name.human)
+          format.html { redirect_to '/home/panel' }
           format.json { head :ok }
         else
-          format.html { render action: "show" }
+          flash[:notice] = I18n.t('flash.notice.not_destroyed', :model => Panel.model_name.human)
+          format.html { redirect_to @panel }
           format.json { render json: @panel.errors, status: :unprocessable_entity }
         end
       end
     end
   end
   
+  def catch
+    @panel = Panel.edit(params[:id], @author)
+
+    respond_to do |format|
+      @author.working_panel_id = @panel.id
+      if @author.save
+        format.html { redirect_to @panel }
+      else
+      end
+    end
+  end
+
 end