Compare commits

...

6 Commits

Author SHA1 Message Date
Spythere 2106675a0a Merge pull request #38 from Spythere/development
v1.8.12
2024-10-22 21:31:37 +02:00
Spythere 1b68e0174d bump: v1.8.12 2024-10-22 20:54:35 +02:00
Spythere b47f692ac1 fix: typos; updated images api source 2024-10-22 20:54:24 +02:00
Spythere b6d776d94e Merge pull request #37 from Spythere/development
v1.8.11
2024-08-21 19:54:09 +02:00
Spythere 3a97f6a7ac bump: v1.8.11 2024-08-21 19:48:26 +02:00
Spythere c03e524f37 fix: wiki vehicles filtering 2024-08-21 19:48:07 +02:00
8 changed files with 71 additions and 49 deletions
+1 -1
View File
@@ -1,6 +1,6 @@
{ {
"name": "pojazdownik", "name": "pojazdownik",
"version": "1.8.10", "version": "1.8.12",
"private": true, "private": true,
"type": "module", "type": "module",
"scripts": { "scripts": {
+1 -1
View File
@@ -76,7 +76,7 @@
<div class="thumbnail-container"> <div class="thumbnail-container">
<div>{{ stockType }}</div> <div>{{ stockType }}</div>
<img <img
:src="`https://static.spythere.eu/thumbnails/${stockType}.png`" :src="`https://stacjownik.spythere.eu/static/thumbnails/${stockType}.png`"
:title="stockType" :title="stockType"
style="opacity: 0" style="opacity: 0"
@error="(e) => onStockItemError(e, stockType)" @error="(e) => onStockItemError(e, stockType)"
+60 -44
View File
@@ -6,41 +6,48 @@
<div class="tab_content"> <div class="tab_content">
<div class="actions"> <div class="actions">
<label> <div class="action action-input">
<span>{{ $t('wiki.labels.search-vehicle') }}</span> <label for="search-vehicle">
{{ $t('wiki.labels.search-vehicle') }}
<button class="reset-btn" @click="resetSearchInput">
<img src="/images/icon-exit.svg" alt="reset vehicle input icon" />
</button>
</label>
<input <input
type="text" type="text"
id="search-vehicle"
name="search-vehicle"
:placeholder="$t('wiki.labels.search-vehicle-placeholder')" :placeholder="$t('wiki.labels.search-vehicle-placeholder')"
v-model="searchedVehicleTypeName" v-model="searchedVehicleTypeName"
/> />
</label> </div>
<label> <div class="action action-select">
<span>{{ $t('wiki.labels.vehicles') }}</span> <label for="filter-type">{{ $t('wiki.labels.vehicles') }}</label>
<select name="filter-type" id="filter-type" v-model="filterType"> <select name="filter-type" id="filter-type" v-model="filterType">
<option v-for="filter in filters" :key="filter" :value="filter"> <option v-for="filter in filters" :key="filter" :value="filter">
{{ $t(`wiki.filters.${filter}`) }} {{ $t(`wiki.filters.${filter}`) }}
</option> </option>
</select> </select>
</label> </div>
<label> <div class="action action-select">
<span>{{ $t('wiki.labels.sort-by') }}</span> <label for="sorter-type">{{ $t('wiki.labels.sort-by') }}</label>
<select name="sorter-type" id="sorter-type" v-model="sorterType"> <select name="sorter-type" id="sorter-type" v-model="sorterType">
<option v-for="sorter in sorters" :key="sorter" :value="sorter"> <option v-for="sorter in sorters" :key="sorter" :value="sorter">
{{ $t(`wiki.sort-by.${sorter}`) }} {{ $t(`wiki.sort-by.${sorter}`) }}
</option> </option>
</select> </select>
</label> </div>
<label> <div class="action action-select">
<span>{{ $t('wiki.labels.sort-direction') }}</span> <label for="sorter-direction">{{ $t('wiki.labels.sort-direction') }}</label>
<select name="sorter-direction" id="sorter-direction" v-model="sorterDirection"> <select name="sorter-direction" id="sorter-direction" v-model="sorterDirection">
<option value="asc">{{ $t('wiki.sort-direction.asc') }}</option> <option value="asc">{{ $t('wiki.sort-direction.asc') }}</option>
<option value="desc">{{ $t('wiki.sort-direction.desc') }}</option> <option value="desc">{{ $t('wiki.sort-direction.desc') }}</option>
</select> </select>
</label> </div>
</div> </div>
<ul class="vehicles" ref="vehicles"> <ul class="vehicles" ref="vehicles">
@@ -79,6 +86,10 @@
</span> </span>
</li> </li>
</ul> </ul>
<div class="no-vehicles-warning" v-if="computedVehicles.length == 0">
{{ $t('wiki.no-vehicles') }}
</div>
</div> </div>
</section> </section>
</template> </template>
@@ -148,23 +159,24 @@ export default defineComponent({
this.previewVehicle(vehicle); this.previewVehicle(vehicle);
}, },
resetSearchInput() {
this.searchedVehicleTypeName = '';
},
filterVehicles(v: IVehicle) { filterVehicles(v: IVehicle) {
if (this.searchedVehicleTypeName) if (
return v.type this.searchedVehicleTypeName != '' &&
.toLocaleLowerCase() !v.type.toLocaleLowerCase().includes(this.searchedVehicleTypeName.toLocaleLowerCase())
.includes(this.searchedVehicleTypeName.toLocaleLowerCase()); )
return false;
switch (this.filterType) { if (
case 'vehicles-all': (this.filterType == 'vehicles-traction' && !isTractionUnit(v)) ||
return true; (this.filterType == 'vehicles-wagon' && isTractionUnit(v))
case 'vehicles-traction': )
return isTractionUnit(v); return false;
case 'vehicles-wagon':
return !isTractionUnit(v);
default: return true;
return false;
}
}, },
sortVehicles(v1: IVehicle, v2: IVehicle) { sortVehicles(v1: IVehicle, v2: IVehicle) {
@@ -180,21 +192,6 @@ export default defineComponent({
case 'maxSpeed': case 'maxSpeed':
return Math.sign(v1[this.sorterType] - v2[this.sorterType]) * direction; return Math.sign(v1[this.sorterType] - v2[this.sorterType]) * direction;
// case 'cargoCount':
// return (
// Math.sign(
// (!isTractionUnit(v1) ? v1.cargoTypes.length || -1 : -1) -
// (!isTractionUnit(row2.vehicle) ? row2.vehicle.cargoTypes.length || -1 : -1)
// ) * direction
// );
// case 'coldStart':
// return (
// ((isTractionUnit(v1) && v1.coldStart ? 1 : -1) -
// (isTractionUnit(row2.vehicle) && row2.vehicle.coldStart ? 1 : -1)) *
// direction
// );
default: default:
return v1.type.localeCompare(v2.type) * direction; return v1.type.localeCompare(v2.type) * direction;
} }
@@ -220,16 +217,29 @@ export default defineComponent({
gap: 0.5em; gap: 0.5em;
} }
.actions > label { .action {
display: flex; display: flex;
flex-direction: column; flex-direction: column;
gap: 0.25em; gap: 0.5em;
span { label {
color: #ccc; color: #ccc;
position: relative;
} }
} }
.action.action-input label {
display: flex;
align-items: center;
justify-content: space-between;
}
.reset-btn {
display: flex;
background-color: #161c2e;
border-radius: 0.25em;
}
.vehicles { .vehicles {
display: grid; display: grid;
grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
@@ -290,6 +300,12 @@ export default defineComponent({
color: #ccc; color: #ccc;
} }
.no-vehicles-warning {
text-align: center;
padding: 1em;
background-color: #161c2e;
}
@media screen and (max-width: $breakpointSm) { @media screen and (max-width: $breakpointSm) {
.actions-panel { .actions-panel {
align-items: stretch; align-items: stretch;
+1 -1
View File
@@ -28,7 +28,7 @@
v-for="thumbnail in getVehicleThumbnails(stock.vehicleRef.type)" v-for="thumbnail in getVehicleThumbnails(stock.vehicleRef.type)"
draggable="false" draggable="false"
style="min-width: 200px" style="min-width: 200px"
:src="`https://static.spythere.eu/thumbnails/v2/${thumbnail.src}.png`" :src="`https://stacjownik.spythere.eu/static/thumbnails/${thumbnail.src}.png`"
:alt="stock.vehicleRef.type" :alt="stock.vehicleRef.type"
:title="stock.vehicleRef.type" :title="stock.vehicleRef.type"
@load="($event) => (($event.target as HTMLImageElement).style.minWidth = 'auto')" @load="($event) => (($event.target as HTMLImageElement).style.minWidth = 'auto')"
+1
View File
@@ -163,6 +163,7 @@
}, },
"wiki": { "wiki": {
"title": "LIST OF AVAILABLE VEHICLES", "title": "LIST OF AVAILABLE VEHICLES",
"no-vehicles": "No vehicles to show with the selected filters!",
"labels": { "labels": {
"vehicles": "Vehicles", "vehicles": "Vehicles",
"sort-by": "Sort by", "sort-by": "Sort by",
+2 -1
View File
@@ -137,7 +137,7 @@
"MM": "MM - międzynar. pośpieszny", "MM": "MM - międzynar. pośpieszny",
"MH": "MH - międzywoj. pośpieszny hotelowy", "MH": "MH - międzywoj. pośpieszny hotelowy",
"RM": "RM - woj. osobowy międzynarodowy", "RM": "RM - woj. osobowy międzynarodowy",
"RA": "RA - woj. osobowy algomeracyjny", "RA": "RA - woj. osobowy aglomeracyjny",
"PW": "PW - pasażerski próżny - służbowy", "PW": "PW - pasażerski próżny - służbowy",
"PX": "PX - pasażerski próżny próbny", "PX": "PX - pasażerski próżny próbny",
@@ -163,6 +163,7 @@
}, },
"wiki": { "wiki": {
"title": "LISTA DOSTĘPNYCH POJAZDÓW", "title": "LISTA DOSTĘPNYCH POJAZDÓW",
"no-vehicles": "Brak pojazdów do pokazania przy obecnych filtrach!",
"labels": { "labels": {
"vehicles": "Pojazdy", "vehicles": "Pojazdy",
"sort-by": "Sortuj wg", "sort-by": "Sortuj wg",
+1 -1
View File
@@ -7,7 +7,7 @@ export default defineComponent({
}, },
getThumbnailURL(vehicleType: string, size: 'small' | 'large') { getThumbnailURL(vehicleType: string, size: 'small' | 'large') {
return `https://static.spythere.eu/images/${vehicleType}--${size == 'small' ? 300 : 800}px.jpg`; return `https://stacjownik.spythere.eu/static/images/${vehicleType}--${size == 'small' ? 300 : 800}px.jpg`;
}, },
}, },
}); });
+4
View File
@@ -115,6 +115,10 @@ button {
&:hover { &:hover {
color: $accentColor; color: $accentColor;
} }
&:focus-visible {
outline: 1px solid $accentColor;
}
} }
[data-tooltip]:hover::after, [data-tooltip]:hover::after,