2019-04-18 04:52:21 +00:00
|
|
|
<template lang="html">
|
|
|
|
<div :class="['platforms-page', { dark: darkModeEnabled }]">
|
2019-04-18 05:43:22 +00:00
|
|
|
<div :class="['platforms', { reverse: sortedByGeneration }]">
|
2019-04-18 04:52:21 +00:00
|
|
|
<div v-for="(group, label) in filteredPlatforms" :key="label">
|
2019-04-19 17:04:04 +00:00
|
|
|
<div class="group-label" v-if="sortedByGeneration">{{ groupLabel(label) }}</div>
|
2019-04-18 04:52:21 +00:00
|
|
|
|
|
|
|
<platform
|
|
|
|
v-for="platform in group"
|
|
|
|
:key="platform.name"
|
|
|
|
:platform-data="platform"
|
|
|
|
/>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
|
2019-04-18 05:43:22 +00:00
|
|
|
<footer>
|
2019-04-18 04:52:21 +00:00
|
|
|
<small>
|
|
|
|
Gamebrary is free and open source, consider helping its development by
|
|
|
|
<a href="https://www.paypal.me/RomanCervantes/5" target="_blank">
|
|
|
|
{{ $t('settings.donate') }}
|
|
|
|
</a>
|
|
|
|
,
|
|
|
|
<a href="https://github.com/romancmx/gamebrary/issues" target="_blank">
|
|
|
|
{{ $t('settings.reportBugs') }}
|
|
|
|
</a>
|
|
|
|
or
|
|
|
|
<a href="https://goo.gl/forms/r0juBCsZaUtJ03qb2" target="_blank">
|
|
|
|
{{ $t('settings.submitFeedback') }}
|
|
|
|
</a>
|
|
|
|
.
|
|
|
|
</small>
|
|
|
|
|
|
|
|
<igdb-credit gray />
|
2019-04-18 05:43:22 +00:00
|
|
|
</footer>
|
2019-04-18 04:52:21 +00:00
|
|
|
</div>
|
|
|
|
</template>
|
|
|
|
|
|
|
|
<script>
|
|
|
|
import platforms from '@/shared/platforms';
|
|
|
|
import ToggleSwitch from '@/components/ToggleSwitch/ToggleSwitch';
|
|
|
|
import IgdbCredit from '@/components/IgdbCredit/IgdbCredit';
|
|
|
|
import Platform from '@/components/Platform/Platform';
|
|
|
|
import Panel from '@/components/Panel/Panel';
|
|
|
|
import { groupBy, sortBy } from 'lodash';
|
|
|
|
import { mapState, mapGetters } from 'vuex';
|
|
|
|
|
|
|
|
export default {
|
|
|
|
components: {
|
|
|
|
ToggleSwitch,
|
|
|
|
IgdbCredit,
|
|
|
|
Platform,
|
|
|
|
Panel,
|
|
|
|
},
|
|
|
|
|
|
|
|
data() {
|
|
|
|
return {
|
|
|
|
platforms,
|
|
|
|
};
|
|
|
|
},
|
|
|
|
|
|
|
|
computed: {
|
|
|
|
...mapState(['gameLists', 'platform', 'settings']),
|
|
|
|
...mapGetters(['darkModeEnabled']),
|
|
|
|
|
|
|
|
ownedListCount() {
|
|
|
|
return Object.keys(this.gameLists).length;
|
|
|
|
},
|
|
|
|
|
|
|
|
hasLists() {
|
|
|
|
return Object.keys(this.gameLists).length > 0;
|
|
|
|
},
|
|
|
|
|
|
|
|
ownedListsOnly() {
|
|
|
|
return this.settings && this.settings.ownedListsOnly;
|
|
|
|
},
|
|
|
|
|
|
|
|
sortedByGeneration() {
|
|
|
|
return this.settings && !this.settings.sortListsAlphabetically;
|
|
|
|
},
|
|
|
|
|
|
|
|
filteredPlatforms() {
|
|
|
|
const availableLists = this.ownedListsOnly
|
|
|
|
? this.platforms.filter(({ code }) => this.gameLists[code])
|
|
|
|
: this.platforms;
|
|
|
|
|
|
|
|
return this.settings && this.settings.sortListsAlphabetically
|
|
|
|
? groupBy(sortBy(availableLists, 'name'), '')
|
|
|
|
: groupBy(availableLists, 'generation');
|
|
|
|
},
|
|
|
|
},
|
|
|
|
|
|
|
|
methods: {
|
|
|
|
groupLabel(label) {
|
|
|
|
return label === '0'
|
|
|
|
? this.$t('platforms.computersArcade')
|
|
|
|
: `${this.ordinalSuffix(label)} ${this.$t('platforms.generation')}`;
|
|
|
|
},
|
|
|
|
|
|
|
|
ordinalSuffix(value) {
|
|
|
|
const j = value % 10;
|
|
|
|
const k = value % 100;
|
|
|
|
|
|
|
|
if (j === 1 && k !== 11) {
|
|
|
|
return `${value}${this.$t('platforms.st')}`;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (j === 2 && k !== 12) {
|
|
|
|
return `${value}${this.$t('platforms.nd')}`;
|
|
|
|
}
|
|
|
|
if (j === 3 && k !== 13) {
|
|
|
|
return `${value}${this.$t('platforms.rd')}`;
|
|
|
|
}
|
|
|
|
|
|
|
|
return `${value}${this.$t('platforms.th')}`;
|
|
|
|
},
|
|
|
|
},
|
|
|
|
};
|
|
|
|
</script>
|
|
|
|
|
|
|
|
<style lang="scss" rel="stylesheet/scss" scoped>
|
|
|
|
@import "~styles/styles.scss";
|
|
|
|
|
|
|
|
.platforms-page {
|
|
|
|
color: $color-dark-gray;
|
|
|
|
min-height: calc(100vh - #{$navHeight});
|
|
|
|
padding: 0 $gp;
|
|
|
|
|
|
|
|
&.dark {
|
|
|
|
color: $color-gray;
|
|
|
|
|
2019-04-18 05:43:22 +00:00
|
|
|
h4 {
|
|
|
|
background-color: $color-darkest-gray;
|
|
|
|
}
|
|
|
|
}
|
2019-04-18 04:52:21 +00:00
|
|
|
}
|
|
|
|
|
2019-04-18 05:43:22 +00:00
|
|
|
.platforms {
|
2019-04-18 04:52:21 +00:00
|
|
|
display: flex;
|
|
|
|
flex-direction: column;
|
|
|
|
|
|
|
|
&.reverse {
|
|
|
|
flex-direction: column-reverse;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-04-19 17:04:04 +00:00
|
|
|
.group-label {
|
2019-04-18 05:43:22 +00:00
|
|
|
position: sticky;
|
|
|
|
top: 0;
|
|
|
|
padding: $gp / 3 0;
|
|
|
|
background-color: $color-gray;
|
2019-04-18 04:52:21 +00:00
|
|
|
}
|
|
|
|
|
2019-04-18 05:43:22 +00:00
|
|
|
footer {
|
|
|
|
padding: $gp / 2 0;
|
2019-04-18 04:52:21 +00:00
|
|
|
justify-content: center;
|
|
|
|
display: flex;
|
|
|
|
align-items: center;
|
|
|
|
|
|
|
|
a {
|
|
|
|
color: $color-dark-gray;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
</style>
|