--- a/stopList.php
+++ b/stopList.php
@@ -1,5 +1,9 @@
';
- foreach ($suburbs as $suburb) {
- echo '
' . $suburb . '';
+ if (!isset($_REQUEST['firstLetter'])) {
+ foreach (range('A', 'Z') as $letter) {
+ echo "$letter...\n";
+ }
+ }
+ else {
+ foreach ($suburbs as $suburb) {
+ if (startsWith($suburb, $_REQUEST['firstLetter'])) {
+ echo '' . $suburb . '';
+ flush(); @ob_flush();
+ }
+ }
}
echo '';
}
else {
// Timing Points / All stops
if ($_REQUEST['allstops']) {
+ $listType = 'allstops=yes';
$url = $APIurl . "/json/stops";
include_header("All Stops", "stopList");
navbar();
timePlaceSettings();
}
else if ($_REQUEST['nearby']) {
+ $listType = 'nearby=yes';
$url = $APIurl . "/json/neareststops?lat={$_SESSION['lat']}&lon={$_SESSION['lon']}&limit=15";
- include_header("Nearby Stops", "stopList");
+ include_header("Nearby Stops", "stopList", true, true);
navbar();
timePlaceSettings(true);
+ if (!isset($_SESSION['lat']) || !isset($_SESSION['lat']) || $_SESSION['lat'] == "" || $_SESSION['lon'] == "") {
+ include_footer();
+ die();
+ }
}
else if ($_REQUEST['suburb']) {
$suburb = filter_var($_REQUEST['suburb'], FILTER_SANITIZE_STRING);
+ $listType = "suburb=$suburb";
$url = $APIurl . "/json/stopzonesearch?q=" . $suburb;
include_header("Stops in " . ucwords($suburb) , "stopList");
- if (isMetricsOn()) {
- // Create a new Instance of the tracker
- $owa = new owa_php($config);
- // Set the ID of the site being tracked
- $owa->setSiteId($owaSiteID);
- // Create a new event object
- $event = $owa->makeEvent();
- // Set the Event Type, in this case a "video_play"
- $event->setEventType('view_stop_list_suburb');
- // Set a property
- $event->set('stop_list_suburb', $suburb);
- // Track the event
- $owa->trackEvent($event);
- }
navbar();
+ trackEvent("Stop Lists","Stops By Suburb", $suburb);
}
else {
$url = $APIurl . "/json/timingpoints";
@@ -63,39 +71,76 @@
navbar();
timePlaceSettings();
}
- echo ' Go to letter: ';
- foreach (range('A', 'Z') as $letter) {
- echo "
$letter ";
+ echo '
';
+ if (!isset($_REQUEST['firstLetter']) && !$_REQUEST['suburb'] && !$_REQUEST['nearby']) {
+ foreach (range('A', 'Z') as $letter) {
+ echo "- $letter...
\n";
+ }
}
- echo "
- ";
- echo ' ';
- $contents = json_decode(getPage($url));
- foreach ($contents as $key => $row) {
- $stopName[$key] = $row[1];
- }
- // Sort the stops by name
- array_multisort($stopName, SORT_ASC, $contents);
- $firstletter = "";
- foreach ($contents as $row) {
- if (substr($row[1], 0, 1) != $firstletter) {
- echo "";
- $firstletter = substr($row[1], 0, 1);
+ else {
+ $stops = json_decode(getPage($url));
+ foreach ($stops as $key => $row) {
+ $stopName[$key] = $row[1];
}
- echo '- ';
- if (!startsWith($row[5], "Wj")) echo '';
- echo '';
- if (isset($_SESSION['lat']) && isset($_SESSION['lon'])) {
- echo '' . floor(distance($row[2], $row[3], $_SESSION['lat'], $_SESSION['lon'])) . 'm away';
+ // Sort the stops by name
+ array_multisort($stopName, SORT_ASC, $stops);
+ if (!isset($_REQUEST['suburb']) && !isset($_REQUEST['nearby'])) {
+ $stops = array_filter($stops, "filterByFirstLetter");
}
- echo bracketsMeanNewLine($row[1]);
- echo '
';
+ $stopsGrouped = Array();
+ foreach ($stops as $key => $row) {
+ if ((trim(preg_replace("/\(Platform.*/", "", $stops[$key][1])) != trim(preg_replace("/\(Platform.*/", "", $stops[$key + 1][1]))) || $key + 1 >= sizeof($stops)) {
+ if (sizeof($stopsGrouped) > 0) {
+ // print and empty grouped stops
+ // subsequent duplicates
+ $stopsGrouped["stop_ids"][] = $row[0];
+ echo '- ';
+ if (!startsWith($stopsGrouped['stop_codes'][0], "Wj")) echo '';
+ echo '';
+ if (isset($_SESSION['lat']) && isset($_SESSION['lon'])) {
+ echo '' . distance($row[2], $row[3], $_SESSION['lat'], $_SESSION['lon'], true) . 'm away';
+ }
+ echo bracketsMeanNewLine(trim(preg_replace("/\(Platform.*/", "", $row[1])) . '(' . sizeof($stopsGrouped["stop_ids"]) . ' stops)');
+ echo "
\n";
+ flush(); @ob_flush();
+ $stopsGrouped = Array();
+ }
+ else {
+ // just a normal stop
+ echo '- ';
+ if (!startsWith($row[5], "Wj")) echo '';
+ echo '';
+ if (isset($_SESSION['lat']) && isset($_SESSION['lon'])) {
+ echo '' . distance($row[2], $row[3], $_SESSION['lat'], $_SESSION['lon'], true) . 'm away';
+ }
+ echo bracketsMeanNewLine($row[1]);
+ echo "
\n";
+ flush(); @ob_flush();
+ }
+ }
+ else {
+ // this is a duplicated line item
+ if ($key - 1 <= 0 || (trim(preg_replace("/\(Platform.*/", "", $stops[$key][1])) != trim(preg_replace("/\(Platform.*/", "", $stops[$key - 1][1])))) {
+ // first duplicate
+ $stopsGrouped = Array(
+ "name" => trim(preg_replace("/\(Platform.*/", "", $row[1])) ,
+ "stop_ids" => Array(
+ $row[0]
+ ) ,
+ "stop_codes" => Array(
+ $row[5]
+ )
+ );
+ }
+ else {
+ // subsequent duplicates
+ $stopsGrouped["stop_ids"][] = $row[0];
+ }
+ }
+ }
}
echo '
';
}
include_footer();
?>
-