OSDN Git Service

fix license picture
[pettanr/pettanr.git] / app / models / writing_format.rb
1 class WritingFormat < Peta::Template
2   load_manifest
3   has_many :speeches
4   belongs_to :system_picture
5   
6   validates :name, :presence => true, :uniqueness => true, :length => {:maximum => 50}
7   validates :module_name, :presence => true, :length => {:maximum => 50}
8   validates :caption, :presence => true, :length => {:maximum => 30}
9   validates :t, :presence => true, :numericality => {:greater_than_or_equal_to => 0}
10   validates :system_picture_id, :presence => true, :numericality => true, :existence => {:both => false}
11   validates :settings, :presence => true
12   
13   def supply_default
14   end
15   
16   def overwrite
17     self.t = WritingFormat.count.to_i if self.new_record?
18   end
19   
20   def symbol_option
21     self.system_picture.tmb_opt_img_tag
22   end
23   
24   def self.list_order
25     'writing_formats.t asc'
26   end
27   
28 #engine vw
29 def self.list
30   self.enable_list
31 end
32
33   def self.enable_list
34     WritingFormat.find(:all).delete_if {|wf|
35       wf.enable? == false
36     }
37   end
38   
39   def self.show_opt
40     {}
41   end
42   
43   def self.show_json_opt
44     {}
45   end
46   
47   def self.store name, attr
48     r = WritingFormat.replace_system_picture(attr || {})
49     attr["settings"] = r["settings"] ? r["settings"].to_json : nil
50     r = WritingFormat.modify_object name, attr
51     r.overwrite
52     r.save
53     r
54   end
55   
56   def parsed_settings
57     @parsed_settings ||= JSON.parse(self.settings)
58   end
59   
60   # get template model   ex) PettanrSimpleFormat::Renderer
61   # render method written in template model
62   #def extend_model
63   #  self.template_module.const_get 'Renderer'
64   #end
65   
66   def self.import filename
67     WritingFormat.import_file(filename) {|name, attr| WritingFormat.store(name, attr)}
68   end
69   
70   def self.disp_import_error r
71     if r == false
72       puts "json file error. file does not exist or broken"
73     else
74       unless r.empty?
75         r.each do |sbt|
76           put sbt.errors.full_messages
77         end
78       end
79     end
80   end
81 end