Skip to content

Commit

Permalink
Merge pull request #44 from TheEnbyperor/main
Browse files Browse the repository at this point in the history
Show Transport for EMF stops, departure boards, and vehicle locations
  • Loading branch information
russss authored May 30, 2024
2 parents 5e2c962 + 89462d2 commit bc6593d
Show file tree
Hide file tree
Showing 6 changed files with 525 additions and 95 deletions.
1 change: 1 addition & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -3,3 +3,4 @@ tegola-cache/
web-assets/
.vscode
*.code-workspace
.idea/
29 changes: 29 additions & 0 deletions web/public/icons/haltestelle.svg
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
103 changes: 8 additions & 95 deletions web/src/icons/bus.svg
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
4 changes: 4 additions & 0 deletions web/src/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@ import ContextMenu from './contextmenu'
import VillagesEditor from './villages'
import { roundPosition, fetchWithTimeout } from './util'
import InstallControl from './installcontrol'
import TransitInfo from './transit'
import ExportControl from './export/export'
import { manifest } from 'virtual:render-svg'

Expand Down Expand Up @@ -90,6 +91,7 @@ class EventMap {
layer_switcher?: LayerSwitcher
url_hash?: URLHash
marker?: Marker
transit_info?: TransitInfo

init() {
registerSW({ immediate: true })
Expand Down Expand Up @@ -179,6 +181,8 @@ class EventMap {
this.map.on('styledata', () => {
updateVehicles(this.map!)
})

this.transit_info = new TransitInfo(this.map);
}
}

Expand Down
116 changes: 116 additions & 0 deletions web/src/transit.css
Original file line number Diff line number Diff line change
@@ -0,0 +1,116 @@
.marker-stop {
font-family: "Raleway", sans-serif;
font-size: 12px;

display: flex;
flex-direction: column;
align-items: center;

-webkit-text-stroke: 5px rgb(242, 243, 240);
color: #000;
paint-order: stroke fill;
}

.marker-stop::before {
content: "";
display: block;
background-color: #f0c900;
background-image: url("/icons/haltestelle.svg");
background-size: cover;
width: 25px;
height: 25px;
border-radius: 50%;
}

.marker-vehicle {
display: block;
width: 50px;
height: 25px;
background-image: url("/icons/bus.svg");
background-repeat: no-repeat;
background-position: 50% 50%;
background-size: contain
}

.popup-vehicle .vehicle-name {
font-weight: bold;
font-size: 1.3em;
}

.popup-vehicle .vehicle-plate {
background: #ffd307;
font-family: monospace;
font-size: 1em;
padding: 2px 5px;
border-radius: 5px;
font-weight: bold;
margin: 7px auto;
width: fit-content;
}

.popup-vehicle .vehicle-stop {
font-size: 1.2em;
}

.popup-vehicle .vehicle-route span {
border-radius: 7px;
padding: 2px 5px;
}

.departure-board {
display: grid;
grid-template-columns: auto 1fr auto;
}

.departure-board .board-line {
display: grid;
grid-template-columns: subgrid;
grid-column: 1 / 4;
grid-gap: 2px 10px;
border-bottom: 1px solid #eee;
padding-bottom: 3px;
margin-bottom: 3px;
}

.departure-board .board-line:last-of-type {
border-bottom: none;
margin-bottom: 0;
padding-bottom: 0;
}

.departure-board .time {
grid-column: 1;
font-weight: bold;
font-size: 1.3em;
}

.departure-board .time.on-time {
color: #528329;
}

.departure-board .time.slightly-late {
color: #F9E200;
}

.departure-board .time.late {
color: #F77F02;
}

.departure-board .time.cancelled {
color: red;
text-decoration: line-through;
}

.departure-board .destination {
grid-column: 2;
font-size: 1.2em;
}

.departure-board .platform {
grid-column: 3;
font-size: 1.5em;
}

.departure-board .operator, .departure-board .note {
grid-column: 1 / 4;
}
Loading

0 comments on commit bc6593d

Please sign in to comment.