OSDN Git Service

fix sign, fix layout
[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     @save_func = options.save_func\r
58     @child_forms = {}\r
59     @item.boosts 'post'\r
60     @init_fields()\r
61   \r
62   render: () ->\r
63     method_type = if @item.isNew()\r
64       'post'\r
65     else\r
66       'put'\r
67     @attr = {\r
68       method: method_type,\r
69       action: @action\r
70     }\r
71     this.$el.attr(@attr)\r
72     this.$el.html('')\r
73     @error_explanation = null\r
74     @div_fields = new Locmare.FormModule.Fields({\r
75       parent: this, fields: @fields\r
76     })\r
77     #this.$el.append(@error_explanation.render().el) if not @error_explanation\r
78     this.$el.append(@div_fields.render().el)\r
79     if @submit\r
80       c = @submit_class()\r
81       @div_submit = new c({form: this})\r
82       this.$el.append(@div_submit.render().el)\r
83       @delegateEvents({'submit': method_type})\r
84     this\r
85   \r
86   add_element: (element) ->\r
87     form = Locmare.Form.factory({\r
88       form_name: element.item_name(), \r
89       item: element, \r
90       mounted: @mounted, \r
91       submit: null, \r
92       operators: @operators,\r
93       action: '/' + element.table_name() + '/' + Pettanr.to_s(element.get('id'))\r
94     })\r
95     this.$el.append(form.render().el)\r
96     mm = @item.my_class().my_manifest()\r
97     em = element.my_class().my_manifest()\r
98     if mm.associations.is_has_one(em)\r
99       @child_forms[element.item_name()] = form\r
100     else\r
101       @child_forms[element.table_name()] ||= []\r
102       @child_forms[element.table_name()].push(form)\r
103     form\r
104   \r
105   init_fields: () ->\r
106     _.each @manifest.field_names, (field_name) =>\r
107       field_manifest = @manifest.fields[field_name]\r
108       boost_name = @item.my_class().find_boost_name(field_name)\r
109       extend_model = if boost_name \r
110         @item.boosters[boost_name].extend_model()\r
111       else\r
112         null\r
113       if boost_name and extend_model # field is extend setting AND template has a extend model\r
114         extend_form_name = @item.boosters[boost_name].item_name()\r
115         extend_item = @item.boosters[boost_name].extend_item()\r
116         @fields[field_name] = new Locmare.ExtendForm({\r
117           parent: this, \r
118           form_name: extend_form_name, \r
119           item: extend_item, \r
120           mounted: @mounted, \r
121           operators: @operators, \r
122           field_name: field_name\r
123         })\r
124       else\r
125         @fields[field_name] = new Locmare.FormModule.Field({\r
126           form: this, \r
127           field_name: field_name, \r
128           field_manifest: field_manifest\r
129         })\r
130   \r
131   submits: () ->\r
132     {\r
133       default: Locmare.FormModule.SubmitModule.Default\r
134     }\r
135   \r
136   submit_class: () ->\r
137     @submits()[@submit]\r
138   \r
139   post: () ->\r
140     _.each @fields, (field) =>\r
141       @item.set(field.field_name, field.val())\r
142     @trigger('post', this)\r
143     return false\r
144   \r
145   put: () ->\r
146     _.each @fields, (field) =>\r
147       @item.set(field.field_name, field.val())\r
148     @trigger('put', this)\r
149     return false\r
150   \r
151   save: (attrs = null, options = null) ->\r
152     if attrs\r
153       @item.save(attrs, options)\r
154     else\r
155       @item.save()\r
156   \r
157   valid: () ->\r
158     window.router.navigate('/' + @item.table_name() + '/' + Pettanr.to_s(@item.get('id')), true)\r
159     return false\r
160   \r
161   invalid: () ->\r
162     alert('invalid')\r
163   \r
164   save_data: () ->\r
165     @item.my_class().child_models()\r
166     attrs = {}\r
167     _.each @fields, (field) =>\r
168       attrs[field.field_name] = @item.get(field.field_name)\r
169     _.each @child_forms, (child_form, name) =>\r
170       mm = @item.my_class().my_manifest()\r
171       em = child_form.item.my_class().my_manifest()\r
172       if mm.associations.is_has_one(em)\r
173         attrs[name + '_attributes'] = child_form.save_data()\r
174       else\r
175         attrs[name + '_attributes'] = []\r
176         _.each child_form, (form) =>\r
177           attrs[name + '_attributes'].push(form.save_data())\r
178     attrs\r
179   \r
180 class Locmare.ExtendForm extends Locmare.FormBase\r
181   tagName: 'div'\r
182   className: 'fields'\r
183   \r
184   initialize: (options) ->\r
185     @parent = options.parent\r
186     @field_name = options.field_name\r
187     super(options)\r
188     @field = new Locmare.FormModule.Field({\r
189       form: @parent, \r
190       field_name: @field_name, \r
191       field_manifest: @parent.manifest.fields[@field_name]\r
192     })\r
193     @label = @field.label\r
194     @init_fields()\r
195   \r
196   render: () ->\r
197     this.$el.html('')\r
198     @div_fields = new Locmare.FormModule.Fields({\r
199       fields: @fields\r
200     })\r
201     this.$el.append(@div_fields.render().el)\r
202     this\r
203   \r
204   init_fields: () ->\r
205     _.each @manifest.field_names, (field_name) =>\r
206       field_manifest = @manifest.fields[field_name]\r
207       @fields[field_name] = new Locmare.FormModule.ExtendField({\r
208         form: this, \r
209         field_name: field_name, \r
210         field_manifest: field_manifest\r
211       })\r
212   \r
213   form_field_name: (extend_field_name) ->\r
214     # parent is field\r
215     @parent.form_field_name(@field_name)  + '[' + extend_field_name + ']'\r
216   \r
217 class Locmare.FormModule\r
218 class Locmare.FormModule.Fields extends Backbone.View\r
219   tagName: 'div'\r
220   className: 'fields'\r
221   \r
222   initialize: (options) ->\r
223     @parent = options.parent\r
224     @fields = options.fields\r
225   \r
226   render: () ->\r
227     this.$el.html('')\r
228     _.each @fields, (field) =>\r
229       this.$el.append(field.render().el)\r
230       this.$el.append(field.rb.render().el) if field.rb\r
231     this\r
232   \r
233 class Locmare.FormModule.SubmitModule\r
234 class Locmare.FormModule.SubmitModule.Default extends Backbone.View\r
235   tagName: 'div'\r
236   className: 'actions'\r
237   \r
238   initialize: (options) ->\r
239     @form = options.form\r
240   \r
241   render: () ->\r
242     caption = I18n.t(@submit_name())\r
243     this.$el.html('<input type="submit" name="commit" class="submit" value="' + caption + '"></input>')\r
244     this\r
245   \r
246   submit_name: () ->\r
247     if @form.item.isNew()\r
248       @form.item.table_name() + '.submit.new'\r
249     else\r
250       @form.item.table_name() + '.submit.edit'\r
251   \r