diff options
| -rwxr-xr-x | index.pl | 32 | ||||
| -rw-r--r-- | public/static/js/geolocation.js | 55 | ||||
| -rw-r--r-- | templates/landingpage.html.ep | 4 | ||||
| -rw-r--r-- | templates/layouts/default.html.ep | 3 | 
4 files changed, 93 insertions, 1 deletions
| @@ -577,7 +577,7 @@ helper 'navbar_class' => sub {  get '/' => sub {  	my ($self) = @_; -	$self->render('landingpage'); +	$self->render( 'landingpage', with_geolocation => 1 );  };  post '/action' => sub { @@ -640,6 +640,36 @@ post '/action' => sub {  	}  }; +post '/x/geolocation' => sub { +	my ($self) = @_; + +	my $lon = $self->param('lon'); +	my $lat = $self->param('lat'); + +	if ( not $lon or not $lat ) { +		$self->render( json => { error => 'Invalid lon/lat received' } ); +	} +	else { +		my @candidates = map { +			{ +				ds100    => $_->[0][0], +				name     => $_->[0][1], +				eva      => $_->[0][2], +				lon      => $_->[0][3], +				lat      => $_->[0][4], +				distance => $_->[1], +			} +		} Travel::Status::DE::IRIS::Stations::get_station_by_location( $lon, +			$lat, 5 ); +		$self->render( +			json => { +				candidates => [@candidates], +			} +		); +	} + +}; +  get '/*station' => sub {  	my ($self) = @_;  	my $station = $self->stash('station'); diff --git a/public/static/js/geolocation.js b/public/static/js/geolocation.js new file mode 100644 index 0000000..1c881e2 --- /dev/null +++ b/public/static/js/geolocation.js @@ -0,0 +1,55 @@ +$(document).ready(function() { +	var prePlaceholder = $('p.geolocationhint'); +	var placeholder = $('div.geolocation div.progress'); +	var showError = function(header, message, code) { +		prePlaceholder.remove(); +		placeholder.remove(); +	}; + +	var processResult = function(data) { +		if (data.error) { +			showError('Backend-Fehler:', data.error, null); +		} else if (data.candidates.length == 0) { +			showError('Keine Bahnhöfe in 70km Umkreis gefunden', '', null); +		} else { +			resultTable = $('<table><tbody></tbody></table>') +			resultBody = resultTable.children(); +			$.each(data.candidates, function(i, candidate) { + +				var ds100 = candidate.ds100, +					name = candidate.name, +					distance = candidate.distance; +				distance = distance.toFixed(1); + +				var stationlink = $(document.createElement('a')); +				stationlink.attr('href', ds100); +				stationlink.text(name); + +				resultBody.append('<tr><td><a href="/' + ds100 + '">' + name + '</a></td></tr>'); +			}); +			placeholder.replaceWith(resultTable); +		} +	}; + +	var processLocation = function(loc) { +		$.post('/x/geolocation', {lon: loc.coords.longitude, lat: loc.coords.latitude}, processResult); +	}; + +	var processError = function(error) { +		if (error.code == error.PERMISSION_DENIED) { +			showError('Standortanfrage nicht möglich.', 'Vermutlich fehlen die Rechte im Browser oder der Android Location Service ist deaktiviert.', 'geolocation.error.PERMISSION_DENIED'); +		} else if (error.code == error.POSITION_UNAVAILABLE) { +			showError('Standort konnte nicht ermittelt werden', '(Service nicht verfügbar)', 'geolocation.error.POSITION_UNAVAILABLE'); +		} else if (error.code == error.TIMEOUT) { +			showError('Standort konnte nicht ermittelt werden', '(Timeout)', 'geolocation.error.TIMEOUT'); +		} else { +			showError('Standort konnte nicht ermittelt werden', '(unbekannter Fehler)', 'unknown geolocation.error code'); +		} +	}; + +	if (navigator.geolocation) { +		navigator.geolocation.getCurrentPosition(processLocation, processError); +	} else { +		showError('Standortanfragen werden von diesem Browser nicht unterstützt', '', null); +	} +}); diff --git a/templates/landingpage.html.ep b/templates/landingpage.html.ep index e25cd22..c7a28bd 100644 --- a/templates/landingpage.html.ep +++ b/templates/landingpage.html.ep @@ -25,6 +25,10 @@  				<div class="card-content white-text">  					<span class="card-title">Hallo, <%= $self->get_user_name %>!</span>  					<p>Du bist gerade nicht eingecheckt.</p> +					<p class="geolocationhint">Stationen in der Umgebung:</p> +					<div class="geolocation"> +						<div class="progress"><div class="indeterminate"></div></div> +					</div>  				</div>  			</div>  		% } diff --git a/templates/layouts/default.html.ep b/templates/layouts/default.html.ep index c3ddac7..b5714c6 100644 --- a/templates/layouts/default.html.ep +++ b/templates/layouts/default.html.ep @@ -10,6 +10,9 @@  	%= javascript '/static/js/jquery-2.2.4.min.js'  	%= javascript '/static/js/materialize.min.js'  	%= javascript '/static/js/travelynx-actions.js' +	% if (stash('with_geolocation')) { +		%= javascript '/static/js/geolocation.js' +	% }  </head>  <body> | 
