OSDN Git Service

temp
[pettanr/pettanr.git] / app / models / scroll.rb
1 class Scroll < ActiveRecord::Base
2   has_many :scroll_panels
3   belongs_to :author
4   
5   validates :title, :presence => true, :length => {:maximum => 100}
6   validates :visible, :presence => true, :numericality => true, :inclusion => {:in => 0..1}
7   validates :author_id, :presence => true, :numericality => true, :existence => {:both => false}
8
9   before_validation :valid_encode
10   
11   cattr_reader :singular, :plural
12   @@singular = 'Scroll'
13   @@plural = 'Scrolls'
14   def self.item_name
15     self.singular.underscore
16   end
17   
18   def item_name
19     self.class.item_name
20   end
21   
22   def self.path_name with_engine = false
23     self.plural.underscore
24   end
25   
26   def path_name 
27     self.class.path_name
28   end
29   
30   def self.owner_type
31     :author
32   end
33   
34   def valid_encode
35     ['title', 'description'].each do |a|
36       next if attributes[a] == nil
37       raise Pettanr::BadRequest unless attributes[a].valid_encoding?
38     end
39   end
40   
41   def supply_default
42     self.visible = 0 if self.visible.blank?
43   end
44   
45   def overwrite operators
46     return false unless operators.author
47     self.author_id = operators.author.id
48   end
49   
50   def own? roles
51     roles = [roles] unless roles.respond_to?(:each)
52     au = Scroll.get_author_from_roles roles
53     return false unless au
54     self.author_id == au.id
55   end
56   
57   def visible? operators
58     if MagicNumber['run_mode'] == 0
59       return false unless operators.guest?
60     else
61       return false unless operators.resource_reader?
62     end
63     self.visible > 0
64   end
65   
66   def scroll_panels_count
67     ScrollPanel.where(['scroll_panels.scroll_id = ?', self.id]).count
68   end
69   
70   def self.default_page_size
71     25
72   end
73   
74   def self.max_page_size
75     100
76   end
77   
78   def self.default_panel_size
79     30
80   end
81   
82   def self.max_panel_size
83     200
84   end
85   
86   def self.page prm = nil
87     page = prm.to_i
88     page = 1 if page < 1
89     page
90   end
91   
92   def self.page_size prm = self.default_page_size
93     page_size = prm.to_i
94     page_size = self.max_page_size if page_size > self.max_page_size
95     page_size = self.default_page_size if page_size < 1
96     page_size
97   end
98   
99   def self.list_order
100     'scrolls.updated_at desc'
101   end
102   
103   def self.list_where
104     'scrolls.visible > 0'
105   end
106   
107   def self.mylist_where au
108     ['scrolls.author_id = ?', au.id]
109   end
110   
111   def self.himlist_where au
112     ['scrolls.author_id = ? and scrolls.visible > 0', au.id]
113   end
114   
115   def self.list page = 1, page_size = self.default_page_size
116     Scroll.where(self.list_where()).includes(Scroll.list_opt).order('scrolls.updated_at desc').offset((page -1) * page_size).limit(page_size)
117   end
118   
119   def self.mylist au, page = 1, page_size = Author.default_scroll_page_size
120     Scroll.where(self.mylist_where(au)).includes(Scroll.list_opt).order('scrolls.updated_at desc').offset((page -1) * page_size).limit(page_size)
121   end
122   
123   def self.himlist au, page = 1, page_size = Author.default_scroll_page_size
124     Scroll.where(self.himlist_where(au)).includes(Scroll.list_opt).order('scrolls.updated_at desc').offset((page -1) * page_size).limit(page_size)
125   end
126   
127   def self.list_paginate page = 1, page_size = self.default_page_size
128     Kaminari.paginate_array(Array.new(Scroll.where(self.list_where()).count, nil)).page(page).per(page_size)
129   end
130   
131   def self.mylist_paginate au, page = 1, page_size = Author.default_scroll_page_size
132     Kaminari.paginate_array(Array.new(Scroll.where(self.mylist_where(au)).count, nil)).page(page).per(page_size)
133   end
134   
135   def self.himlist_paginate au, page = 1, page_size = Author.default_scroll_page_size
136     Kaminari.paginate_array(Array.new(Scroll.where(self.himlist_where(au)).count, nil)).page(page).per(page_size)
137   end
138   
139   def self.list_by_panel panel_id, roles, page = 1, page_size = self.default_page_size
140     self.where(ScrollPanel.list_by_panel_where(panel_id)).includes(
141       {:scroll_panels => {}}
142     ).order('scroll_panels.updated_at desc').offset((page -1) * page_size).limit(page_size)
143   end
144   
145   def self.list_by_author_where author_id
146     ['scrolls.author_id = ?', author_id]
147   end
148   
149   def self.list_by_author author_id, roles, page = 1, page_size = self.default_page_size
150     self.where(self.list_by_author_where(author_id)).includes(self.list_opt).order('scrolls.updated_at desc').offset((page -1) * page_size).limit(page_size)
151   end
152   
153   def self.list_opt
154     {:scroll_panels => {:panel => {}}, :author => {} }
155   end
156   
157   def self.list_json_opt
158     {:include => {:scroll_panels => {:include => {:panel => {}}}, :author => {}}}
159   end
160   
161   def self.show sid, operators
162     opt = {}
163     opt.merge!(Scroll.show_opt)
164     res = Scroll.find(sid, opt)
165     raise ActiveRecord::Forbidden unless res.visible?(operators)
166     res
167   end
168   
169   def self.edit sid, au
170     opt = {}
171     opt.merge!(Scroll.show_opt)
172     res = Scroll.find(sid, opt)
173     raise ActiveRecord::Forbidden unless res.own?(au)
174     res
175   end
176   
177   def self.show_opt
178     {:include => {:scroll_panels => {:panel => {}}, :author => {}}}
179   end
180   
181   def self.show_json_opt
182     {:include => {:scroll_panels => {:include => {:panel => {}}}, :author => {}}}
183   end
184   
185   def self.visible_count
186     Scroll.count 'visible > 0'
187   end
188   
189   def destroy_with_scroll_panel
190     res = false
191     Scroll.transaction do
192       self.scroll_panels.each do |scroll_panel|
193         raise ActiveRecord::Rollback unless scroll_panel.destroy
194       end
195       raise ActiveRecord::Rollback unless self.destroy
196       res = true
197     end
198     res
199   end
200   
201   def scenario
202     panels.map {|panel|
203       panel.scenario
204     }.join
205   end
206   
207   def plain_scenario
208     panels.map {|panel|
209       panel.plain_scenario
210     }.join
211   end
212   
213 end