OSDN Git Service

fix: show's destroy button
[pettanr/pettanr.git] / app / assets / javascripts / locmare / form.js.coffee
1 # form_name_with_sub_form\r
2 # item: editing item\r
3 # submit: string / 'submit'\r
4 class Locmare.FormBase extends Backbone.View\r
5   tagName: 'form'\r
6   \r
7   initialize: (options) ->\r
8     @form_name = options.form_name #_with_sub_form\r
9     @use_name = options.use_name || 'default'\r
10     @item = options.item\r
11     @element_form = options.element_form\r
12     @submit = options.submit\r
13     if /\./.test(@form_name)\r
14       @sub_form_names = @form_name.split('.')\r
15       @form_name = @sub_form_names.pop()\r
16       @root_form_name = @sub_form_names.shift()\r
17     else\r
18       @sub_form_names = []\r
19       #@form_name = @form_name\r
20       @root_form_name = @form_name\r
21     @manifest = LocalManifest.manifest().forms[@form_name].uses[@use_name]\r
22     @fields = {}\r
23     @on('change:field', @change)\r
24   \r
25   change: (field) ->\r
26     console.log(field.field_name)\r
27   \r
28   fold_extend_settings: (params) ->\r
29     @item.my_class().fold_extend_settings params[@item.item_name()]\r
30   \r
31   sub_form_name: () ->\r
32     r = _.map @sub_form_names, (name) ->\r
33       '[' + name + '_attributes' + ']'\r
34     r.join()\r
35   \r
36   form_field_name: (field_name) ->\r
37     @root_form_name + @sub_form_name() + '[' + field_name + ']'\r
38   \r
39   image_dir: () ->\r
40     '/images/'\r
41   \r
42   quit: () ->\r
43     null\r
44   \r
45 class Locmare.Form extends Locmare.FormBase\r
46   \r
47   @factory: (options) ->\r
48     custom_form = Pettanr.Views[Pettanr.camelize(options.item.model_name())].Form\r
49     if custom_form\r
50       new custom_form(options)\r
51     else\r
52       new Locmare.Form(options)\r
53   \r
54   initialize: (options) ->\r
55     super(options)\r
56     @submit = options.submit\r
57     @child_forms = {}\r
58     @item.boosts 'post'\r
59     @init_fields()\r
60   \r
61   render: () ->\r
62     this.$el.attr(@form_attr())\r
63     this.$el.html('')\r
64     @error_explanation = null\r
65     @div_fields = new Locmare.FormModule.Fields({\r
66       parent: this, fields: @fields\r
67     })\r
68     #this.$el.append(@error_explanation.render().el) if not @error_explanation\r
69     this.$el.append(@div_fields.render().el)\r
70     @add_elements() if @element_form\r
71     if @submit\r
72       c = @submit_class()\r
73       @div_submit = new c({form: this})\r
74       this.$el.append(@div_submit.render().el)\r
75       @delegateEvents({'submit': @method_type()})\r
76     this\r
77   \r
78   form_attr: () ->\r
79     {\r
80       method: @method_type(),\r
81       action: @action_url()\r
82     }\r
83   \r
84   refresh: () ->\r
85     _.each @fields, (field) =>\r
86       field.refresh()\r
87     _.each @child_forms, (child_form, name) =>\r
88       child_form.refresh()\r
89   \r
90   method_type: () ->\r
91     if @item.isNew()\r
92       'post'\r
93     else\r
94       'put'\r
95   \r
96   action_url: () ->\r
97     return null if !@submit    # element has not create actions\r
98     if @item.isNew()\r
99       @item.create_url()\r
100     else\r
101       @item.edit_url()\r
102   \r
103   add_elements: () ->\r
104     _.each @item.my_class().child_models(), (element_model) =>\r
105       items = @item.element_items(element_model)\r
106       if @item.my_class().my_manifest().associations.is_has_one(element_model)\r
107         @add_element(items)\r
108       else\r
109         _.each items, (item) =>\r
110           @add_element(item)\r
111   \r
112   add_element: (element) ->\r
113     form = Locmare.Form.factory({\r
114       form_name: element.item_name(), \r
115       use_name: @use_name,\r
116       item: element, \r
117       element_form: @element_form, \r
118       submit: null, \r
119     })\r
120     this.$el.append(form.render().el)\r
121     mm = @item.my_class().my_manifest()\r
122     em = element.my_class().my_manifest()\r
123     child_element_name = mm.associations.child_element_name(element.my_class())\r
124     if mm.associations.is_has_one(em)\r
125       @child_forms[child_element_name] = form\r
126     else\r
127       @child_forms[child_element_name] ||= []\r
128       @child_forms[child_element_name].push(form)\r
129     form\r
130   \r
131   remove_elements: () ->\r
132     _.each @child_forms, (child_form, name) =>\r
133       child_form.item.set({_destroy: true}, {silent: true})\r
134       child_form.remove_elements()\r
135   \r
136   init_fields: () ->\r
137     _.each @manifest.field_names, (field_name) =>\r
138       field_manifest = @manifest.fields[field_name]\r
139       boost_name = @item.my_class().find_boost_name(field_name)\r
140       extend_model = if boost_name \r
141         @item.boosters[boost_name].extend_model()\r
142       else\r
143         null\r
144       if boost_name and extend_model # field is extend setting AND template has a extend model\r
145         extend_form_name = @item.boosters[boost_name].item_name()\r
146         extend_item = @item.boosters[boost_name].extend_item()\r
147         @fields[field_name] = new Locmare.ExtendForm({\r
148           parent: this, \r
149           form_name: extend_form_name, \r
150           use_name: @use_name,\r
151           item: extend_item, \r
152           field_name: field_name\r
153         })\r
154       else\r
155         @fields[field_name] = new Locmare.FormModule.Field({\r
156           form: this, \r
157           field_name: field_name, \r
158           field_manifest: field_manifest\r
159         })\r
160   \r
161   submits: () ->\r
162     {\r
163       default: Locmare.FormModule.SubmitModule.Default\r
164     }\r
165   \r
166   submit_class: () ->\r
167     @submits()[@submit]\r
168   \r
169   post: () ->\r
170     _.each @fields, (field) =>\r
171       field.fold() if field.is_extend()\r
172       @item.set(field.field_name, field.val())\r
173     @item.unset('id')  # isNew use flag that id attr set\r
174     @trigger('http_post', @item.create_url(), this)\r
175     return false\r
176   \r
177   put: () ->\r
178     _.each @fields, (field) =>\r
179       field.fold() if field.is_extend()\r
180       @item.set(field.field_name, field.val())\r
181     @trigger('http_post', @item.update_url(), this)\r
182     return false\r
183   \r
184   save: () ->\r
185     @listenTo(@item, 'save:success', @success)\r
186     @listenTo(@item, 'save:fail', @fail)\r
187     @item.save()\r
188   \r
189   success: (model, response) ->\r
190     if !Pettanr.cache.restore(model.cache_key())\r
191       # item is new\r
192       model.url = model.default_url()\r
193       Pettanr.cache.store(model)\r
194     else\r
195       @item.fix()\r
196     @trigger('success', model, response)\r
197   \r
198   fail: (model, response) ->\r
199     @trigger('fail', response)\r
200   \r
201   quit: () ->\r
202     @item.release()\r
203   \r
204   save_data: (inspire = false) ->\r
205     @item.my_class().child_models()\r
206     attrs = {}\r
207     _.each @fields, (field) =>\r
208       attrs[field.field_name] = @item.get(field.field_name)\r
209     delete attrs['id'] if @item.isNew()\r
210     _.each @child_forms, (child_form, name) =>\r
211       mm = @item.my_class().my_manifest()\r
212       em = child_form.item.my_class().my_manifest()\r
213       if mm.associations.is_has_one(em)\r
214         d = child_form.save_data(inspire)\r
215         if inspire\r
216           delete d['id']\r
217           delete d[@item.item_name() + '_id']\r
218         attrs[name + '_attributes'] = d\r
219       else\r
220         attrs[name + '_attributes'] = []\r
221         _.each child_form, (form) =>\r
222           d = form.save_data(inspire)\r
223           if inspire\r
224             delete d['id']\r
225             delete d[@item.item_name() + '_id']\r
226           attrs[name + '_attributes'].push(d)\r
227     attrs\r
228   \r
229 class Locmare.ExtendForm extends Locmare.FormBase\r
230   tagName: 'div'\r
231   className: 'fields'\r
232   \r
233   initialize: (options) ->\r
234     @parent = options.parent\r
235     @field_name = options.field_name\r
236     super(options)\r
237     @listenTo(@item, 'input', @input)\r
238     @field = new Locmare.FormModule.Field({\r
239       form: @parent, \r
240       field_name: @field_name, \r
241       field_manifest: @parent.manifest.fields[@field_name]\r
242     })\r
243     @label = @field.label\r
244     @init_fields()\r
245   \r
246   render: () ->\r
247     this.$el.html('')\r
248     if !@is_hidden()\r
249       this.$el.append(@label.render().el) if not @label.hidden()\r
250       @div_fields = new Locmare.FormModule.Fields({\r
251         fields: @fields\r
252       })\r
253       this.$el.append(@div_fields.render().el)\r
254     this\r
255   \r
256   refresh: () ->\r
257     @field.refresh()\r
258   \r
259   input: (field) ->\r
260     a = {}\r
261     a[@field_name] = @val()\r
262     @parent.item.set(a, {silent: true})\r
263     @parent.item.trigger('input:' + @field_name + ':' + field)\r
264     @parent.item.trigger('input:' + @field_name)\r
265     @parent.item.trigger('input')\r
266   \r
267   fold: () ->\r
268     _.each @fields, (field) =>\r
269       @item.set(field.field_name, field.val())\r
270   \r
271   val: () ->\r
272     JSON.stringify(@item.attributes)\r
273   \r
274   is_hidden: () ->\r
275     _.isEmpty(@manifest.field_names)\r
276   \r
277   init_fields: () ->\r
278     _.each @manifest.field_names, (field_name) =>\r
279       field_manifest = @manifest.fields[field_name]\r
280       @fields[field_name] = new Locmare.FormModule.ExtendField({\r
281         form: this, \r
282         field_name: field_name, \r
283         field_manifest: field_manifest\r
284       })\r
285   \r
286   form_field_name: (extend_field_name) ->\r
287     # parent is field\r
288     @parent.form_field_name(@field_name)  + '[' + extend_field_name + ']'\r
289   \r
290   is_extend: () ->\r
291     true\r
292   \r
293 class Locmare.FormModule\r
294 class Locmare.FormModule.Fields extends Backbone.View\r
295   tagName: 'div'\r
296   className: 'fields'\r
297   \r
298   initialize: (options) ->\r
299     @parent = options.parent\r
300     @fields = options.fields\r
301   \r
302   render: () ->\r
303     this.$el.html('')\r
304     _.each @fields, (field) =>\r
305       this.$el.append(field.render().el)\r
306       this.$el.append(field.rb.render().el) if field.rb\r
307     this\r
308   \r
309 class Locmare.FormModule.SubmitModule\r
310 class Locmare.FormModule.SubmitModule.Default extends Backbone.View\r
311   tagName: 'div'\r
312   className: 'actions'\r
313   \r
314   initialize: (options) ->\r
315     @form = options.form\r
316   \r
317   render: () ->\r
318     caption = I18n.t(@submit_name())\r
319     this.$el.html('<input type="submit" name="commit" class="submit" value="' + caption + '"></input>')\r
320     this\r
321   \r
322   submit_name: () ->\r
323     if @form.item.isNew()\r
324       @form.item.table_name() + '.submit.new'\r
325     else\r
326       @form.item.table_name() + '.submit.edit'\r
327   \r