Tidy up forms.
[readifood.git] / lib / donation.php
1 <?php
2
3   if (isset($_POST['show_add_donation'])) {
4     $area_id = $_POST['area_id'];
5     show_new_donation_form($area_id);
6   }
7   else if (isset($_POST['add_donation'])) {
8     $id = add_donation();
9     if ($id !== false) {
10       echo "<p>Donation recorded.</p>\n";
11       $parameters = array("id", $id);
12     }
13   }
14   else if (isset($_POST['update_donation'])) {
15     list($ignored, $id, $args) = parse_parameters($parameters);
16     $q = new DonationQuery;
17     $donation = $q->findOneById($id);
18     if ($donation) {
19       if (update_donation($donation) !== false) {
20         echo "<p>Updated donation.</p>\n";
21         $parameters = array("id", $donation->getId());
22       }
23     }
24     else {
25       echo "<p>No such contact!</p>\n";
26     }
27   }
28   else if ($_POST['area_id']) {
29     $q = new AreaQuery;
30     $area = $q->findOneById($_POST['area_id']);
31     /* XXX: Function to build URL because we need to set a class in links. */
32     header(sprintf("Location: http%s://%s/%s/in/area/%s/%d", ($_SERVER['HTTPS']) ? "s" : "", $_SERVER['HTTP_HOST'], $module, urlencode($area->getName()), $_POST['area_id']));
33     exit;
34   }
35   else if ($_POST['city_id']) {
36     $q = new CityQuery;
37     $city = $q->findOneById($_POST['city_id']);
38     header(sprintf("Location: http%s://%s/%s/in/city/%s/%d", ($_SERVER['HTTPS']) ? "s" : "", $_SERVER['HTTP_HOST'], $module, urlencode($city->getName()), $_POST['city_id']));
39     exit;
40   }
41
42   function show_donations($offset, $per_page, $contact_ids = null, $hub_ids = null) {
43     $q = new DonationQuery;
44     if (isset($contact_ids)) $q->filterByContactId($contact_ids);
45     if (isset($hub_ids)) $q->filterByHubId($hub_ids);
46     $donations = $q->find();
47     if (count($donations)) {
48       foreach ($donations as $donation) {
49         echo "<br>\nDonation " . $donation->getStrongLink($donation->getId()) . ": " . get_donation_displayname($donation);
50
51         /* XXX: Should pull from query. */
52         $q = new ContactQuery;
53         $contact = $q->findOneById($donation->getContactId());
54         if ($contact) echo " from " . $contact->getLink();
55
56         $q = new HubQuery;
57         $hub = $q->findOneById($donation->getHubId());
58         if ($hub) {
59           echo " to " . $hub->getLink();
60           $area = get_hub_area($hub);
61           if ($area) {
62             echo " in " . $area->getLink();
63             $city = get_area_city($area);
64             if ($city) echo ", " . $city->getLink(get_city_displayname($city));
65           }
66         }
67         if (check_admin(1)) {
68           echo " " . $donation->getDeleteLink();
69         }
70       }
71     }
72     else echo " none";
73   }
74
75   function show_city_donations($offset, $per_page, $city_name, $city_id = null) {
76     if (isset($city_id)) $city = get_city_by_id($city_id);
77     else if ($city_name) $city = get_city_by_name($city_name);
78     if ($city) {
79       $hubs = get_city_hubs($city->getId());
80       $hub_ids = array();
81       foreach ($hubs as $hub) $hub_ids[] = $hub->getId();
82
83       echo "<p>Donations in city " . $city->getLink(get_city_displayname($city)) . ":";
84       return show_donations($offset, $per_page, null, $hub_ids);
85     }
86     else echo "<p>No such city!</p>\n";
87   }
88
89   function show_contact_donations($offset, $per_page, $contact_name, $contact_id = null) {
90     if (isset($contact_id)) $contact = get_contact_by_id($contact_id);
91     else if ($contact_name) $contact = get_contact_by_name($contact_name);
92     if ($contact) {
93       echo "<p>Donations from contact " . $contact->getLink() . ":";
94       return show_donations($offset, $per_page, $contact->getId());
95     }
96     else echo "<p>No such contact!</p>\n";
97   }
98
99   function show_hub_donations($offset, $per_page, $hub_name, $hub_id = null) {
100     if (isset($hub_id)) $hub = get_hub_by_id($hub_id);
101     else if ($hub_name) $hub = get_hub_by_name($hub_name);
102     if ($hub) {
103       echo "<p>Donations to hub " . $hub->getLink() . ":";
104       return show_donations($offset, $per_page, null, $hub->getId());
105     }
106     else echo "<p>No such hub!</p>\n";
107   }
108
109   function show_area_donations($offset, $per_page, $area_name, $area_id = null) {
110     if (isset($area_id)) $area = get_area_by_id($area_id);
111     else if ($area_name) $area = get_area_by_name($area_name);
112     if ($area) {
113       $hubs = get_area_hubs($area->getId());
114       $hub_ids = array();
115       foreach ($hubs as $hub) $hub_ids[] = $hub->getId();
116
117       echo "<p>Donations in area " . $area->getLink() . ":";
118       return show_donations($offset, $per_page, null, $hub_ids);
119     }
120     else echo "<p>No such area!</p>\n";
121   }
122
123   function show_donation_areas_form($city_id = null) {
124     $areas = get_city_areas($city_id);
125     if (! count($areas)) {
126       echo "<p>No <a href=\"/area\">areas</a>!</p>\n";
127       return;
128     }
129
130     echo "<p>Show donations in area\n";
131     echo "<select name=\"area_id\">\n";
132     foreach ($areas as $area) {
133       option("area_id", $area->getId(), get_area_displayname($area));
134     }
135     echo "</select>\n";
136     echo "<input type=\"submit\" value=\"Show\">\n";
137   }
138
139   function show_donation_cities_form($city_id = null) {
140     $q = new CityQuery;
141     $cities = $q->orderByName()->find();
142
143     if (! count($cities)) {
144       echo "<p>No <a href=\"/city\">cities</a>!</p>\n";
145       return;
146     }
147
148     echo "<p>Show donations in city\n";
149     echo "<select name=\"city_id\">\n";
150     foreach ($cities as $city) {
151       option("city_id", $city->getId(), get_city_displayname($city), $city_id);
152     }
153     echo "</select>\n";
154     echo "<input type=\"submit\" value=\"Show\">\n";
155   }
156
157   function show_donation_forms($city_id) {
158     form("noprint standout");
159     show_donation_areas_form($city_id);
160     show_donation_cities_form($city_id);
161     end_form();
162   }
163
164   function show_donation_form($donation = null, $area_id = null) {
165     if (! $donation) $donation = new Donation;
166
167     /* Date. */
168     echo "<tr>\n";
169     echo "  <td>Date</td>\n";
170     echo "  <td>"; show_date_form("date", $donation->getDate()); echo "</td>\n";
171     echo "</tr>\n";
172
173     /* Contact. */
174     echo "<tr>\n";
175     echo "  <td>Donor</td>\n";
176     echo "  <td><select name=\"contact_id\">\n";
177     $contacts = get_area_donors();
178     foreach ($contacts as $contact) {
179       option("contact_id", $contact->getId(), $contact->getDisplayname(), $donation->getContactId());
180     }
181     echo "</select></td>\n";
182     echo "</tr>\n";
183
184     /* Hub. */
185     echo "<tr>\n";
186     echo "  <td>Hub</td>\n";
187     echo "  <td><select name=\"hub_id\">\n";
188     $hubs = get_area_hubs();
189     foreach ($hubs as $hub) {
190       option("hub_id", $hub->getId(), $hub->getDisplayname(), $donation->getHubId());
191     }
192     echo "</select></td>\n";
193     echo "</tr>\n";
194
195     /* Quantity. */
196     echo "<tr>\n";
197     echo "  <td>Quantity (kg)</td>\n";
198     echo "  <td>"; input("quantity", sprintf("%0.2f", $donation->getQuantity() / 1000)); echo "</td>\n";
199     echo "</tr>\n";
200   }
201
202   function show_new_donation_form($area_id = null) {
203     if (! check_admin(1)) return;
204
205     $area = get_area_by_id($area_id);
206     if (! count($area)) {
207       echo "<p>No such <a href=\"/area\">area</a>!</p>\n";
208       return;
209     }
210
211     form();
212     echo "<p>Record a donation:</p>\n";
213
214     echo "<table>\n";
215     show_donation_form(null, $area_id);
216
217     echo "<tr>\n";
218     echo "  <td colspan=2>"; submit("add_donation", "Record"); echo "</td></tr>\n";
219     echo "</tr>\n";
220     echo "</table>\n";
221     end_form();
222   }
223
224   function show_add_new_donation_form() {
225     if (! check_admin(1)) return;
226
227     /* We intentionally hide areas with no hubs. */
228     $areas = get_city_areas_with_hubs();
229     if (! count($areas)) {
230       echo "<p>Can't record any donations until at least one <a href=\"/area\">area</a> has a <a href=\"/hub\">hub</a>!</p>\n";
231       return;
232     }
233
234     form("noprint standout");
235     echo "<p>Record a donation in <select name=\"area_id\">\n";
236     foreach ($areas as $area) {
237       option("area_id", $area->getId(), get_area_displayname($area));
238     }
239     echo "</select>";
240     submit("show_add_donation", "Proceed");
241     echo "</p>\n";
242     end_form();
243   }
244
245   function update_donation(&$donation, $new = false) {
246     #$date = ymd_to_iso8601("date");
247     $date = $_POST['date'];
248     $contact_id = $_POST['contact_id'];
249     $hub_id = $_POST['hub_id'];
250     $quantity = $_POST['quantity'];
251
252     if (! $date) $date = time();
253     /* XXX: check date */
254
255     $contact = get_contact_by_id($contact_id);
256     if (! $contact) {
257       echo "<p>Invalid contact!</p>\n";
258       return false;
259     }
260
261     $hub = get_hub_by_id($hub_id);
262     if (! $hub) {
263       echo "<p>Invalid hub!</p>\n";
264       return false;
265     }
266
267     if (! is_numeric($quantity)) {
268       echo "<p>Invalid quantity!</p>\n";
269       return false;
270     }
271
272     $donation->setDate($date);
273     $donation->setContactId($contact_id);
274     $donation->setHubId($hub_id);
275     $donation->setQuantity($quantity * 1000);
276
277     try {
278       $donation->save();
279     }
280     catch (Exception $e) {
281       if ($new) echo "<p>Error recording donation.</p>\n";
282       else echo "<p>Error updating donation.</p>\n";
283       return false;
284     }
285
286     return true;
287   }
288
289   function add_donation() {
290     if (! check_admin(1, "record a donation")) return;
291
292     $donation = new Donation;
293     if (! update_donation($donation, true)) return false;
294     return $donation->getId();
295   }
296
297   function delete_donation($id = null) {
298     if (! check_admin(1, "delete a donation")) return;
299
300     if (isset($id)) $donation = get_donation_by_id($id);
301     if (! $donation) return false;
302
303     try {
304       $donation->delete();
305       echo "<p>Deleted donation.</p>\n";
306     }
307     catch (Exception $e) {
308       echo "<p>Error deleting donation $id!</p>\n";
309       return false;
310     }
311
312     return true;
313   }
314
315   function show_donation(&$id = null) {
316     if (isset($id)) $donation = get_donation_by_id($id);
317     if (! $donation) return;
318
319     form();
320     echo "<p>Donation <span class=\"strong\">" . $donation->getId() . "</span>";
321     if (check_admin(1)) {
322       echo " " . $donation->getDeleteLink();
323     }
324     echo ": ";
325     echo "\n</p>";
326
327     echo "<table>\n";
328     show_donation_form($donation);
329
330     if (check_admin(1)) {
331       echo "<tr>\n";
332       echo "  <td colspan=2>";
333       submit("update_donation", "Update");
334       echo "</td>\n";
335       echo "</tr>\n";
336     }
337
338     echo "</table>\n";
339     end_form();
340   }
341
342   if (count($parameters)) {
343     if ($parameters[0] == "in") {
344       /* /donation/in/area/Romsey+Town/1 */
345       switch ($parameters[1]) {
346         case "area":
347           $area_id = $parameters[3];
348           $_POST['area_id'] = $area_id;
349           $q = new AreaQuery;
350           $area = $q->findOneById($area_id);
351           $city = get_area_city($area);
352           if ($city) $city_id = $city->getId();
353           show_area_donations(0, 10, $parameters[2], $area_id);
354         break;
355
356         case "city":
357           $city_id = $parameters[3];
358           $_POST['city_id'] = $city_id;
359           $q = new CityQuery;
360           $city = $q->findOneById($city_id);
361           show_city_donations(0, 10, $parameters[2], $city_id);
362         break;
363       }
364     }
365     else if ($parameters[0] == "from") {
366       /* /donation/from/contact/Iain+Patterson/4 */
367       switch ($parameters[1]) {
368         case "contact":
369           $contact_id = $parameters[3];
370           $q = new ContactQuery;
371           $contact = $q->findOneById($contact_id);
372           show_contact_donations(0, 10, $parameters[2], $contact_id);
373         break;
374       }
375     }
376     else if ($parameters[0] == "to") {
377       /* /donation/to/hub/Cambridge+Community+Church/1 */
378       switch ($parameters[1]) {
379         case "hub":
380           $hub_id = $parameters[3];
381           $q = new HubQuery;
382           $hub = $q->findOneById($hub_id);
383           show_hub_donations(0, 10, $parameters[2], $hub_id);
384         break;
385       }
386     }
387   }
388   list($ignored, $id, $args) = parse_parameters($parameters);
389   //echo "<p>$name($id) " . print_r($args, true) . "</p>\n";
390   if (count($args)) {
391     switch ($args[0]) {
392       case "delete":
393         delete_donation($id);
394       break;
395     }
396   }
397   else if (isset($id)) show_donation($id);
398
399   show_donation_forms($city_id);
400   show_add_new_donation_form($city_id);
401
402 ?>