put vertical space between events
[angular-mojolicious.git] / public / app / reservations / calendar.html
1 <!DOCTYPE HTML>
2 <html xmlns:ng="http://angularjs.org">
3 <head>
4 <meta charset="utf-8">
5 <!--
6 <script src="angular.js" ng:autobind></script>
7 -->
8 <script src="http://code.angularjs.org/0.9.15/angular-0.9.15.min.js"
9    ng:autobind></script>
10
11 <script>
12 Calendar.$inject = ['$xhr', '$resource','$log'];
13
14 function Calendar($xhr,$resource,$log){ 
15         $log.info('Calendar');
16         var self = this;
17         $xhr("GET"
18                 , "/reservations/get/www.google.com/calendar/ical/8tg8ecg285qshtp75813jktqa0%40group.calendar.google.com/private-b9d68b530fde2c6060979f8a05aa0865/basic.ics"
19                 , function(code, response){ 
20                         $log.log('xhr calendar', code, response);
21                         self.data = response;
22                 }
23         );
24
25         var Reservation = $resource('/data/reservations/prijava/:id');
26         this.reservation = new Reservation();
27
28         this.load_submited = function() {
29                 $xhr("GET"
30                         , "/reservations/events/submited"
31                         , function(code, response){ 
32                                 $log.log('xhr submited', code, response);
33                                 self.submited = response;
34                         }
35                 );
36         }
37         this.load_submited();
38
39         self.reservation.status = 'event';
40
41         this.select_event = function(c) {
42                 $log.info('select_event', c);
43                 self.reservation.event = c;
44                 self.reservation.status = 'changed';
45                 if (self.submited) self.reservation.slot_nr = ++self.submited[c.UID];
46         }
47
48         this.change_event = function() {
49                 self.reservation.event = null;
50                 self.reservation.status = 'event';
51                 self.load_submited();
52         }
53
54         this.save_submission = function() {
55                 if ( self.reservation && self.reservation.event ) {
56                         $log.info('submit save');
57                         self.reservation.status = 'saved';
58                         self.reservation.$save();
59                         self.load_submited();
60                 } else {
61                         $log.info('submit ignored');
62                 }
63         }
64
65
66
67 // http://groups.google.com/group/angular/browse_thread/thread/af68afb22fd2d2ab/18fc5e3216a77e53?show_docid=18fc5e3216a77e53
68 </script>
69
70 <title>Reservations</title>
71
72 <style>
73 li {
74         margin-bottom: 1em;
75 }
76 </style>
77
78 </head>
79 <body>
80
81 <div ng:controller="Calendar"> 
82
83 <h1>{{data.cal['X-WR-CALNAME']}}</h1>
84
85 <div>{{data.cal['X-WR-CALDESC'] | html}}</div>
86
87 <ul>
88 <li ng:repeat="c in data.events" ng:show="reservation.status == 'event'">
89 {{c.DTSTART}} - {{c.DTEND}}
90
91 <span ng:show="! submited[c.UID] || submited[c.UID] < c.slots">
92  <a href="" ng:click="select_event(c)">{{c.SUMMARY}}</a>
93  <em ng:show="submited[c.UID]">prijava: {{submited[c.UID]}}</em>
94  <em ng:show="c.slots">mjesta: {{c.slots}}</em>
95 </span>
96
97 <span ng:show="submited[c.UID] >= c.slots">
98  <b>{{c.SUMMARY}}</b>
99  <em>popunjena sva mjesta: {{c.slots}}</em>
100 </span>
101
102 <div>{{c.LOCATION}}</div>
103 <div ng:show="c.DESCRIPTION">
104 {{c.DESCRIPTION}}
105 </div>
106 </li>
107 </ul>
108
109 <div ng:show="reservation.error" style="background:#f88">{{reservation.error}}</div>
110
111 <form ng:show="reservation.status != 'event'">
112
113 <div ng:show="reservation.event" style="background: #ff8">
114 Vaša <b>{{reservation.status}}</b> prijava za
115 <b>{{reservation.event.SUMMARY}}</b>
116 u terminu {{reservation.event.DTSTART}} u trajanju od {{reservation.event.hours}} sata
117 <span ng:show="reservation.slot_nr">broj {{reservation.slot_nr}}</span>
118 <span ng:show="reservation.saved">je spremljena.</span>
119 <input type=button value="Potvrdi promjenu" ng:show="reservation.changed" ng:click="save_submission()">
120
121 <a href="" ng:click="change_event()">Promjeni termin</a>
122 </div>
123
124
125 ime: <input name="reservation.name" ng:required>
126 <br>
127 prezime: <input name="reservation.surname" ng:required>
128 <br>
129 e-mail: <input name="reservation.email" ng:required>
130 <br>
131 odsjek: <input name="reservation.odsjek" ng:required>
132 <br>
133 zvanje: <input name="reservation.zvanje">
134 <br>
135 područke/tema zaninimanja: <input name="reservation.porducje">
136 <br>
137 <input type=button ng:click="save_submission()" value="Prijavi me" ng:disable="$invalidWidgets.visible()">
138 </form>
139
140 <input name=debug type=checkbox>
141 <pre ng:show="debug">
142 reservation={{reservation}}
143 submited={{submited}}
144 data={{data}}
145 </pre>
146
147 </div>
148
149
150 </body>
151 </html>