travelynx/templates/layouts/default.html.ep

162 lines
5.8 KiB
Text
Raw Normal View History

2018-09-02 19:41:33 +00:00
<!DOCTYPE html>
<html lang="de">
<head>
<title><%= stash('title') // 'travelynx' %></title>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
2019-05-03 19:13:22 +00:00
<meta name="description" content="Checkin-Service und Verspätungslog für Bahnfahrten">
2018-10-07 09:46:08 +00:00
<meta name="theme-color" content="#673ab7">
2019-05-11 09:52:47 +00:00
<meta name="apple-mobile-web-app-title" content="Travelynx">
% while (my ($key, $value) = each %{stash('twitter') // {}}) {
<meta name="twitter:<%= $key %>" content="<%= $value %>">
% }
2020-09-21 18:31:08 +00:00
% while (my ($key, $value) = each %{stash('opengraph') // {}}) {
<meta property="og:<%= $key %>" content="<%= $value %>">
% }
2024-07-28 14:25:49 +00:00
% my $av = 'v79'; # asset version
2019-05-11 09:52:47 +00:00
<link rel="icon" type="image/png" href="/static/<%= $av %>/icons/icon-16x16.png" sizes="16x16">
<link rel="icon" type="image/png" href="/static/<%= $av %>/icons/icon-32x32.png" sizes="32x32">
<link rel="icon" type="image/png" href="/static/<%= $av %>/icons/icon-96x96.png" sizes="96x96">
<link rel="apple-touch-icon" href="/static/<%= $av %>/icons/touch-icon-120x120.png">
<link rel="apple-touch-icon" sizes="180x180" href="/static/<%= $av %>/icons/touch-icon-180x180.png">
<link rel="apple-touch-icon" sizes="152x152" href="/static/<%= $av %>/icons/touch-icon-152x152.png">
<link rel="apple-touch-icon" sizes="167x167" href="/static/<%= $av %>/icons/touch-icon-167x167.png">
<link rel="manifest" href="/static/<%= $av %>/manifest.json">
2019-05-18 06:23:59 +00:00
% if (session('theme') and session('theme') eq 'dark') {
%= stylesheet "/static/${av}/css/dark.min.css", id => 'theme'
% }
% else {
%= stylesheet "/static/${av}/css/light.min.css", id => 'theme'
% }
<script>
2019-05-18 06:23:59 +00:00
function addStyleSheet(name, id) {
var path = '/static/<%=$av%>/css/' + name + '.min.css';
var old = document.getElementById(id);
if (old && (old.href != path)) {
old.href = path;
document.cookie = 'theme=' + name;
}
}
2019-05-16 14:10:53 +00:00
var otherTheme = {
2019-05-18 06:23:59 +00:00
'dark': 'light',
'light': 'dark',
};
var currentTheme = localStorage.getItem('theme');
if (!otherTheme.hasOwnProperty(currentTheme)) {
currentTheme = window.matchMedia('(prefers-color-scheme: dark)').matches ? 'dark' : 'light';
}
addStyleSheet(currentTheme, 'theme');
</script>
2019-03-07 17:36:11 +00:00
%= stylesheet "/static/${av}/css/material-icons.css"
% if (stash('with_map')) {
%= stylesheet "/static/${av}/leaflet/leaflet.css"
% }
2019-05-04 06:30:05 +00:00
%= javascript "/static/${av}/js/jquery-3.4.1.min.js"
2019-03-07 17:36:11 +00:00
%= javascript "/static/${av}/js/materialize.min.js"
% my $min = ".min";
% if (app->mode eq 'development') {
% $min = q{};
% }
%= javascript "/static/${av}/js/travelynx-actions${min}.js"
2018-10-07 09:35:47 +00:00
% if (stash('with_geolocation')) {
%= javascript "/static/${av}/js/geolocation${min}.js"
2018-10-07 09:35:47 +00:00
% }
% if (stash('with_autocomplete')) {
Multi-backend support Squashed commit of the following: commit 92518024ba295456358618c0e8180bd8e996fdf1 Author: Birte Kristina Friesel <birte.friesel@uos.de> Date: Fri Jul 26 18:39:46 2024 +0200 add_or_update station: remove superfluos 'new backend id := old backend id' commit df21c20c6e4c86454f8a9ac69121404415217f2a Author: Birte Kristina Friesel <birte.friesel@uos.de> Date: Fri Jul 26 18:35:51 2024 +0200 revert connection targets min_count to 3 commit be335cef07d0b42874f5fc1de4a1d13396e8e807 Author: Birte Kristina Friesel <birte.friesel@uos.de> Date: Fri Jul 26 18:20:05 2024 +0200 mention backend selection in API documentation commit 9f41828fb4f18fd707e0087def3032e8d4c8d7d8 Author: Birte Kristina Friesel <derf@finalrewind.org> Date: Thu Jul 25 20:19:23 2024 +0200 use_history: not all backends provide route data in departure monitor commit 09714b4d89684b8331d0e96f564a4c7432318f70 Author: Birte Kristina Friesel <derf@finalrewind.org> Date: Thu Jul 25 20:11:44 2024 +0200 disambiguation: pass correct hafas parameter commit 8cdf1120fc32155dc6525be64601b7c10a9c7f52 Author: Birte Kristina Friesel <derf@finalrewind.org> Date: Thu Jul 25 20:11:28 2024 +0200 _checked_in: hide Zuglauf link for non-db checkins commit 7455653f541198e0e0a6d11aed421487ffdb6285 Author: Birte Kristina Friesel <derf@finalrewind.org> Date: Thu Jul 25 20:01:47 2024 +0200 debug output commit b9cda07f85601a58ea32dbdacdd5399f302db52b Author: Birte Kristina Friesel <derf@finalrewind.org> Date: Thu Jul 25 19:09:07 2024 +0200 fix remaining get_connection_targets / get_connecting_trains_p invocations commit 2759d7258c37c7498905cfe19f6b4c4f6d16bd21 Author: Birte Kristina Friesel <derf@finalrewind.org> Date: Wed Jul 24 20:50:12 2024 +0200 support non-DB HAFAS backends (WiP)
2024-07-26 16:55:58 +00:00
%= javascript "/dyn/${av}/autocomplete.js?backend_id=" . (stash('backend_id') // 1), defer => undef
% }
% if (stash('with_map')) {
%= javascript "/static/${av}/leaflet/leaflet.js"
% }
2018-09-02 19:41:33 +00:00
</head>
% my $acc = is_user_authenticated() && current_user();
2018-09-02 19:41:33 +00:00
<body>
<div class="navbar-fixed">
<nav class="deep-purple">
<div class="nav-wrapper container">
<a href="/" class="brand-logo left"><span class="ca">tr</span><span class="cb">av</span><span class="cc">e</span><span class="cd">ly</span><span class="ce">nx</span></a>
<ul id="nav-mobile" class="right">
<li class="loading">
<div class="preloader-wrapper small" style="margin-top: 0.5em; margin-bottom: -1em;">
<div class="spinner-layer spinner-blue-only">
<div class="circle-clipper left">
<div class="circle"></div>
</div><div class="gap-patch">
<div class="circle"></div>
</div><div class="circle-clipper right">
<div class="circle"></div>
</div>
2019-05-06 16:07:53 +00:00
</div>
</div>
</li>
% if ($acc) {
2020-11-21 09:53:01 +00:00
<li class="<%= navbar_class('/history') %>"><a href='/history' title="Vergangene Zugfahrten"><i class="material-icons" aria-label="Vergangene Zugfahrten">history</i></a></li>
<li class="<%= navbar_class('/account') %>"><a href="/account" title="Account"><i class="material-icons" aria-label="Account"><%= $acc->{notifications} ? 'notifications' : 'account_circle' %></i></a></li>
% }
% else {
2020-11-21 09:53:01 +00:00
<li class="<%= navbar_class('/about') %>"><a href='/about' title="Über Travelynx"><i class="material-icons" aria-label="Über Travelynx">info_outline</i></a></li>
% }
</ul>
</div>
</nav>
</div>
2018-09-02 19:41:33 +00:00
2019-04-13 16:59:46 +00:00
% if (app->mode eq 'development') {
<div class="container">
<div class="row">
<div class="col s12 caution-color white-text">
2019-04-13 16:59:46 +00:00
Development Mode Datenbank: <%= app->config->{db}->{database} %>
@ <%= app->config->{db}->{host} %>
</div>
</div>
</div>
% }
% if (app->config->{announcement}) {
<div class="container">
<div class="row">
<div class="col s12 caution-color white-text">
%= app->config->{announcement}
</div>
</div>
</div>
% }
2018-09-02 19:41:33 +00:00
<div class="container">
% if ($acc and $acc->{deletion_requested}) {
%= include '_deletion_note', timestamp => $acc->{deletion_requested}
2019-03-12 20:49:26 +00:00
% }
2018-09-02 19:41:33 +00:00
%= content
2023-07-07 20:26:31 +00:00
<div class="row" style="margin-top: 5em;">
<div class="col s12 center-align grey-text">
<a href="/about">travelynx</a> v<%= $version // '???' %>
<span style="margin-left: 0.5em; margin-right: 0.5em;"></span>
<a href="/impressum">Impressum</a>
<span style="margin-left: 0.5em; margin-right: 0.5em;"></span>
<a href="/impressum">Datenschutz</a>
<span style="margin-left: 0.5em; margin-right: 0.5em;"></span>
<a href="/legend">Legende</a>
</div>
</div>
<div class="row">
<div class="col s12 center-align grey-text config">
Farbschema:
<a onClick="javascript:setTheme('light')">hell</a>
·
<a onClick="javascript:setTheme('dark')">dunkel</a>
·
<a onClick="javascript:setTheme('default')">automatisch</a>
</div>
</div>
2018-09-02 19:41:33 +00:00
</div>
2019-05-03 18:43:46 +00:00
<script>
if ('serviceWorker' in navigator) {
window.addEventListener('load', () => {
2019-05-18 06:29:21 +00:00
navigator.serviceWorker.register('/service-worker.js');
2019-05-03 18:43:46 +00:00
});
}
</script>
2018-09-02 19:41:33 +00:00
</body>
</html>