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