X-Git-Url: http://git.iain.cx/?a=blobdiff_plain;ds=sidebyside;f=lib%2Fhub.php;h=176903dbbce7cb09cd1ca60053cfc9b4371871ae;hb=refs%2Ftags%2Fuat-2016-03-29;hp=48b45ae992ff64808ef3b55691abfcd275869a61;hpb=6fdbfe32798452ec1c0fdbda57edabb892518409;p=readifood.git diff --git a/lib/hub.php b/lib/hub.php index 48b45ae..176903d 100644 --- a/lib/hub.php +++ b/lib/hub.php @@ -1,10 +1,12 @@ Added hub.
\n"; @@ -27,31 +29,48 @@ echo "No such hub!
\n"; } } - else if ($_POST['area_id']) { + else if ($_POST['show_in_area']) { + set_last_selected("area_id", $_POST['area_id']); $q = new AreaQuery; $area = $q->findOneById($_POST['area_id']); header(sprintf("Location: http%s://%s/%s/in/area/%s/%d", ($_SERVER['HTTPS']) ? "s" : "", $_SERVER['HTTP_HOST'], $module, urlencode($area->getName()), $_POST['area_id'])); exit; } - else if ($_POST['city_id']) { + else if ($_POST['show_in_city']) { + set_last_selected("city_id", $_POST['city_id']); $q = new CityQuery; $city = $q->findOneById($_POST['city_id']); header(sprintf("Location: http%s://%s/%s/in/city/%s/%d", ($_SERVER['HTTPS']) ? "s" : "", $_SERVER['HTTP_HOST'], $module, urlencode($city->getName()), $_POST['city_id'])); exit; } + function show_hub_summary(&$hub, $editing = false) { + if ($editing) echo "Hub: " . htmlspecialchars($hub->getName()) . "";
+ else echo "
\nHub " . $hub->getStrongLink();
+ $role = $hub->getRole();
+ $role_string = get_hub_role_string($hub);
+ if ($role_string) echo " $role_string";
+ $d = urlencode($hub->getName());
+ $i = $hub->getId();
+ if ($role & $GLOBALS['ROLE_COLLECTION']) {
+ printf(" Donations", $d, $i);
+ echo " " . get_small_link("Record", "/donation/record/to/hub/%s/%d", $d, $i);
+ }
+ if ($role & $GLOBALS['ROLE_DISTRIBUTION']) printf(" Orders", $d, $i);
+ if (check_admin(1)) {
+ echo " " . $hub->getDeleteLink();
+ }
+ $area = get_hub_area($hub);
+ if ($area) echo " in " . $area->getLink();
+ $city = get_hub_city($hub);
+ if ($city) echo ", " . $city->getLink(get_city_displayname($city));
+ }
+
function show_hubs($offset, $per_page, $address_ids) {
$q = new HubQuery;
$hubs = $q->filterByAddressId($address_ids)->find();
if (count($hubs)) {
- foreach ($hubs as $hub) {
- echo "
\nhub " . $hub->getLink();
- if (check_admin(1)) {
- echo " " . $hub->getDeleteLink();
- }
- $area = get_hub_area($hub);
- echo " in " . $area->getLink();
- }
+ foreach ($hubs as $hub) show_hub_summary($hub);
}
else echo " none";
}
@@ -70,7 +89,7 @@
$address_ids = array();
foreach ($addresses as $address) $address_ids[] = $address->getId();
- echo "
hubs in city " . $city->getLink(get_city_displayname($city)) . ":"; + echo "
Hubs in city " . $city->getLink(get_city_displayname($city)) . ":"; return show_hubs($offset, $per_page, $address_ids); } else echo "
No such city!
\n"; @@ -98,15 +117,20 @@ return; } - echo "\n"; + submit("show_in_area", "Show"); } function show_hub_cities_form($city_id = null) { @@ -118,25 +142,42 @@ return; } - echo "\n"; + submit("show_in_city", "Show"); } function show_hub_forms($city_id) { + form("noprint standout"); show_hub_areas_form($city_id); show_hub_cities_form($city_id); + end_form(); + } + + function show_hub_role_form($role) { + return show_role_form($role, $GLOBALS['hub_roles']); } function show_hub_form($hub = null, $area_id = null) { if (! $hub) $hub = new Hub; + /* Role. */ + echo "You must confirm deletion of hub " . $hub->getDisplayname() . ": " . $hub->getDeleteLink(true) . "
\n"; + } + function delete_hub($name, $id = null, &$city_id = null) { if (! check_admin(1, "delete a hub")) return; @@ -329,13 +399,8 @@ else $hub = get_hub_by_name($name); if (! $hub) return; - echo "\n"; + end_form(); } /* /hub/in/area/Cambridge/1 */ @@ -376,8 +441,6 @@ show_city_hubs(0, 10, $parameters[2], $city_id); break; } - - show_new_hub_form($city_id); } } list($name, $id, $args) = parse_parameters($parameters); @@ -385,19 +448,17 @@ if (count($args)) { switch ($args[0]) { case "delete": + confirm_delete_hub($name, $id); + break; + + case "confirmdelete": delete_hub($name, $id); break; } } else if (isset($name)) show_hub($name, $id); - else { - /* XXX: Shown after adding. */ - show_hub_forms($city_id); - show_add_new_hub_form($city_id); - } - if (count($parameters)) { - show_hub_forms($city_id); - } + show_hub_forms($city_id); + show_add_new_hub_form($city_id); ?>