X-Git-Url: http://git.osdn.net/view?a=blobdiff_plain;f=app%2Fmodels%2Fpanel.rb;h=11ac11208bacad3c4d147374a1f78dd49267c47a;hb=6fb8bc9e0e2b4ee9840f42e2915598db46b9a4b8;hp=84a6685fc980b021af1bf8ff1f540bd2ea4d5ade;hpb=2a757d724155bd506f611cd6117b4d3cac7302c6;p=pettanr%2Fpettanr.git diff --git a/app/models/panel.rb b/app/models/panel.rb index 84a6685f..11ac1120 100644 --- a/app/models/panel.rb +++ b/app/models/panel.rb @@ -1,8 +1,8 @@ #コマ -class Panel < ActiveRecord::Base +class Panel < Pettanr::Content belongs_to :author - belongs_to :resource_picture - has_many :stories + has_many :scroll_panels + has_many :sheet_panels has_many :panel_pictures, :dependent => :destroy has_many :speech_balloons, :dependent => :destroy has_many :ground_pictures, :dependent => :destroy @@ -15,186 +15,162 @@ class Panel < ActiveRecord::Base validates :width, :presence => true, :numericality => true, :natural_number => true validates :height, :presence => true, :numericality => true, :natural_number => true validates :border, :presence => true, :numericality => {:greater_than_or_equal_to => 0} - validates :x, :numericality => {:allow_blank => true} - validates :y, :numericality => {:allow_blank => true} - validates :z, :numericality => {:allow_blank => true, :greater_than => 0} validates :author_id, :presence => true, :numericality => true, :existence => {:both => false} validates :publish, :presence => true, :numericality => true - before_validation :valid_encode + def self.valid_encode_columns + super + ['caption'] + end - def valid_encode - ['caption'].each do |a| - next if attributes[a] == nil - raise Pettanr::BadRequest unless attributes[a].valid_encoding? + def self.each_element_class_names + Pettanr::Application.manifest.system_resources.elements.each do |k, n| + yield k end end + def self.class_name_to_class k + Object.const_get k + end + + def self.each_element_classes + self.each_element_class_names do |k| + e = self.class_name_to_class k + yield e + end + end + + def elements_by_class_name class_name + self.__send__ class_name.tableize + end + def supply_default self.border = 2 self.publish = 0 end - def overwrite au - self.author_id = au.id + def overwrite operators + return false unless operators.author + self.author_id = operators.author.id end - def own? roles - roles = [roles] unless roles.respond_to?(:each) - au = Panel.get_author_from_roles roles - return false unless au - self.author_id == au.id - end - - def visible? roles - if MagicNumber['run_mode'] == 0 - return false unless guest_role_check(roles) - else - return false unless reader_role_check(roles) - end - return true if self.own?(roles) + def visible? operators + return false unless super + return true if self.new_record? self.publish? end - def usable? au - visible? au + def usable? operators + self.visible? operators end def publish? self.publish > 0 end - def self.default_page_size - 25 + def tag_id c = nil + 'panel' + self.tag_panel_id + c.to_s end - def self.max_page_size - 100 + def tag_panel_id + self.new_record? ? '0' : self.id.to_s end - def self.page prm = nil - page = prm.to_i - page = 1 if page < 1 - page + def field_tag_id f + self.tag_id + f.to_s end - def self.page_size prm = self.default_page_size - page_size = prm.to_i - page_size = self.max_page_size if page_size > self.max_page_size - page_size = self.default_page_size if page_size < 1 - page_size + def tag_attributes column = nil, opt = {} + { + :id => self.field_tag_id(column), :panel_id => self.tag_panel_id + }.merge(opt) end - def self.list page = 1, page_size = self.default_page_size - opt = {} - opt.merge!(self.list_opt) - opt.merge!({:limit => page_size, :offset => (page -1) * page_size}) if page_size > 0 - opt.merge!({:conditions => 'panels.publish > 0', :order => 'panels.updated_at desc'}) - Panel.find(:all, opt) + def select_tag_attributes(selected, column, opt = {}) + [ + :last, :first, + {:html => {:selected => selected}}, + self.field_tag_attributes(column, opt) + ] end - def self.mylist au, page = 1, page_size = Author.default_panel_page_size - opt = {} - opt.merge!(self.list_opt) - opt.merge!({:limit => page_size, :offset => (page -1) * page_size}) if page_size > 0 - opt.merge!({:conditions => ['panels.author_id = ?', au.id], :order => 'panels.updated_at desc'}) - Panel.find(:all, opt) + def field_tag_attributes column, opt = {} + self.tag_attributes(column).merge( + {:column => column} + ).merge(opt) end - def self.himlist au, page = 1, page_size = Author.default_panel_page_size - opt = {} - opt.merge!(self.list_opt) - opt.merge!({:limit => page_size, :offset => (page -1) * page_size}) if page_size > 0 - opt.merge!({:conditions => ['panels.author_id = ? and panels.publish > 0', au.id], :order => 'panels.updated_at desc'}) - Panel.find(:all, opt) + def tag_attr column = nil, opt = {} + self.tag_attributes(column, opt).to_attr end - def self.list_opt - {:include => { - :panel_pictures => { - :picture => {:artist => {}, :license => {}} - }, - :speech_balloons => {:balloons => {}, :speeches => {}}, - :ground_pictures => { - :picture => {:artist => {}, :license => {}} - }, - :ground_colors => { - }, - :author => {} - }} + def field_tag_attr column, no_attr, opt = {} + self.field_tag_attributes(column, no_attr, opt).to_attr end - def self.show rid, roles - opt = {} - opt.merge!(Panel.show_opt) - res = Panel.find(rid, opt) - raise ActiveRecord::Forbidden unless res.visible?(roles) - res + def render_count + @render_count ||= 1 + end + + def rendered + @render_count = render_count + 1 + end + + def self.list_where + 'panels.publish > 0' end - def self.edit rid, au - opt = {} - opt.merge!(Panel.show_opt) - res = Panel.find(rid, opt) - raise ActiveRecord::Forbidden unless res.own?(au) - res + def self.list_order + 'panels.updated_at desc' + end + + def self.list_opt + r = { + :author => {} + } + self.each_element_classes do |e| + r.merge!(e.list_opt_for_panel) + end + r end def self.show_opt - {:include => { - :panel_pictures => { - :picture => {:artist => {}, :license => {}} - }, - :speech_balloons => {:balloons => {}, :speeches => {}}, - :ground_pictures => { - :picture => {:artist => {}, :license => {}} - }, - :ground_colors => { - }, + r = { :author => {} - }} + } + self.each_element_classes do |e| + r.merge!(e.show_opt_for_panel) + end + {:include => r} end def parts_element - ((self.panel_pictures || []) + (self.speech_balloons || [])).compact + r = [] + self.class.each_element_class_names do |k| + r += (self.elements_by_class_name(k) || []) + end + r end - def parts + def zorderd_elements res = [] self.parts_element.each do |e| - res[e.t] = e + res[e.z-1] = e end res end - def grounds - ((self.ground_colors || []) + (self.ground_pictures || [])).compact - end - def panel_elements - parts + grounds - end - - @@elm_json_opt = { - 'PanelPicture' => { - :picture => {:artist => {}, :license => {}} - }, - 'SpeechBalloon' => {:balloons => {}, :speeches => {}}, - 'GroundPicture' => { - :picture => {:artist => {}, :license => {}} - }, - 'GroundColor' => { - }, - } - - def self.elm_json_opt e - @@elm_json_opt[e.class.to_s] + res = [] + self.parts_element.each do |e| + res[e.t] = e + end + res end def elements self.panel_elements.map {|e| #(-_-;)<... kore wa hidoi - JSON.parse e.to_json({:include => Panel.elm_json_opt(e)}) + JSON.parse e.to_json({:include => e.class.json_opt_for_panel}) } end @@ -206,6 +182,14 @@ class Panel < ActiveRecord::Base '[' + ary.map {|i| i.panel_elements_as_json }.join(',') + ']' end + def new_t + self.panel_elements.size + end + + def new_z + self.panel_elements.size + 1 + end + def scenario panel_elements.map { |e| e.scenario @@ -220,7 +204,8 @@ class Panel < ActiveRecord::Base def licensed_pictures r = {} - ((self.panel_pictures || []) + (self.ground_pictures || [])).compact.each do |elm| + self.panel_elements.each do |elm| + next unless elm.class.has_picture? r[elm.picture_id] = elm.picture unless r[elm.picture_id] end r @@ -233,62 +218,108 @@ class Panel < ActiveRecord::Base def self.collect_element_value elements, name elements.map {|e| e.map {|o| - o[name] - } + if o['_destroy'] or o[:_destroy] + nil + else + o[name] + end + }.compact }.flatten end - def self.validate_t ary - i = 0 - ary.compact.sort.each do |t| - break false unless t == i + def self.validate_serial ary, offset = 0 + i = offset + ary.compact.sort.each do |n| + break false unless n == i i += 1 end - ary.compact.size == i + ary.compact.size == i - offset end - def self.validate_element_t elements, name - Panel.validate_t(Panel.collect_element_value(elements, name)) + def self.validate_element_serial elements, name, offset = 0 + Panel.validate_serial(Panel.collect_element_value(elements, name), offset) end - def self.validate_elements_t c + def self.validate_elements_serial c c.map {|conf| - Panel.validate_element_t(conf[:elements], conf[:name]) ? nil : false + Panel.validate_element_serial(conf[:elements], conf[:name], conf[:offset]) ? nil : false }.compact.empty? end - def validate_t_list + def validate_serial_list + l = [] + self.class.each_element_class_names do |k| + l << self.elements_by_class_name(k) + end [ - {:elements => [self.panel_pictures, self.speech_balloons], :name => :t} + {:elements => l, :name => :t, :offset => 0}, + {:elements => l, :name => :z, :offset => 1} ] end def validate_child # r1 = Panel.validate_elements_id validate_id_list - Panel.validate_elements_t validate_t_list + Panel.validate_elements_serial validate_serial_list end - def store attr, au + def boost + @new_element_index = 0 + self.panel_elements.each do |elm| + if elm.new_record? + elm.new_index = @new_element_index + @new_element_index += 1 + end + end + end + + def store attr, operators if attr == false self.errors.add :base, I18n.t('errors.invalid_json') return false end self.attributes = attr - self.overwrite au + self.overwrite operators res = false Panel.transaction do + self.panel_elements.each do |elm| + elm.new_panel = self + elm.boost + end +#self.publish = nil + res = self.save unless validate_child + res = false self.errors.add :base, I18n.t('errors.invalid_t') raise ActiveRecord::Rollback end - res = self.save end res end + def remove_element target, operators + ct = target.t + cz = target.z + panel_attributes = {} + self.panel_elements.each do |elm| + attr = elm.attributes + if elm == target + attr['_destroy'] = true + end + if elm.t > ct + attr['t'] -= 1 + end + if elm.z > cz + attr['z'] -= 1 + end + panel_attributes[elm.class.to_s.tableize + '_attributes'] ||= {} + panel_attributes[elm.class.to_s.tableize + '_attributes'][elm.id] = attr + end + self.store(panel_attributes, operators) + end + def destroy_with_elements res = false Panel.transaction do - self.panel_elements.each do |element| + self.parts_element.each do |element| raise ActiveRecord::Rollback unless element.destroy end raise ActiveRecord::Rollback unless self.destroy @@ -297,6 +328,30 @@ class Panel < ActiveRecord::Base res end + def copy + attr = self.copy_attributes + Panel.each_element_class_names do |n| + attr.merge! Panel.class_name_to_class(n).panelize(self.elements_by_class_name(n).map {|elm| elm.copy_attributes}) + end + attr + end + + def copy_attributes + r = self.attributes + r.delete 'id' + r.delete 'author_id' + r.delete 'created_at' + r.delete 'updated_at' + r + end + + def self.panelize panel + attr = panel.attributes + attr.delete 'id' + attr + end + + =begin def self.validate_id ary, pid ary.map {|v|