{"id":1954,"date":"2016-07-06T13:05:09","date_gmt":"2016-07-06T12:05:09","guid":{"rendered":"http:\/\/www.jurecuhalev.com\/blog\/?p=1954"},"modified":"2016-07-06T13:05:09","modified_gmt":"2016-07-06T12:05:09","slug":"example-of-ember-form-for-and-mirage-server-side-validation","status":"publish","type":"post","link":"https:\/\/www.jurecuhalev.com\/blog\/example-of-ember-form-for-and-mirage-server-side-validation\/","title":{"rendered":"Example of ember-form-for and mirage server side validation"},"content":{"rendered":"<p>At the time of writing, <a href=\"https:\/\/emberobserver.com\/addons\/ember-form-for\">ember-form-for<\/a> is the\u00a0top Ember.js plugin for forms on Ember Observer.\u00a0It provides a straightforward way to display form fields without having to write all the boilerplate HTML code around it.<\/p>\n<p>What you do is you take:<\/p>\n<pre class=\"brush: xml; title: ; notranslate\" title=\"\">\r\n\r\n\r\n    &lt;label&gt;First name: {{input value=model.firstname}}&lt;\/label&gt;\r\n    {{#each model.errors.firstname as |error|}}\r\n      &lt;span class=&quot;errors&quot;&gt;{{error.message}}&lt;\/span&gt;\r\n    {{\/each}}\r\n  \r\n\r\n<\/pre>\n<p>and replace it with form-for-model helper:<\/p>\n<pre class=\"brush: xml; title: ; notranslate\" title=\"\">\r\n{{#form-for model as |f|}}\r\n  {{f.text-field &quot;firstname&quot;}}\r\n\r\n  .. \/\/ other fields and submit button\r\n{{\/form-for}}\r\n<\/pre>\n<p>It will generate HTML code for you, as well as display validation errors.<\/p>\n<p>Complete form becomes much more readable this way:<\/p>\n<pre class=\"brush: xml; title: ; notranslate\" title=\"\">\r\n{{#form-for model as |f|}}\r\n  {{f.text-field &quot;firstname&quot;}}\r\n  {{f.text-field &quot;lastname&quot;}}\r\n\r\n  {{f.select-field &quot;gender&quot; &quot;unknown male female&quot;}}\r\n  {{f.checkbox-field &quot;terms&quot; label=&quot;I agree to the Terms of Service&quot;}}\r\n\r\n  {{f.submit &quot;Submit&quot;}}\r\n{{\/form-for}}\r\n<\/pre>\n<p>I&#8217;ve created a dedicated Github branch <strong>ember-form-for<\/strong>, that you can experiment with:<br \/>\n<a href=\"https:\/\/github.com\/ember-examples\/server-side-validation-mirage\/tree\/ember-form-for\">https:\/\/github.com\/ember-examples\/server-side-validation-mirage\/tree\/ember-form-for<\/a><\/p>\n","protected":false},"excerpt":{"rendered":"<p>At the time of writing, ember-form-for is the\u00a0top Ember.js plugin for forms on Ember Observer.\u00a0It provides a straightforward way to display form fields without having to write all the boilerplate HTML code around it. What you do is you take: &lt;label&gt;First name: {{input value=model.firstname}}&lt;\/label&gt; {{#each model.errors.firstname as |error|}} &lt;span class=&quot;errors&quot;&gt;{{error.message}}&lt;\/span&gt; {{\/each}} and replace it with [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"_acf_changed":false,"_jetpack_newsletter_access":"","_jetpack_dont_email_post_to_subs":false,"_jetpack_newsletter_tier_id":0,"_jetpack_memberships_contains_paywalled_content":false,"_jetpack_feature_clip_id":0,"_jetpack_memberships_contains_paid_content":false,"footnotes":"","jetpack_post_was_ever_published":false},"categories":[925],"tags":[],"class_list":["post-1954","post","type-post","status-publish","format-standard","hentry","category-ember-js"],"acf":[],"jetpack_featured_media_url":"","jetpack_sharing_enabled":true,"_links":{"self":[{"href":"https:\/\/www.jurecuhalev.com\/blog\/wp-json\/wp\/v2\/posts\/1954","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.jurecuhalev.com\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.jurecuhalev.com\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.jurecuhalev.com\/blog\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/www.jurecuhalev.com\/blog\/wp-json\/wp\/v2\/comments?post=1954"}],"version-history":[{"count":2,"href":"https:\/\/www.jurecuhalev.com\/blog\/wp-json\/wp\/v2\/posts\/1954\/revisions"}],"predecessor-version":[{"id":1956,"href":"https:\/\/www.jurecuhalev.com\/blog\/wp-json\/wp\/v2\/posts\/1954\/revisions\/1956"}],"wp:attachment":[{"href":"https:\/\/www.jurecuhalev.com\/blog\/wp-json\/wp\/v2\/media?parent=1954"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.jurecuhalev.com\/blog\/wp-json\/wp\/v2\/categories?post=1954"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.jurecuhalev.com\/blog\/wp-json\/wp\/v2\/tags?post=1954"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}