blob: 1ad15ab3d2a2fe1805f7e13a52973aa46a13bcf8 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
|
import { useApp } from "../AppContext";
import "../styles/Settings.css";
export function Settings() {
const { theme, setTheme, tableStyle, setTableStyle, mapPositionMode, setMapPositionMode } = useApp();
return (
<div className="about-page">
<h1 className="page-title">Sobre UrbanoVigo Web</h1>
<p className="about-description">
Aplicación web para encontrar paradas y tiempos de llegada de los autobuses
urbanos de Vigo, España.
</p>
<section className="settings-section">
<h2>Ajustes</h2>
<div className="settings-content-inline">
<label htmlFor="theme" className="form-label-inline">Modo:</label>
<select id="theme" className="form-select-inline" value={theme} onChange={(e) => setTheme(e.target.value as "light" | "dark")}>
<option value="light">Claro</option>
<option value="dark">Oscuro</option>
</select>
</div>
<div className="settings-content-inline">
<label htmlFor="tableStyle" className="form-label-inline">Estilo de tabla:</label>
<select id="tableStyle" className="form-select-inline" value={tableStyle} onChange={(e) => setTableStyle(e.target.value as "regular" | "grouped")}>
<option value="regular">Mostrar por orden</option>
<option value="grouped">Agrupar por línea</option>
</select>
</div>
<div className="settings-content-inline">
<label htmlFor="mapPositionMode" className="form-label-inline">Posición del mapa:</label>
<select id="mapPositionMode" className="form-select-inline" value={mapPositionMode} onChange={e => setMapPositionMode(e.target.value as 'gps' | 'last')}>
<option value="gps">Posición GPS</option>
<option value="last">Donde lo dejé</option>
</select>
</div>
<details className="form-details">
<summary>¿Qué significa esto?</summary>
<p>
La tabla de horarios puede mostrarse de dos formas:
</p>
<dl>
<dt>Mostrar por orden</dt>
<dd>Las paradas se muestran en el orden en que se visitan. Aplicaciones como Infobus (Vitrasa) usan este estilo.</dd>
<dt>Agrupar por línea</dt>
<dd>Las paradas se agrupan por la línea de autobús. Aplicaciones como iTranvias (A Coruña) o Moovit (más o menos) usan este estilo.</dd>
</dl>
</details>
</section>
<h2>Créditos</h2>
<p>
<a href="https://github.com/arielcostas/urbanovigo-web" className="about-link" rel="nofollow noreferrer noopener">
Código en GitHub
</a> -
Desarrollado por <a href="https://www.costas.dev" className="about-link" rel="nofollow noreferrer noopener">
Ariel Costas
</a>
</p>
<p>
Datos obtenidos de <a href="https://datos.vigo.org" className="about-link" rel="nofollow noreferrer noopener">datos.vigo.org</a> bajo
licencia <a href="https://opendefinition.org/licenses/odc-by/" className="about-link" rel="nofollow noreferrer noopener">Open Data Commons Attribution License</a>
</p>
</div>
)
}
|