X-Git-Url: http://git.osdn.net/view?p=pettanr%2Fpettanr.git;a=blobdiff_plain;f=app%2Fcontrollers%2Fstories_controller.rb;h=0792326543673b55988ab53daec969fefce5c873;hp=1fcf0030e179fec5e65135512295781b35ede08c;hb=d7c8065be895b67dc453b0e11ad0f259f1ca6706;hpb=62c02bb06a5d343682992461a43df9188f9a7a2f diff --git a/app/controllers/stories_controller.rb b/app/controllers/stories_controller.rb index 1fcf0030..07923265 100644 --- a/app/controllers/stories_controller.rb +++ b/app/controllers/stories_controller.rb @@ -1,150 +1,94 @@ class StoriesController < ApplicationController 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] + before_action :authenticate_user, :only => [:new, :create, :edit, :update, :destroy] + before_action :authenticate_author, :only => [:new, :create, :edit, :update, :destroy] else - before_filter :authenticate_reader, :only => [:index, :show, :play, :story_sheets, :sheets, :by_comic, :by_sheet, :by_author] - before_filter :authenticate_user, :only => [:new, :create, :edit, :update, :destroy] - before_filter :authenticate_author, :only => [:new, :create, :edit, :update, :destroy] - end - - def self.model - Story + before_action :authenticate_reader, :only => [ + :index, :show, :play, :by_comic, :by_sheet, :by_author + ] + before_action :authenticate_user, :only => [:new, :create, :edit, :update, :destroy] + before_action :authenticate_author, :only => [:new, :create, :edit, :update, :destroy] end def index - public_list - end - - def story_sheets - has_many_list - end - - def sheets - has_many_list + filer_list end def by_comic - filter_list + filer_list param: params[:id] end def by_sheet - filter_list + filer_list param: params[:id] end def by_author - filter_list + filer_list param: params[:id] + end + + def show_html_format format + format.html { + @play_list = Locmare::ListGroup.list( + 'story_sheets', 'by_story', @operators, + {:id => @item.id, :page_size => -1} # set no limit options + ) + } end def show - @item = Story.show(params[:id], @operators) - + set_show respond_to do |format| - format.html { - if @operators.author - @new_sheet_items = assist_items('sheet', 'private_list') - @new_sheet_filer = assist_filer 'sheet', @new_sheet_items - 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 - @item = Story.show(params[:id], @operators) - @page = StorySheet.page params[:page] - @sheet = StorySheet.play_sheet(@item, @operators, @page) + set_play + @finder.per( 1) # show one sheet + play_list respond_to do |format| format.html { - @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 { - if @sheet - @story_sheets = SheetPanel.play_list @sheet, @author - render text: SheetPanel.list_as_json_text(@story_sheets, @author) - else - render text: '' + @pager = @finder + if @item.own? @operators + @new_sheet_items = assist_items('home', 'sheets', finder: :find_private, param: @operators) end } - format.jsonp { - render :json => "callback(" + @story_sheets.to_json_list + ");" - } + list_json_format @finder, format end end def new - @story = Story.new - @story.supply_default - respond_to do |format| - format.html - format.js - format.json { render json: @story.to_json(Story.show_json_opt) } - end + form_new end - + def edit - @story = Story.edit(params[:id], @operators) - 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, @operators) if @story.comic_id - - respond_to do |format| - 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) } - else - flash[:notice] = I18n.t('flash.notice.not_created', :model => Story.model_name.human) - format.html { render action: "new" } - format.json { render json: @story.errors, status: :unprocessable_entity } - end - end + set_model + @story = @item + @item = @my_model_class.new + @item.supply_default + @item.attributes = @item.permit_params params + @item.overwrite @operators + render_create end def update - @story = Story.edit(params[:id], @operators) - ot = @story.t - @story.attributes = params[:story] - @story.overwrite - respond_to do |format| - 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 } - else - flash[:notice] = I18n.t('flash.notice.not_updated', :model => Story.model_name.human) - format.html { render action: "edit" } - format.json { render json: @story.errors, status: :unprocessable_entity } - end - end + set_edit + @story = @item + @item.attributes = @item.permit_params params + @item.overwrite @operators + render_update end - + def destroy - @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) - format.html { redirect_to comic_path(@story.comic)} - format.json { head :ok } - else - flash[:notice] = I18n.t('flash.notice.not_destroyed', :model => Story.model_name.human) - format.html { redirect_to story_path(@story) } - format.json { render json: @story.errors, status: :unprocessable_entity } - end - end + set_model + @item = @my_model_class.edit(params[:id], @operators) + render_destroy '/home/' + @item.path_name end + end