mirror of
https://github.com/Spythere/stacjownik.git
synced 2026-05-02 21:08:12 +00:00
Zmiana w działaniu filtrów
This commit is contained in:
+24
-12
@@ -10,13 +10,15 @@
|
|||||||
<span class="online">Scenerie online: {{stationCount}} | Maszyniści online: {{ trainCount }}</span>
|
<span class="online">Scenerie online: {{stationCount}} | Maszyniści online: {{ trainCount }}</span>
|
||||||
</header>
|
</header>
|
||||||
|
|
||||||
<div class="app-bar">
|
<div class="app-bar" ref="appBar">
|
||||||
<div class="bar-left">
|
<div class="bar-content">
|
||||||
<Options />
|
<div class="bar-left">
|
||||||
</div>
|
<Options />
|
||||||
|
</div>
|
||||||
|
|
||||||
<div class="bar-right">
|
<div class="bar-right">
|
||||||
<!-- <div class="last-update">Ostatnie zmiany</div> -->
|
<!-- <div class="last-update">Ostatnie zmiany</div> -->
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
@@ -70,6 +72,14 @@ export default Vue.extend({
|
|||||||
this.getStationList();
|
this.getStationList();
|
||||||
|
|
||||||
setInterval(this.getStationList, 5000);
|
setInterval(this.getStationList, 5000);
|
||||||
|
|
||||||
|
document.addEventListener("scroll", e => {
|
||||||
|
const appBarEl = this.$refs.appBar as Element;
|
||||||
|
|
||||||
|
if (appBarEl.getBoundingClientRect().top < 0)
|
||||||
|
appBarEl.classList.add("sticky");
|
||||||
|
else appBarEl.classList.remove("sticky");
|
||||||
|
});
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
</script>
|
</script>
|
||||||
@@ -83,11 +93,9 @@ html {
|
|||||||
}
|
}
|
||||||
|
|
||||||
body {
|
body {
|
||||||
|
width: 100%;
|
||||||
margin: 0;
|
margin: 0;
|
||||||
font-family: "Lato", sans-serif;
|
font-family: "Lato", sans-serif;
|
||||||
background: $bgCol;
|
|
||||||
width: 100%;
|
|
||||||
min-height: 100vh;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
button,
|
button,
|
||||||
@@ -141,7 +149,10 @@ ul {
|
|||||||
}
|
}
|
||||||
|
|
||||||
.app {
|
.app {
|
||||||
|
background: $bgCol;
|
||||||
color: white;
|
color: white;
|
||||||
|
width: 100%;
|
||||||
|
|
||||||
overflow: hidden;
|
overflow: hidden;
|
||||||
|
|
||||||
&-container {
|
&-container {
|
||||||
@@ -171,7 +182,7 @@ ul {
|
|||||||
}
|
}
|
||||||
|
|
||||||
.online {
|
.online {
|
||||||
font-size: calc(0.6rem + 0.4vw);
|
font-size: calc(0.3rem + 0.8vw);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -179,13 +190,14 @@ ul {
|
|||||||
display: flex;
|
display: flex;
|
||||||
align-items: center;
|
align-items: center;
|
||||||
justify-content: space-between;
|
justify-content: space-between;
|
||||||
|
|
||||||
font-size: calc(0.8rem + 0.2vw);
|
font-size: calc(0.8rem + 0.2vw);
|
||||||
|
|
||||||
|
position: sticky;
|
||||||
|
top: 0;
|
||||||
|
|
||||||
background: #222;
|
background: #222;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
footer {
|
footer {
|
||||||
background: #111;
|
background: #111;
|
||||||
padding: 0.3rem;
|
padding: 0.3rem;
|
||||||
|
|||||||
@@ -19,7 +19,7 @@ export default {
|
|||||||
justify-content: center;
|
justify-content: center;
|
||||||
align-items: center;
|
align-items: center;
|
||||||
|
|
||||||
min-height: 100vh;
|
min-height: 100%;
|
||||||
|
|
||||||
flex-direction: column;
|
flex-direction: column;
|
||||||
|
|
||||||
|
|||||||
@@ -13,7 +13,7 @@ export default Vue.extend({});
|
|||||||
justify-content: center;
|
justify-content: center;
|
||||||
align-items: center;
|
align-items: center;
|
||||||
|
|
||||||
min-height: 100vh;
|
min-height: 100%;
|
||||||
|
|
||||||
font-size: calc(0.75rem + 1vw);
|
font-size: calc(0.75rem + 1vw);
|
||||||
|
|
||||||
|
|||||||
@@ -188,11 +188,6 @@ export default Vue.extend({
|
|||||||
@import "../../styles/variables.scss";
|
@import "../../styles/variables.scss";
|
||||||
@import "../../styles/responsive.scss";
|
@import "../../styles/responsive.scss";
|
||||||
|
|
||||||
ul {
|
|
||||||
list-style: none;
|
|
||||||
padding: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
.hour {
|
.hour {
|
||||||
padding: 0.4em;
|
padding: 0.4em;
|
||||||
border-radius: 1rem;
|
border-radius: 1rem;
|
||||||
@@ -247,17 +242,18 @@ ul {
|
|||||||
}
|
}
|
||||||
|
|
||||||
display: block;
|
display: block;
|
||||||
|
|
||||||
white-space: nowrap;
|
white-space: nowrap;
|
||||||
border-collapse: collapse;
|
border-collapse: collapse;
|
||||||
|
|
||||||
font-size: calc(0.6rem + 0.4vw);
|
font-size: calc(0.6rem + 0.4vw);
|
||||||
cursor: pointer;
|
|
||||||
|
@include smallScreen() {
|
||||||
|
font-size: 0.5rem;
|
||||||
|
}
|
||||||
|
|
||||||
thead th {
|
thead th {
|
||||||
padding: 0.8rem;
|
padding: 0.2rem;
|
||||||
background-color: #444;
|
background-color: #444;
|
||||||
min-width: 100px;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
tr {
|
tr {
|
||||||
@@ -284,6 +280,8 @@ ul {
|
|||||||
text-align: center;
|
text-align: center;
|
||||||
vertical-align: middle;
|
vertical-align: middle;
|
||||||
|
|
||||||
|
cursor: pointer;
|
||||||
|
|
||||||
@include smallScreen() {
|
@include smallScreen() {
|
||||||
margin: 0;
|
margin: 0;
|
||||||
padding: 0.1rem 0.5rem;
|
padding: 0.1rem 0.5rem;
|
||||||
|
|||||||
@@ -51,14 +51,14 @@ export default Vue.extend({
|
|||||||
|
|
||||||
.options {
|
.options {
|
||||||
position: relative;
|
position: relative;
|
||||||
font-size: calc(0.7rem + 0.5vw);
|
font-size: calc(0.6rem + 0.9vw);
|
||||||
|
|
||||||
display: flex;
|
display: flex;
|
||||||
}
|
}
|
||||||
|
|
||||||
button {
|
button {
|
||||||
color: #e0e0e0;
|
color: #e0e0e0;
|
||||||
font-size: 1em;
|
font-size: 0.8em;
|
||||||
|
|
||||||
display: flex;
|
display: flex;
|
||||||
align-items: center;
|
align-items: center;
|
||||||
|
|||||||
@@ -12,6 +12,7 @@
|
|||||||
:type="el.type"
|
:type="el.type"
|
||||||
:id="item.id"
|
:id="item.id"
|
||||||
:name="item.name"
|
:name="item.name"
|
||||||
|
v-model="item.value"
|
||||||
checked
|
checked
|
||||||
@change="handleChange"
|
@change="handleChange"
|
||||||
/>
|
/>
|
||||||
@@ -30,15 +31,16 @@
|
|||||||
<div class="item-content centered">
|
<div class="item-content centered">
|
||||||
<div class="item-input" style="text-align: center;">
|
<div class="item-input" style="text-align: center;">
|
||||||
<input
|
<input
|
||||||
|
v-model="levelFrom"
|
||||||
type="number"
|
type="number"
|
||||||
name="level-from"
|
name="level-from"
|
||||||
min="0"
|
min="0"
|
||||||
max="25"
|
max="25"
|
||||||
value="0"
|
|
||||||
@change="handleInput"
|
@change="handleInput"
|
||||||
/>
|
/>
|
||||||
<span> do </span>
|
<span> do </span>
|
||||||
<input
|
<input
|
||||||
|
v-model="levelTo"
|
||||||
type="number"
|
type="number"
|
||||||
name="level-to"
|
name="level-to"
|
||||||
min="0"
|
min="0"
|
||||||
@@ -63,6 +65,19 @@
|
|||||||
<div class="item-content">
|
<div class="item-content">
|
||||||
<div class="item-input">
|
<div class="item-input">
|
||||||
<input
|
<input
|
||||||
|
v-model="oneWay"
|
||||||
|
type="checkbox"
|
||||||
|
id="no-1track"
|
||||||
|
name="no-1track"
|
||||||
|
checked
|
||||||
|
@change="handleChange"
|
||||||
|
/>
|
||||||
|
<label for="no-1track">Jednotory</label>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="item-input">
|
||||||
|
<input
|
||||||
|
v-model="oneWayCatenary"
|
||||||
type="number"
|
type="number"
|
||||||
name="1track-e"
|
name="1track-e"
|
||||||
min="0"
|
min="0"
|
||||||
@@ -75,6 +90,7 @@
|
|||||||
|
|
||||||
<div class="item-input">
|
<div class="item-input">
|
||||||
<input
|
<input
|
||||||
|
v-model="oneWayOther"
|
||||||
type="number"
|
type="number"
|
||||||
name="1track-ne"
|
name="1track-ne"
|
||||||
min="0"
|
min="0"
|
||||||
@@ -98,6 +114,20 @@
|
|||||||
<div class="item-content">
|
<div class="item-content">
|
||||||
<div class="item-input">
|
<div class="item-input">
|
||||||
<input
|
<input
|
||||||
|
v-model="twoWay"
|
||||||
|
type="checkbox"
|
||||||
|
id="no-2track"
|
||||||
|
name="no-2track"
|
||||||
|
ref="2track"
|
||||||
|
checked
|
||||||
|
@change="handleChange"
|
||||||
|
/>
|
||||||
|
<label for="no-2track">Dwutory</label>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="item-input">
|
||||||
|
<input
|
||||||
|
v-model="twoWayCatenary"
|
||||||
type="number"
|
type="number"
|
||||||
name="2track-e"
|
name="2track-e"
|
||||||
min="0"
|
min="0"
|
||||||
@@ -110,6 +140,7 @@
|
|||||||
|
|
||||||
<div class="item-input">
|
<div class="item-input">
|
||||||
<input
|
<input
|
||||||
|
v-model="twoWayOther"
|
||||||
type="number"
|
type="number"
|
||||||
name="2track-ne"
|
name="2track-ne"
|
||||||
min="0"
|
min="0"
|
||||||
@@ -123,6 +154,10 @@
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</li>
|
</li>
|
||||||
|
|
||||||
|
<li class="grid-row">
|
||||||
|
<button @click="reset">RESET FILTRÓW</button>
|
||||||
|
</li>
|
||||||
</ul>
|
</ul>
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
@@ -133,7 +168,22 @@ import { mapActions } from "vuex";
|
|||||||
|
|
||||||
export default Vue.extend({
|
export default Vue.extend({
|
||||||
name: "list-filter",
|
name: "list-filter",
|
||||||
|
watch: {
|
||||||
|
gridElements: {
|
||||||
|
handler: (v1, v2) => {},
|
||||||
|
deep: true
|
||||||
|
}
|
||||||
|
},
|
||||||
data: () => ({
|
data: () => ({
|
||||||
|
oneWay: true,
|
||||||
|
twoWay: true,
|
||||||
|
levelFrom: 0,
|
||||||
|
levelTo: 20,
|
||||||
|
oneWayCatenary: 0,
|
||||||
|
oneWayOther: 0,
|
||||||
|
twoWayCatenary: 0,
|
||||||
|
twoWayOther: 0,
|
||||||
|
|
||||||
gridElements: {
|
gridElements: {
|
||||||
access: {
|
access: {
|
||||||
title: "Dostępność",
|
title: "Dostępność",
|
||||||
@@ -141,16 +191,19 @@ export default Vue.extend({
|
|||||||
items: [
|
items: [
|
||||||
{
|
{
|
||||||
id: "is-default",
|
id: "is-default",
|
||||||
|
value: true,
|
||||||
name: "default",
|
name: "default",
|
||||||
content: "w paczce z grą"
|
content: "w paczce z grą"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
id: "not-default",
|
id: "not-default",
|
||||||
|
value: true,
|
||||||
name: "notDefault",
|
name: "notDefault",
|
||||||
content: "poza paczką z grą"
|
content: "poza paczką z grą"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
id: "non-public",
|
id: "non-public",
|
||||||
|
value: true,
|
||||||
name: "nonPublic",
|
name: "nonPublic",
|
||||||
content: "niepubliczna"
|
content: "niepubliczna"
|
||||||
}
|
}
|
||||||
@@ -164,21 +217,25 @@ export default Vue.extend({
|
|||||||
items: [
|
items: [
|
||||||
{
|
{
|
||||||
id: "SPK",
|
id: "SPK",
|
||||||
|
value: true,
|
||||||
name: "SPK",
|
name: "SPK",
|
||||||
content: "SPK"
|
content: "SPK"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
id: "SCS",
|
id: "SCS",
|
||||||
|
value: true,
|
||||||
name: "SCS",
|
name: "SCS",
|
||||||
content: "SCS"
|
content: "SCS"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
id: "by-hand",
|
id: "by-hand",
|
||||||
|
value: true,
|
||||||
name: "ręczne",
|
name: "ręczne",
|
||||||
content: "ręczne"
|
content: "ręczne"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
id: "levers",
|
id: "levers",
|
||||||
|
value: true,
|
||||||
name: "mechaniczne",
|
name: "mechaniczne",
|
||||||
content: "mechaniczne"
|
content: "mechaniczne"
|
||||||
}
|
}
|
||||||
@@ -192,21 +249,25 @@ export default Vue.extend({
|
|||||||
items: [
|
items: [
|
||||||
{
|
{
|
||||||
id: "modern",
|
id: "modern",
|
||||||
|
value: true,
|
||||||
name: "współczesna",
|
name: "współczesna",
|
||||||
content: "współczesna"
|
content: "współczesna"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
id: "semaphore",
|
id: "semaphore",
|
||||||
|
value: true,
|
||||||
name: "kształtowa",
|
name: "kształtowa",
|
||||||
content: "kształtowa"
|
content: "kształtowa"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
id: "mixed",
|
id: "mixed",
|
||||||
|
value: true,
|
||||||
name: "mieszana",
|
name: "mieszana",
|
||||||
content: "mieszana"
|
content: "mieszana"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
id: "historic",
|
id: "historic",
|
||||||
|
value: true,
|
||||||
name: "historyczna",
|
name: "historyczna",
|
||||||
content: "historyczna"
|
content: "historyczna"
|
||||||
}
|
}
|
||||||
@@ -215,7 +276,7 @@ export default Vue.extend({
|
|||||||
}
|
}
|
||||||
}),
|
}),
|
||||||
methods: {
|
methods: {
|
||||||
...mapActions(["setFilter"]),
|
...mapActions(["setFilter", "resetFilters"]),
|
||||||
handleChange(e: any) {
|
handleChange(e: any) {
|
||||||
this.setFilter({ filterName: e.target.name, value: !e.target.checked });
|
this.setFilter({ filterName: e.target.name, value: !e.target.checked });
|
||||||
},
|
},
|
||||||
@@ -224,6 +285,24 @@ export default Vue.extend({
|
|||||||
filterName: e.target.name,
|
filterName: e.target.name,
|
||||||
value: parseInt(e.target.value)
|
value: parseInt(e.target.value)
|
||||||
});
|
});
|
||||||
|
},
|
||||||
|
reset() {
|
||||||
|
for (const [key, value] of Object.entries(this.gridElements)) {
|
||||||
|
for (const item of this.gridElements[key].items) {
|
||||||
|
item.value = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
this.oneWay = true;
|
||||||
|
this.twoWay = true;
|
||||||
|
this.levelFrom = 0;
|
||||||
|
this.levelTo = 20;
|
||||||
|
this.oneWayCatenary = 0;
|
||||||
|
this.oneWayOther = 0;
|
||||||
|
this.twoWayCatenary = 0;
|
||||||
|
this.twoWayOther = 0;
|
||||||
|
|
||||||
|
this.resetFilters();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
@@ -246,6 +325,10 @@ export default Vue.extend({
|
|||||||
white-space: nowrap;
|
white-space: nowrap;
|
||||||
|
|
||||||
font-size: calc(0.6rem + 0.4vw);
|
font-size: calc(0.6rem + 0.4vw);
|
||||||
|
|
||||||
|
@include smallScreen() {
|
||||||
|
font-size: 0.65rem;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.grid {
|
.grid {
|
||||||
@@ -271,12 +354,13 @@ export default Vue.extend({
|
|||||||
-webkit-user-select: none;
|
-webkit-user-select: none;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
.item {
|
||||||
|
&-title {
|
||||||
|
text-align: center;
|
||||||
|
margin-bottom: 0.5rem;
|
||||||
|
font-weight: bold;
|
||||||
|
|
||||||
.item-title {
|
color: $accentCol;
|
||||||
text-align: center;
|
}
|
||||||
margin-bottom: 0.5rem;
|
|
||||||
font-weight: bold;
|
|
||||||
|
|
||||||
color: $accentCol;
|
|
||||||
}
|
}
|
||||||
</style>
|
</style>
|
||||||
@@ -1,134 +0,0 @@
|
|||||||
import Vue from 'vue'
|
|
||||||
import Vuex from 'vuex'
|
|
||||||
import data from '@/data/stations.json';
|
|
||||||
|
|
||||||
Vue.use(Vuex)
|
|
||||||
|
|
||||||
export default new Vuex.Store({
|
|
||||||
state: {
|
|
||||||
stations: [],
|
|
||||||
filteredStations: [],
|
|
||||||
filters: [],
|
|
||||||
trainCount: 0
|
|
||||||
},
|
|
||||||
actions: {
|
|
||||||
fetchStations: async ({ commit }) => {
|
|
||||||
let onlineStations, statusList, onlineTrains
|
|
||||||
|
|
||||||
try {
|
|
||||||
onlineStations = (await (await fetch('https://api.td2.info.pl:9640/?method=getStationsOnline')).json()).message
|
|
||||||
statusList = (await (await fetch('https://api.td2.info.pl:9640/?method=readFromSWDR&value=getDispatcherStatusList%3B1')).json()).message
|
|
||||||
onlineTrains = (await (await fetch('https://api.td2.info.pl:9640/?method=getTrainsOnline')).json()).message
|
|
||||||
} catch (error) {
|
|
||||||
throw Error(error.message);
|
|
||||||
}
|
|
||||||
|
|
||||||
commit('setTrainCount', onlineTrains.filter((train) => train.isOnline && train.region === 'eu').length);
|
|
||||||
|
|
||||||
const mappedStations = onlineStations
|
|
||||||
.filter((station) => station.region === 'eu')
|
|
||||||
.filter((station) => station.isOnline)
|
|
||||||
.map((
|
|
||||||
{ stationName = '', stationHash = '', maxUsers = 0, currentUsers = 0, spawnString = '',
|
|
||||||
dispatcherRate = 0, dispatcherName = '', dispatcherExp = 0, dispatcherId = 0 }) => {
|
|
||||||
|
|
||||||
const status = statusList.find((s) => s[0] === stationHash && s[1] === 'eu')
|
|
||||||
let occupiedTo = "---"
|
|
||||||
let occupiedTimestamp = 0
|
|
||||||
|
|
||||||
if (!status)
|
|
||||||
occupiedTo = "NIEZALOGOWANY";
|
|
||||||
else {
|
|
||||||
let occupiedCode = status[2];
|
|
||||||
|
|
||||||
occupiedTimestamp = status[3];
|
|
||||||
occupiedTo = "NIEDOSTĘPNY";
|
|
||||||
|
|
||||||
if (occupiedCode === 0) {
|
|
||||||
if (occupiedTimestamp - Date.now() > 21000000)
|
|
||||||
occupiedTo = "BEZ LIMITU";
|
|
||||||
else
|
|
||||||
occupiedTo = new Date(status[3])
|
|
||||||
.toLocaleTimeString('en-US',
|
|
||||||
{ hour12: false, hour: '2-digit', minute: '2-digit' });
|
|
||||||
}
|
|
||||||
|
|
||||||
if (occupiedCode === 1)
|
|
||||||
occupiedTo = "Z/W";
|
|
||||||
|
|
||||||
if (occupiedCode === 2 && occupiedTimestamp === 0)
|
|
||||||
occupiedTo = "KOŃCZY";
|
|
||||||
|
|
||||||
if (occupiedCode === 3)
|
|
||||||
occupiedTo = "BRAK MIEJSCA";
|
|
||||||
}
|
|
||||||
|
|
||||||
const trains = onlineTrains.filter((train) =>
|
|
||||||
train.region === 'eu' && train.isOnline === 1 && train.station.stationName === stationName)
|
|
||||||
|
|
||||||
const stationData = data.find((station) => station.stationName === stationName) || { stationName, stationURL: "" }
|
|
||||||
|
|
||||||
return {
|
|
||||||
...stationData,
|
|
||||||
stationHash,
|
|
||||||
maxUsers,
|
|
||||||
currentUsers,
|
|
||||||
spawnString: spawnString && spawnString.split(';').map(v => v.split(',')[6] ? v.split(',')[6] : v.split(',')[0]),
|
|
||||||
dispatcherName,
|
|
||||||
dispatcherRate,
|
|
||||||
dispatcherId,
|
|
||||||
dispatcherExp: dispatcherExp < 2 ? 'L' : dispatcherExp,
|
|
||||||
occupiedTo,
|
|
||||||
trains
|
|
||||||
}
|
|
||||||
})
|
|
||||||
|
|
||||||
commit('setStations', mappedStations);
|
|
||||||
commit('filterStations');
|
|
||||||
},
|
|
||||||
|
|
||||||
addFilters({ commit }, filterId) {
|
|
||||||
commit('addFilters', filterId);
|
|
||||||
commit('filterStations');
|
|
||||||
},
|
|
||||||
|
|
||||||
removeFilters({ commit }, filterId) {
|
|
||||||
commit('removeFilters', filterId);
|
|
||||||
commit('filterStations');
|
|
||||||
}
|
|
||||||
},
|
|
||||||
mutations: {
|
|
||||||
setStations: (state, stations) => state.stations = stations,
|
|
||||||
setTrainCount: (state, count) => state.trainCount = count,
|
|
||||||
|
|
||||||
addFilters(state, filters) {
|
|
||||||
state.filters.push(...filters);
|
|
||||||
},
|
|
||||||
removeFilters: (state, filters) => {
|
|
||||||
filters.forEach(filter => {
|
|
||||||
state.filters = state.filters.filter((id) => id !== filter);
|
|
||||||
})
|
|
||||||
},
|
|
||||||
|
|
||||||
filterStations(state) {
|
|
||||||
state.filteredStations = state.stations.filter((station) => {
|
|
||||||
if (station.default && state.filters.includes("default")) return false;
|
|
||||||
if ((!station.default) && state.filters.includes("notDefault")) return false;
|
|
||||||
if ((station.nonPublic || !station.reqLevel) && (state.filters.includes("nonPublic"))) return false;
|
|
||||||
|
|
||||||
if (state.filters.includes(station.controlType)) return false;
|
|
||||||
if (state.filters.includes(station.signalType)) return false;
|
|
||||||
|
|
||||||
if (station.controlType && state.filters.filter((f) => station.controlType.includes(f)).length > 0) return false;
|
|
||||||
|
|
||||||
return true;
|
|
||||||
})
|
|
||||||
}
|
|
||||||
},
|
|
||||||
getters: {
|
|
||||||
getStations: state => state.filteredStations,
|
|
||||||
getStationCount: state => state.stations.length,
|
|
||||||
getTrainCount: state => state.trainCount,
|
|
||||||
getFilters: state => state.filters,
|
|
||||||
}
|
|
||||||
})
|
|
||||||
@@ -27,6 +27,28 @@ class Store extends VuexModule {
|
|||||||
|
|
||||||
public filteredStations: {}[] = [];
|
public filteredStations: {}[] = [];
|
||||||
|
|
||||||
|
public filterInitStates = {
|
||||||
|
"default": false,
|
||||||
|
"notDefault": false,
|
||||||
|
"nonPublic": false,
|
||||||
|
"SPK": false,
|
||||||
|
"SCS": false,
|
||||||
|
"ręczne": false,
|
||||||
|
"mechaniczne": false,
|
||||||
|
"współczesna": false,
|
||||||
|
"kształtowa": false,
|
||||||
|
"historyczna": false,
|
||||||
|
"mieszana": false,
|
||||||
|
"levelFrom": 0,
|
||||||
|
"levelTo": 20,
|
||||||
|
"1track-ne": 0,
|
||||||
|
"2track-ne": 0,
|
||||||
|
"1track-e": 0,
|
||||||
|
"2track-e": 0,
|
||||||
|
"no-1track": false,
|
||||||
|
"no-2track": false
|
||||||
|
} as const;
|
||||||
|
|
||||||
public filters = {
|
public filters = {
|
||||||
"default": false,
|
"default": false,
|
||||||
"notDefault": false,
|
"notDefault": false,
|
||||||
@@ -45,6 +67,8 @@ class Store extends VuexModule {
|
|||||||
"2track-ne": 0,
|
"2track-ne": 0,
|
||||||
"1track-e": 0,
|
"1track-e": 0,
|
||||||
"2track-e": 0,
|
"2track-e": 0,
|
||||||
|
"no-1track": false,
|
||||||
|
"no-2track": false
|
||||||
} as any;
|
} as any;
|
||||||
|
|
||||||
|
|
||||||
@@ -70,6 +94,12 @@ class Store extends VuexModule {
|
|||||||
this.context.commit('filterStations');
|
this.context.commit('filterStations');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Action
|
||||||
|
public resetFilters() {
|
||||||
|
this.context.commit('resetFilterList');
|
||||||
|
this.context.commit('filterStations');
|
||||||
|
}
|
||||||
|
|
||||||
@Action
|
@Action
|
||||||
public async fetchStations() {
|
public async fetchStations() {
|
||||||
let onlineStations: {
|
let onlineStations: {
|
||||||
@@ -175,6 +205,9 @@ class Store extends VuexModule {
|
|||||||
if (station.reqLevel < this.filters['level-from']) return false;
|
if (station.reqLevel < this.filters['level-from']) return false;
|
||||||
if (station.reqLevel > this.filters['level-to']) return false;
|
if (station.reqLevel > this.filters['level-to']) return false;
|
||||||
|
|
||||||
|
if (this.filters["no-1track"] && (station.routes.oneWay.catenary != 0 || station.routes.oneWay.noCatenary != 0)) return false;
|
||||||
|
if (this.filters["no-2track"] && (station.routes.twoWay.catenary != 0 || station.routes.twoWay.noCatenary != 0)) return false;
|
||||||
|
|
||||||
if (station.routes.oneWay.catenary < this.filters['1track-e']) return false;
|
if (station.routes.oneWay.catenary < this.filters['1track-e']) return false;
|
||||||
if (station.routes.oneWay.noCatenary < this.filters['1track-ne']) return false;
|
if (station.routes.oneWay.noCatenary < this.filters['1track-ne']) return false;
|
||||||
|
|
||||||
@@ -195,6 +228,11 @@ class Store extends VuexModule {
|
|||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Mutation
|
||||||
|
public resetFilterList() {
|
||||||
|
this.filters = { ...this.filterInitStates };
|
||||||
|
}
|
||||||
|
|
||||||
@Mutation
|
@Mutation
|
||||||
public setStations(stations: []) {
|
public setStations(stations: []) {
|
||||||
this.stations = stations;
|
this.stations = stations;
|
||||||
|
|||||||
@@ -5,6 +5,8 @@
|
|||||||
"strict": true,
|
"strict": true,
|
||||||
"jsx": "preserve",
|
"jsx": "preserve",
|
||||||
"importHelpers": true,
|
"importHelpers": true,
|
||||||
|
"suppressImplicitAnyIndexErrors": true,
|
||||||
|
"noImplicitAny": false,
|
||||||
"moduleResolution": "node",
|
"moduleResolution": "node",
|
||||||
"experimentalDecorators": true,
|
"experimentalDecorators": true,
|
||||||
"esModuleInterop": true,
|
"esModuleInterop": true,
|
||||||
|
|||||||
Reference in New Issue
Block a user