mirror of
https://github.com/derf/travelynx
synced 2024-11-10 06:54:17 +00:00
show close stations via geolocation
This commit is contained in:
parent
d95cb9d06a
commit
6fd985ae7e
4 changed files with 93 additions and 1 deletions
32
index.pl
32
index.pl
|
@ -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');
|
||||
|
|
55
public/static/js/geolocation.js
Normal file
55
public/static/js/geolocation.js
Normal file
|
@ -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);
|
||||
}
|
||||
});
|
|
@ -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>
|
||||
% }
|
||||
|
|
|
@ -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>
|
||||
|
||||
|
|
Loading…
Reference in a new issue