2019-03-07 17:36:11 +00:00
|
|
|
% if (is_user_authenticated()) {
|
2022-08-04 12:07:25 +00:00
|
|
|
% my $status = stash('user_status');
|
2019-03-16 20:49:47 +00:00
|
|
|
% if (stash('error')) {
|
|
|
|
<div class="row">
|
|
|
|
<div class="col s12">
|
2019-05-16 13:02:17 +00:00
|
|
|
<div class="card caution-color">
|
2019-03-16 20:49:47 +00:00
|
|
|
<div class="card-content white-text">
|
|
|
|
<span class="card-title">Backend-Fehler</span>
|
|
|
|
<p><%= stash('error') %></p>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
% }
|
2019-03-07 17:36:11 +00:00
|
|
|
<div class="row">
|
2019-04-23 20:27:13 +00:00
|
|
|
<div class="col s12 statuscol">
|
2019-03-07 17:36:11 +00:00
|
|
|
% if ($status->{checked_in}) {
|
2023-02-27 21:14:54 +00:00
|
|
|
%= include '_checked_in', journey => $status, journey_visibility => stash('journey_visibility');
|
2019-03-07 17:36:11 +00:00
|
|
|
% }
|
2019-03-19 17:20:05 +00:00
|
|
|
% elsif ($status->{cancelled}) {
|
2023-07-15 17:20:37 +00:00
|
|
|
% if ( @{stash('timeline') // [] } ) {
|
|
|
|
%= include '_timeline_link', timeline => stash('timeline')
|
|
|
|
% }
|
2019-05-16 13:02:17 +00:00
|
|
|
<div class="card info-color">
|
2019-03-19 17:20:05 +00:00
|
|
|
<div class="card-content">
|
2023-08-14 10:24:26 +00:00
|
|
|
<span class="card-title">Ausfall dokumentieren</span>
|
2019-03-19 17:20:05 +00:00
|
|
|
<p>Prinzipiell wärest du nun eingecheckt in
|
|
|
|
<%= $status->{train_type} %> <%= $status->{train_no} %>
|
2023-08-14 10:24:26 +00:00
|
|
|
ab <%= $status->{dep_name} %>, doch diese Fahrt fällt aus.
|
2019-03-19 17:20:05 +00:00
|
|
|
</p>
|
2023-08-14 10:24:26 +00:00
|
|
|
<p>Falls du den Ausfall z.B. für Fahrgastrechte
|
|
|
|
dokumentieren möchtest, wähle bitte jetzt das
|
|
|
|
vorgesehene Ziel aus.</p>
|
2019-03-19 17:20:05 +00:00
|
|
|
<table>
|
|
|
|
<tbody>
|
|
|
|
% my $is_after = 0;
|
|
|
|
% for my $station (@{$status->{route_after}}) {
|
2019-05-26 15:28:21 +00:00
|
|
|
<tr><td><a class="action-cancelled-to" data-station="<%= $station->[0] %>"><%= $station->[0] %></a></td></tr>
|
2019-03-19 17:20:05 +00:00
|
|
|
% }
|
|
|
|
</tbody>
|
|
|
|
</table>
|
|
|
|
</div>
|
2019-04-23 16:08:07 +00:00
|
|
|
<div class="card-action">
|
|
|
|
<a class="action-undo" data-id="in_transit">
|
|
|
|
<i class="material-icons">undo</i> Checkinversuch Rückgängig?
|
|
|
|
</a>
|
|
|
|
</div>
|
2019-03-19 17:20:05 +00:00
|
|
|
</div>
|
|
|
|
% }
|
2019-03-07 17:36:11 +00:00
|
|
|
% else {
|
2023-07-15 17:20:37 +00:00
|
|
|
% if ( @{stash('timeline') // [] } ) {
|
|
|
|
%= include '_timeline_link', timeline => stash('timeline')
|
|
|
|
% }
|
2019-05-16 13:02:17 +00:00
|
|
|
<div class="card">
|
|
|
|
<div class="card-content">
|
2020-11-21 09:35:18 +00:00
|
|
|
<span class="card-title">Hallo, <%= current_user->{name} %>!</span>
|
2019-03-07 17:36:11 +00:00
|
|
|
<p>Du bist gerade nicht eingecheckt.</p>
|
2023-01-18 17:13:35 +00:00
|
|
|
<div class="geolocation" data-recent="<%= join('|', map { $_->{eva} . ';' . $_->{name} } @{stash('recent_targets') // []} ) %>">
|
2019-05-16 13:02:17 +00:00
|
|
|
<button class="btn waves-effect waves-light btn-flat">Stationen in der Umgebung abfragen</button>
|
2019-03-07 17:36:11 +00:00
|
|
|
</div>
|
2019-03-16 20:33:19 +00:00
|
|
|
%= form_for 'list_departures' => begin
|
2019-03-16 20:49:47 +00:00
|
|
|
<div class="input-field">
|
2020-10-17 12:18:39 +00:00
|
|
|
%= text_field 'station', id => 'station', class => 'autocomplete contrast-color-text', autocomplete => 'off', required => undef
|
2019-03-16 20:33:19 +00:00
|
|
|
<label for="station">Manuelle Eingabe (Name oder DS100)</label>
|
|
|
|
</div>
|
|
|
|
<div class="center-align">
|
2019-05-16 13:02:17 +00:00
|
|
|
<button class="btn waves-effect waves-light btn-flat" type="submit" name="action" value="departures">
|
2020-01-28 19:26:15 +00:00
|
|
|
<i class="material-icons left" aria-hidden="true">send</i>
|
2019-03-16 20:33:19 +00:00
|
|
|
Abfahrten
|
|
|
|
</button>
|
|
|
|
</div>
|
|
|
|
%= end
|
2018-10-07 09:35:47 +00:00
|
|
|
</div>
|
2018-09-02 19:41:33 +00:00
|
|
|
</div>
|
2019-03-07 17:36:11 +00:00
|
|
|
% }
|
|
|
|
</div>
|
2018-09-02 19:41:33 +00:00
|
|
|
</div>
|
2019-03-07 17:36:11 +00:00
|
|
|
<h1>Letzte Fahrten</h1>
|
2020-11-21 09:35:18 +00:00
|
|
|
%= include '_history_trains', date_format => '%d.%m', journeys => [journeys->get(uid => current_user->{id}, limit => 5, with_datetime => 1)];
|
2019-03-07 17:36:11 +00:00
|
|
|
% }
|
|
|
|
% else {
|
2019-03-08 16:16:19 +00:00
|
|
|
<div class="row">
|
|
|
|
<div class="col s12">
|
|
|
|
<p>
|
|
|
|
Travelynx erlaubt das Einchecken in Züge im Netz der Deutschen
|
|
|
|
Bahn. So können die eigenen Fahrten später inklusive Echtzeitdaten
|
|
|
|
und eingetragenen Servicemeldungen nachvollzogen und brennende
|
2023-08-14 10:24:26 +00:00
|
|
|
Fragen wie „Wie viele Stunden war ich letzten Monat unterwegs?“
|
|
|
|
beantwortet werden.
|
2019-03-08 16:16:19 +00:00
|
|
|
</p>
|
|
|
|
<p>
|
|
|
|
Die Idee dazu kommt von <a
|
2019-05-11 13:45:16 +00:00
|
|
|
href="https://traewelling.de/">Träwelling</a>.
|
2019-03-16 13:36:35 +00:00
|
|
|
</p>
|
|
|
|
<p>
|
|
|
|
Features:
|
|
|
|
<ul>
|
|
|
|
<li>Protokoll von Fahrplan- und Echtzeitdaten an Start- und
|
|
|
|
Zielbahnhof</li>
|
2023-06-04 17:07:19 +00:00
|
|
|
<li>Teilen von aktuellen und vergangenen Fahrten mit anderen Personen</li>
|
2020-02-26 19:38:01 +00:00
|
|
|
<li>Web-Hooks und <a href="/api">API</a> zum automatisierten Einchecken und Auslesen des aktuellen Status</li>
|
2019-04-06 19:32:18 +00:00
|
|
|
<li>Statistiken über Reisezeiten und Verspätungen</li>
|
2019-09-16 15:20:37 +00:00
|
|
|
<li>Unterstützung beim Ausfüllen von Fahrgastrechteformularen</li>
|
2023-06-04 17:07:19 +00:00
|
|
|
<li>Optional: Öffentlicher Reisestatus und öffentliche Angaben zu vergangenen Fahrten</li>
|
2020-10-04 10:50:41 +00:00
|
|
|
<li>Optional: Verknüpfung mit Träwelling</li>
|
2019-03-16 13:36:35 +00:00
|
|
|
</ul>
|
2019-03-08 16:16:19 +00:00
|
|
|
</p>
|
|
|
|
<p>
|
|
|
|
Travelynx ist ein kostenfreies, privat betriebenes Projekt ohne
|
|
|
|
Verfügbarkeitsgarantie. Unangekündigte Downtimes oder eine
|
|
|
|
kurzfristige Einstellung dieser Seite sind nicht vorgesehen, aber
|
|
|
|
möglich. Wer mag, kann auch den
|
|
|
|
<a href="https://finalrewind.org/projects/travelynx">Quelltext</a>
|
2019-03-16 13:36:35 +00:00
|
|
|
laden und eine eigene Instanz aufsetzen.
|
2019-03-08 16:16:19 +00:00
|
|
|
</p>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div class="row">
|
|
|
|
<div class="col s1 m1 l3">
|
|
|
|
</div>
|
|
|
|
<div class="col s10 m10 l6 center-align">
|
2021-09-12 06:15:59 +00:00
|
|
|
% if (not app->config->{registration}{disabled}) {
|
|
|
|
<a href="/register" class="waves-effect waves-light btn"><i class="material-icons left" aria-hidden="true">add</i>Registrieren</a>
|
|
|
|
% }
|
2020-09-05 12:15:50 +00:00
|
|
|
<a href="/login" class="waves-effect waves-light btn"><i class="material-icons left" aria-hidden="true">account_circle</i>Anmelden</a>
|
2019-03-08 16:16:19 +00:00
|
|
|
</div>
|
|
|
|
<div class="col s1 m1 l3">
|
|
|
|
</div>
|
|
|
|
</div>
|
2019-03-07 17:36:11 +00:00
|
|
|
% }
|