OSDN Git Service

t#32471:add profiles
[pettanr/pettanr.git] / app / controllers / panels_controller.rb
index 7d5e4e6..14adc89 100644 (file)
@@ -1,7 +1,13 @@
 class PanelsController < ApplicationController
   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]
+  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
@@ -12,19 +18,37 @@ class PanelsController < ApplicationController
     @panels = Panel.list(@page, @page_size)
 
     respond_to do |format|
-      format.html # index.html.erb
+      format.html {
+        @paginate = Panel.list_paginate(@page, @page_size)
+        render :template => 'system/filer', :locals => {
+          :items => @panels, :model => Panel, 
+          :roles => [@user, @admin], :pager => @paginate
+        }
+      }
+      format.html {
+      }
       format.json { render text: Panel.list_as_json_text(@panels) }
+      format.atom 
+      format.rss { render :layout => false }
     end
   end
 
   def show
-    @panel = Panel.show(params[:id], @author)
+    @item = Panel.show(params[:id], [@user, @admin])
 
     respond_to do |format|
-      format.html # show.html.erb
-      format.json { render json: @panel.panel_elements_as_json }
+      format.html {
+        if @author
+          @new_scrolls = Scroll.mylist(@author, 1, 5)
+          @fresh_scrolls = ScrollPanel.mylist(@author, 1, 5).map {|sp| sp.scroll}
+          @new_sheets = Sheet.mylist(@author, 1, 5)
+          @fresh_sheets = SheetPanel.mylist(@author, 1, 5).map {|sp| sp.sheet}
+        end
+      }
+      format_prof format
+      format.json { render json: @item.panel_elements_as_json }
       format.jsonp {
-        render :json => "callback(" + @panel.panel_elements_as_json + ");"
+        render :json => "callback(" + @item.panel_elements_as_json + ");"
       }
     end
   end
@@ -58,7 +82,7 @@ class PanelsController < ApplicationController
     @panel.supply_default
 
     respond_to do |format|
-      format.html # new.html.erb
+      format.html
       format.js
       format.json { render json: @panel.panel_elements_as_json }
     end
@@ -117,7 +141,7 @@ class PanelsController < ApplicationController
       Panel.transaction do
         if @panel.destroy_with_elements
           flash[:notice] = I18n.t('flash.notice.destroyed', :model => Panel.model_name.human)
-          format.html { redirect_to '/home/panel' }
+          format.html { redirect_to '/home/panels' }
           format.json { head :ok }
         else
           flash[:notice] = I18n.t('flash.notice.not_destroyed', :model => Panel.model_name.human)
@@ -128,4 +152,16 @@ class PanelsController < ApplicationController
     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