move Cookbook to templates
[angular-mojolicious.git] / templates / Cookbook / 2-BasicForm.html
1 <!DOCTYPE HTML>
2 <html xmlns:ng="http://angularjs.org">
3   <head>
4     <script type="text/javascript"
5          src="http://angularjs.org/ng/js/angular-debug.js" ng:autobind></script>
6   </head>
7   <body>
8
9 <div ng:init="user = {name: 'John Smith', address:{line1: '123 Main St.', city:'Anytown', state:'AA', zip:'12345'}, contacts:[{type:'phone', value:'1(234) 555-1212'}]}">
10
11   <label>Name:</label><br/>
12   <input type="text" name="user.name" ng:required/> <br/><br/>
13
14   <label>Address:</label><br/>
15   <input type="text" name="user.address.line1" size="33" ng:required/> <br/>
16   <input type="text" name="user.address.city" size="12" ng:required/>,
17   <input type="text" name="user.address.state" size="2" ng:required ng:validate="regexp:/^\w\w$/"/>
18   <input type="text" name="user.address.zip" size="5" ng:required ng:validate="regexp:/^\d\d\d\d\d$/"/><br/><br/>
19
20   <label>Phone:</label>
21   [ <a href="" ng:click="user.contacts.$add()">add</a> ]
22   <div ng:repeat="contact in user.contacts">
23     <select name="contact.type">
24       <option>email</option>
25       <option>phone</option>
26       <option>pager</option>
27       <option>IM</option>
28     </select>
29     <input type="text" name="contact.value" ng:required/> 
30      [ <a href="" ng:click="user.contacts.$remove(contact)">X</a> ]
31   </div>
32 </div>
33
34 <hr/>
35 Debug View:
36 <pre>user={{user}}</pre>
37
38   </body>
39 </html>