OSDN Git Service

fix editor event
[pettanr/pettanr.git] / app / assets / javascripts / locmare / form.js.coffee
1 # form_name_with_sub_form\r
2 # item: editing item\r
3 # mounted: true/false\r
4 # submit: string / 'submit'\r
5 # operators: \r
6 class Locmare.FormBase extends Backbone.View\r
7   tagName: 'form'\r
8   \r
9   initialize: (options) ->\r
10     @form_name = options.form_name #_with_sub_form\r
11     @item = options.item\r
12     @mounted = options.mounted\r
13     @submit = options.submit\r
14     @operators = options.operators\r
15     if /\./.test(@form_name)\r
16       @sub_form_names = @form_name.split('.')\r
17       @form_name = @sub_form_names.pop()\r
18       @root_form_name = @sub_form_names.shift()\r
19     else\r
20       @sub_form_names = []\r
21       #@form_name = @form_name\r
22       @root_form_name = @form_name\r
23     @manifest = LocalManifest.manifest().forms[@form_name]\r
24     @fields = {}\r
25     @on('change:field', @change)\r
26   \r
27   change: (field) ->\r
28     console.log(field.field_name)\r
29   \r
30   fold_extend_settings: (params) ->\r
31     @item.my_class().fold_extend_settings params[@item.item_name()]\r
32   \r
33   sub_form_name: () ->\r
34     r = _.map @sub_form_names, (name) ->\r
35       '[' + name + '_attributes' + ']'\r
36     r.join()\r
37   \r
38   form_field_name: (field_name) ->\r
39     @root_form_name + @sub_form_name() + '[' + field_name + ']'\r
40   \r
41   image_dir: () ->\r
42     '/images/'\r
43   \r
44 class Locmare.Form extends Locmare.FormBase\r
45   \r
46   @factory: (options) ->\r
47     custom_form = Pettanr.Views[Pettanr.camelize(options.item.model_name())].Form\r
48     if custom_form\r
49       new custom_form(options)\r
50     else\r
51       new Locmare.Form(options)\r
52   \r
53   initialize: (options) ->\r
54     super(options)\r
55     @submit = options.submit\r
56     @action = options.action\r
57     @item.boosts 'post'\r
58     @init_fields()\r
59   \r
60   render: () ->\r
61     method_type = if @item.isNew()\r
62       'post'\r
63     else\r
64       'put'\r
65     @attr = {\r
66       method: method_type,\r
67       action: @action\r
68     }\r
69     this.$el.attr(@attr)\r
70     this.$el.html('')\r
71     @error_explanation = null\r
72     @div_fields = new Locmare.FormModule.Fields({\r
73       parent: this, fields: @fields\r
74     })\r
75     #this.$el.append(@error_explanation.render().el) if not @error_explanation\r
76     this.$el.append(@div_fields.render().el)\r
77     if @submit\r
78       c = @submit_class()\r
79       @div_submit = new c({form: this})\r
80       this.$el.append(@div_submit.render().el)\r
81       @delegateEvents({'submit': method_type})\r
82     this\r
83   \r
84   add_element: (element) ->\r
85     form = new Locmare.Form(\r
86       element.item_name(), \r
87       element, \r
88       @mounted, \r
89       null, \r
90       @operators\r
91     )\r
92     this.$el.append( form.render().el)\r
93     form\r
94   \r
95   init_fields: () ->\r
96     _.each @manifest.field_names, (field_name) =>\r
97       field_manifest = @manifest.fields[field_name]\r
98       boost_name = @item.my_class().find_boost_name(field_name)\r
99       extend_model = if boost_name \r
100         @item.boosters[boost_name].extend_model()\r
101       else\r
102         null\r
103       if boost_name and extend_model # field is extend setting AND template has a extend model\r
104         extend_form_name = @item.boosters[boost_name].item_name()\r
105         extend_item = @item.boosters[boost_name].extend_item()\r
106         @fields[field_name] = new Locmare.ExtendForm({\r
107           parent: this, \r
108           form_name: extend_form_name, \r
109           item: extend_item, \r
110           mounted: @mounted, \r
111           operators: @operators, \r
112           field_name: field_name\r
113         })\r
114       else\r
115         @fields[field_name] = new Locmare.FormModule.Field({\r
116           form: this, \r
117           field_name: field_name, \r
118           field_manifest: field_manifest\r
119         })\r
120   \r
121   submits: () ->\r
122     {\r
123       default: Locmare.FormModule.SubmitModule.Default\r
124     }\r
125   \r
126   submit_class: () ->\r
127     @submits()[@submit]\r
128   \r
129   post: () ->\r
130     _.each @fields, (field) =>\r
131       @item.set(field.field_name, field.val())\r
132     if @item.save()\r
133       window.router.navigate('/' + @item.table_name() + '/' + Pettanr.to_s(@item.get('id')), true)\r
134       return false\r
135     else\r
136       alert('invalid')\r
137   \r
138   put: () ->\r
139     _.each @fields, (field) =>\r
140       @item.set(field.field_name, field.val())\r
141     @item.overwrite({operators: @operators})\r
142     if @item.save()\r
143       window.router.navigate('/' + @item.table_name() + '/' + Pettanr.to_s(@item.get('id')), true)\r
144       return false\r
145     else\r
146       alert('invalid')\r
147   \r
148 class Locmare.ExtendForm extends Locmare.FormBase\r
149   tagName: 'div'\r
150   className: 'fields'\r
151   \r
152   initialize: (options) ->\r
153     @parent = options.parent\r
154     @field_name = options.field_name\r
155     super(options)\r
156     @field = new Locmare.FormModule.Field({\r
157       form: @parent, \r
158       field_name: @field_name, \r
159       field_manifest: @parent.manifest.fields[@field_name]\r
160     })\r
161     @label = @field.label\r
162     @init_fields()\r
163   \r
164   render: () ->\r
165     this.$el.html('')\r
166     @div_fields = new Locmare.FormModule.Fields({\r
167       fields: @fields\r
168     })\r
169     this.$el.append(@div_fields.render().el)\r
170     this\r
171   \r
172   init_fields: () ->\r
173     _.each @manifest.field_names, (field_name) =>\r
174       field_manifest = @manifest.fields[field_name]\r
175       @fields[field_name] = new Locmare.FormModule.ExtendField({\r
176         form: this, \r
177         field_name: field_name, \r
178         field_manifest: field_manifest\r
179       })\r
180   \r
181   form_field_name: (extend_field_name) ->\r
182     # parent is field\r
183     @parent.form_field_name(@field_name)  + '[' + extend_field_name + ']'\r
184   \r
185 class Locmare.FormModule\r
186 class Locmare.FormModule.Fields extends Backbone.View\r
187   tagName: 'div'\r
188   className: 'fields'\r
189   \r
190   initialize: (options) ->\r
191     @parent = options.parent\r
192     @fields = options.fields\r
193   \r
194   render: () ->\r
195     this.$el.html('')\r
196     _.each @fields, (field) =>\r
197       this.$el.append(field.render().el)\r
198       this.$el.append(field.rb.render().el) if field.rb\r
199     this\r
200   \r
201 class Locmare.FormModule.SubmitModule\r
202 class Locmare.FormModule.SubmitModule.Default extends Backbone.View\r
203   tagName: 'div'\r
204   className: 'actions'\r
205   \r
206   initialize: (options) ->\r
207     @form = options.form\r
208   \r
209   render: () ->\r
210     caption = I18n.t(@submit_name())\r
211     this.$el.html('<input type="submit" name="commit" class="submit" value="' + caption + '"></input>')\r
212     this\r
213   \r
214   submit_name: () ->\r
215     if @form.item.isNew()\r
216       @form.item.table_name() + '.submit.new'\r
217     else\r
218       @form.item.table_name() + '.submit.edit'\r
219   \r