diff options
author | Daniel Friesel <derf@finalrewind.org> | 2019-11-10 09:01:33 +0100 |
---|---|---|
committer | Daniel Friesel <derf@finalrewind.org> | 2019-11-10 09:01:33 +0100 |
commit | cc0dda06d89a5affbfe950a9cca226144d5cc887 (patch) | |
tree | f72dab133f81d8f36b946774d30f5e322b497aa0 /lib | |
parent | 60b691aa76a3956872ecd841f63546c83dc3ea7f (diff) |
single layout: strip non-numeric platform parts for now2.3.12
Diffstat (limited to 'lib')
-rw-r--r-- | lib/DBInfoscreen.pm | 20 | ||||
-rw-r--r-- | lib/DBInfoscreen/Controller/Stationboard.pm | 17 |
2 files changed, 33 insertions, 4 deletions
diff --git a/lib/DBInfoscreen.pm b/lib/DBInfoscreen.pm index aad1290..b062c9d 100644 --- a/lib/DBInfoscreen.pm +++ b/lib/DBInfoscreen.pm @@ -245,6 +245,26 @@ sub startup { } ); + $self->helper( + 'numeric_platform_part' => sub { + my ( $self, $platform ) = @_; + + if ( not defined $platform ) { + return 0; + } + + if ( $platform =~ m{ ^ \d+ $ }x ) { + return $platform; + } + + if ( $platform =~ m{ (\d+) }x ) { + return $1; + } + + return 0; + } + ); + my $r = $self->routes; $r->get('/_redirect')->to('static#redirect'); diff --git a/lib/DBInfoscreen/Controller/Stationboard.pm b/lib/DBInfoscreen/Controller/Stationboard.pm index 95aa08c..5acd616 100644 --- a/lib/DBInfoscreen/Controller/Stationboard.pm +++ b/lib/DBInfoscreen/Controller/Stationboard.pm @@ -519,15 +519,24 @@ sub handle_request { if ( $template eq 'single' ) { if ( not @platforms ) { for my $result (@results) { - if ( not( $result->platform ~~ \@platforms ) ) { - push( @platforms, $result->platform ); + if ( + not( $self->numeric_platform_part( $result->platform ) ~~ + \@platforms ) + ) + { + push( @platforms, + $self->numeric_platform_part( $result->platform ) ); } } @platforms = sort { $a <=> $b } @platforms; } my %pcnt; - @results = grep { $pcnt{ $_->platform }++ < 1 } @results; - @results = sort { $a->platform <=> $b->platform } @results; + @results + = grep { $pcnt{ $self->numeric_platform_part( $_->platform ) }++ < 1 } + @results; + @results = map { $_->[1] } + sort { $a->[0] <=> $b->[0] } + map { [ $self->numeric_platform_part( $_->platform ), $_ ] } @results; } if ( $backend eq 'iris' and $show_realtime ) { |