diff options
Diffstat (limited to 'lib')
| -rw-r--r-- | lib/DBInfoscreen/Controller/Map.pm | 30 | ||||
| -rw-r--r-- | lib/DBInfoscreen/Helper/HAFAS.pm | 6 | 
2 files changed, 33 insertions, 3 deletions
| diff --git a/lib/DBInfoscreen/Controller/Map.pm b/lib/DBInfoscreen/Controller/Map.pm index e552a18..bced612 100644 --- a/lib/DBInfoscreen/Controller/Map.pm +++ b/lib/DBInfoscreen/Controller/Map.pm @@ -314,13 +314,26 @@ sub route {  	my ($self)  = @_;  	my $trip_id = $self->stash('tripid');  	my $line_no = $self->stash('lineno'); +	my $hafas   = $self->param('hafas');  	my $from_name = $self->param('from');  	my $to_name   = $self->param('to');  	$self->render_later; -	$self->hafas->get_polyline_p( $trip_id, $line_no )->then( +	my $service = 'DB'; +	if (    $hafas +		and $hafas ne '1' +		and Travel::Status::DE::HAFAS::get_service($hafas) ) +	{ +		$service = $hafas; +	} + +	$self->hafas->get_polyline_p( +		id      => $trip_id, +		line    => $line_no, +		service => $service +	)->then(  		sub {  			my ($journey) = @_; @@ -458,12 +471,25 @@ sub ajax_route {  	my ($self)  = @_;  	my $trip_id = $self->stash('tripid');  	my $line_no = $self->stash('lineno'); +	my $hafas   = $self->param('hafas');  	delete $self->stash->{layout};  	$self->render_later; -	$self->hafas->get_polyline_p( $trip_id, $line_no )->then( +	my $service = 'DB'; +	if (    $hafas +		and $hafas ne '1' +		and Travel::Status::DE::HAFAS::get_service($hafas) ) +	{ +		$service = $hafas; +	} + +	$self->hafas->get_polyline_p( +		id      => $trip_id, +		line    => $line_no, +		service => $service +	)->then(  		sub {  			my ($journey) = @_; diff --git a/lib/DBInfoscreen/Helper/HAFAS.pm b/lib/DBInfoscreen/Helper/HAFAS.pm index 302cb9c..148a917 100644 --- a/lib/DBInfoscreen/Helper/HAFAS.pm +++ b/lib/DBInfoscreen/Helper/HAFAS.pm @@ -161,11 +161,15 @@ sub get_route_p {  # Input: (HAFAS TripID, line number)  # Output: Promise returning a Travel::Status::DE::HAFAS::Journey instance on success  sub get_polyline_p { -	my ( $self, $trip_id, $line ) = @_; +	my ( $self, %opt ) = @_; +	my $trip_id = $opt{id}; +	my $line    = $opt{line}; +	my $service = $opt{service};  	my $promise = Mojo::Promise->new;  	Travel::Status::DE::HAFAS->new_p( +		service => $service,  		journey => {  			id   => $trip_id,  			name => $line, | 
