OSDN Git Service

element
[pettanr/pettanr.git] / app / controllers / stories_controller.rb
index 5d137c4..0b8fea2 100644 (file)
@@ -1,56 +1,63 @@
 class StoriesController < ApplicationController
-  layout 'test' if MagicNumber['test_layout']
-  if MagicNumber['run_mode'] == 0
+  if Manifest.manifest.magic_numbers['run_mode'] == 0
     before_filter :authenticate_user, :only => [:new, :create, :edit, :update, :destroy]
     before_filter :authenticate_author, :only => [:new, :create, :edit, :update, :destroy]
   else
-    before_filter :authenticate_reader, :only => [:index, :show, :play]
+    before_filter :authenticate_reader, :only => [
+      :index, :show, :play, :by_comic, :by_sheet, :by_author, :count, :count_by_comic, :count_by_sheet, :count_by_author
+    ]
     before_filter :authenticate_user, :only => [:new, :create, :edit, :update, :destroy]
     before_filter :authenticate_author, :only => [:new, :create, :edit, :update, :destroy]
   end
-  before_filter :authenticate_admin!, :only => [:list, :browse]
 
+  def self.model
+    Story
+  end
+  
   def index
-    @page = Story.page params[:page]
-    @page_size = Story.page_size params[:page_size]
-    @stories = Story.list(@page, @page_size)
-
-    respond_to do |format|
-      format.html {
-        @paginate = Story.list_paginate(@page, @page_size)
-        render :template => 'system/filer', :locals => {
-          :items => @stories, :model => Story, 
-          :roles => [@user, @admin], :pager => @paginate
-        }
-      }
-      format.json { render :json => @stories.to_json(Story.list_json_opt) }
-    end
+    filer_list
   end
-
+  
+  def by_comic
+    filer_list
+  end
+  
+  def by_sheet
+    filer_list
+  end
+  
+  def by_author
+    filer_list
+  end
+  
+  def show_html_format format
+    format.html {
+      if @operators.author
+        @new_sheet_items = assist_items('sheet', 'private')
+        #@new_sheet_filer = assist_filer 'sheet', @new_sheet_items
+      end
+    }
+  end
+  
   def show
-    @item = Story.show(params[:id], [@user, @admin])
-
+    set_show
     respond_to do |format|
-      format.html { 
-        @story = @item
-        if @author
-          @new_sheets = Sheet.mylist(@author, 1, 5)
-        end
-      }
-      format_prof format
-      format.json { render json: @item.to_json(Story.show_json_opt) }
+      show_html_format format
+      show_prof_format format
+      show_json_format format
     end
   end
   
   def play
-    @story = Story.show(params[:id], [@user, @admin])
+    @item = Story.show(params[:id], @operators)
     @page = StorySheet.page params[:page]
-    @sheet = StorySheet.play_sheet(@story, @author, @page)
+    @sheet = StorySheet.play_sheet(@item, @operators, @page)
     respond_to do |format|
       format.html {
-        @paginate = StorySheet.play_paginate(@story, @page)
-        if @author
-          @new_sheets = Sheet.mylist(@author, 1, 5)
+        @paginate = StorySheet.play_paginate(@item, @page)
+        if @operators.author
+          @new_sheet_items = assist_items('sheet', 'private_list')
+          @new_sheet_filer = assist_filer 'sheet', @new_sheet_items
         end
       }
       format.json {
@@ -67,51 +74,39 @@ class StoriesController < ApplicationController
     end
   end
   
-  def list
-    @stories = Story.all
-
-    respond_to do |format|
-      format.html { render layout: 'system' }# index.html.erb
-      format.json { render json: @stories }
-    end
+  def count
+    list_count
   end
-
-  def browse
-    @story = Story.find(params[:id])
-
-    respond_to do |format|
-      format.html { render layout: 'system' } # show.html.erb
-      format.json { render json: @story }
-    end
+  
+  def count_by_comic
+    list_count
+  end
+  
+  def count_by_sheet
+    list_count
+  end
+  
+  def count_by_author
+    list_count
   end
   
   def new
-    @story = Story.new 
-    @story.supply_default
-    respond_to do |format|
-      format.html # new.html.erb
-      format.js
-      format.json { render json: @story.to_json(Story.show_json_opt) }
-    end
+    form_new
   end
-
+  
   def edit
-    @story = Story.edit(params[:id], @author)
-    respond_to do |format|
-      format.html 
-      format.js
-    end
+    form_edit
   end
-
+  
   def create
     @story = Story.new 
     @story.supply_default
     @story.attributes = params[:story]
     @story.overwrite
-    @comic = Comic.edit(@story.comic_id, @author) if @story.comic_id
+    @comic = Comic.edit(@story.comic_id, @operators) if @story.comic_id
     
     respond_to do |format|
-      if @story.store @author
+      if @story.store @operators
         flash[:notice] = I18n.t('flash.notice.created', :model => Story.model_name.human)
         format.html { redirect_to play_story_path(@story, :page => @story.t.to_i + 1) }
         format.json { render json: @story.to_json(Story.show_json_opt) }
@@ -124,12 +119,12 @@ class StoriesController < ApplicationController
   end
   
   def update
-    @story = Story.edit(params[:id], @author)
+    @story = Story.edit(params[:id], @operators)
     ot = @story.t
     @story.attributes = params[:story]
     @story.overwrite
     respond_to do |format|
-      if @story.store  @author, ot
+      if @story.store @operators, ot
         flash[:notice] = I18n.t('flash.notice.updated', :model => Story.model_name.human)
         format.html { redirect_to play_story_path(@story, :page => @story.t.to_i + 1) }
         format.json { head :ok }
@@ -142,7 +137,7 @@ class StoriesController < ApplicationController
   end
 
   def destroy
-    @story = Story.edit(params[:id], @author)
+    @story = Story.edit(params[:id], @operators)
     respond_to do |format|
       if @story.destroy_and_shorten
         flash[:notice] = I18n.t('flash.notice.destroyed', :model => Story.model_name.human)