2019-12-01 04:32:47 +00:00
|
|
|
<template>
|
2020-05-18 02:28:38 +00:00
|
|
|
<div class="tags">
|
|
|
|
<div
|
|
|
|
v-for="(tags, category) in categories"
|
|
|
|
:key="category"
|
2020-07-19 01:52:36 +00:00
|
|
|
class="category"
|
2020-05-18 02:28:38 +00:00
|
|
|
>
|
|
|
|
<h3 class="heading">{{ category }}</h3>
|
2020-03-25 01:48:54 +00:00
|
|
|
|
2020-05-18 02:28:38 +00:00
|
|
|
<div
|
|
|
|
:key="sfw"
|
|
|
|
v-lazy-container
|
|
|
|
class="tiles"
|
|
|
|
>
|
|
|
|
<Tag
|
|
|
|
v-for="tag in tags"
|
|
|
|
:key="`tag-${tag.id}`"
|
|
|
|
:tag="tag"
|
|
|
|
:lazy="true"
|
|
|
|
/>
|
|
|
|
</div>
|
|
|
|
</div>
|
2020-08-15 17:04:33 +00:00
|
|
|
|
|
|
|
<Footer />
|
2020-05-18 02:28:38 +00:00
|
|
|
</div>
|
2019-12-01 04:32:47 +00:00
|
|
|
</template>
|
|
|
|
|
|
|
|
<script>
|
2020-06-28 01:19:09 +00:00
|
|
|
import Tag from './tile.vue';
|
2019-12-01 04:32:47 +00:00
|
|
|
|
2020-04-08 12:50:43 +00:00
|
|
|
function sfw() {
|
2020-05-18 02:28:38 +00:00
|
|
|
return this.$store.state.ui.sfw;
|
2020-04-08 12:50:43 +00:00
|
|
|
}
|
|
|
|
|
2019-12-01 04:32:47 +00:00
|
|
|
async function mounted() {
|
2020-05-18 02:28:38 +00:00
|
|
|
const tagSlugsByCategory = {
|
|
|
|
popular: [
|
|
|
|
'anal',
|
|
|
|
'lesbian',
|
|
|
|
'interracial',
|
|
|
|
'mff',
|
|
|
|
'mfm',
|
|
|
|
'teen',
|
|
|
|
'milf',
|
|
|
|
'blowjob',
|
|
|
|
'orgy',
|
|
|
|
'gangbang',
|
2020-07-02 02:04:28 +00:00
|
|
|
'dp',
|
2020-05-18 02:28:38 +00:00
|
|
|
'facial',
|
|
|
|
'creampie',
|
2020-06-25 00:26:25 +00:00
|
|
|
'squirting',
|
2020-05-18 02:28:38 +00:00
|
|
|
],
|
2020-08-01 13:11:07 +00:00
|
|
|
appearance: [
|
2020-05-18 02:28:38 +00:00
|
|
|
'asian',
|
|
|
|
'ebony',
|
|
|
|
'latina',
|
|
|
|
'caucasian',
|
2020-05-21 01:44:44 +00:00
|
|
|
'natural-boobs',
|
|
|
|
'fake-boobs',
|
2020-05-18 02:28:38 +00:00
|
|
|
'blonde',
|
|
|
|
'brunette',
|
|
|
|
'redhead',
|
2020-05-20 01:00:46 +00:00
|
|
|
'tattoos',
|
|
|
|
'piercings',
|
2020-05-18 02:28:38 +00:00
|
|
|
],
|
2020-05-21 01:44:44 +00:00
|
|
|
oral: [
|
|
|
|
'blowjob',
|
|
|
|
'deepthroat',
|
|
|
|
'facefucking',
|
|
|
|
'double-blowjob',
|
|
|
|
'blowbang',
|
|
|
|
'pussy-eating',
|
|
|
|
'ass-eating',
|
2020-05-26 02:11:29 +00:00
|
|
|
'atm',
|
2020-05-21 01:44:44 +00:00
|
|
|
],
|
2020-05-18 02:28:38 +00:00
|
|
|
cumshot: [
|
|
|
|
'facial',
|
|
|
|
'bukkake',
|
|
|
|
'creampie',
|
|
|
|
'anal-creampie',
|
|
|
|
'cum-in-mouth',
|
2020-07-22 02:12:20 +00:00
|
|
|
'oral-creampie',
|
2020-07-08 02:58:12 +00:00
|
|
|
'cum-on-butt',
|
2020-05-18 02:28:38 +00:00
|
|
|
],
|
2020-08-14 21:05:25 +00:00
|
|
|
extreme: [
|
|
|
|
'airtight',
|
|
|
|
'dap',
|
|
|
|
'dvp',
|
|
|
|
'da-tp',
|
|
|
|
'dv-tp',
|
|
|
|
'tap',
|
|
|
|
],
|
2020-05-18 02:28:38 +00:00
|
|
|
roleplay: [
|
|
|
|
'family',
|
2020-07-18 03:12:32 +00:00
|
|
|
'parody',
|
2020-05-18 02:28:38 +00:00
|
|
|
'schoolgirl',
|
|
|
|
'nurse',
|
|
|
|
'maid',
|
|
|
|
],
|
2020-05-19 02:46:49 +00:00
|
|
|
fetish: [
|
|
|
|
'bdsm',
|
2020-07-22 02:12:20 +00:00
|
|
|
'bondage',
|
2020-05-19 02:46:49 +00:00
|
|
|
'femdom',
|
|
|
|
],
|
|
|
|
toys: [
|
2020-08-20 21:35:18 +00:00
|
|
|
'anal-toys',
|
2020-05-19 02:46:49 +00:00
|
|
|
'double-dildo',
|
|
|
|
'double-dildo-blowjob',
|
|
|
|
],
|
2020-05-18 02:28:38 +00:00
|
|
|
misc: [
|
|
|
|
'gaping',
|
2020-06-25 00:26:25 +00:00
|
|
|
'squirting',
|
2020-05-18 02:28:38 +00:00
|
|
|
'oil',
|
|
|
|
],
|
|
|
|
};
|
2020-03-25 01:48:54 +00:00
|
|
|
|
2020-05-18 02:28:38 +00:00
|
|
|
const tags = await this.$store.dispatch('fetchTags', {
|
|
|
|
slugs: Object.values(tagSlugsByCategory).flat(),
|
|
|
|
});
|
2019-12-04 20:58:08 +00:00
|
|
|
|
2020-05-18 02:28:38 +00:00
|
|
|
const tagsBySlug = tags.reduce((acc, tag) => ({ ...acc, [tag.slug]: tag }), {});
|
2020-03-23 03:58:23 +00:00
|
|
|
|
2020-05-18 02:28:38 +00:00
|
|
|
this.categories = Object.entries(tagSlugsByCategory).reduce((acc, [category, tagSlugs]) => ({
|
|
|
|
...acc,
|
|
|
|
[category]: tagSlugs.map(tagSlug => tagsBySlug[tagSlug]),
|
|
|
|
}), {});
|
2020-03-25 01:48:54 +00:00
|
|
|
|
2020-05-18 02:28:38 +00:00
|
|
|
this.pageTitle = 'Tags';
|
2019-12-01 04:32:47 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
export default {
|
2020-05-18 02:28:38 +00:00
|
|
|
components: {
|
|
|
|
Tag,
|
|
|
|
},
|
|
|
|
data() {
|
|
|
|
return {
|
|
|
|
categories: {},
|
|
|
|
pageTitle: null,
|
|
|
|
};
|
|
|
|
},
|
|
|
|
computed: {
|
|
|
|
sfw,
|
|
|
|
},
|
|
|
|
mounted,
|
2019-12-01 04:32:47 +00:00
|
|
|
};
|
|
|
|
</script>
|
|
|
|
|
|
|
|
<style lang="scss" scoped>
|
2019-12-09 04:00:49 +00:00
|
|
|
@import 'theme';
|
|
|
|
|
2019-12-01 04:32:47 +00:00
|
|
|
.tags {
|
2020-08-15 17:04:33 +00:00
|
|
|
padding: 1rem 1rem 0 1rem;
|
2019-12-04 20:58:08 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
.tiles {
|
2019-12-01 04:32:47 +00:00
|
|
|
display: grid;
|
2020-06-28 01:58:16 +00:00
|
|
|
grid-template-columns: repeat(auto-fill, minmax(23rem, .33fr));
|
2020-07-05 02:10:35 +00:00
|
|
|
grid-gap: 1rem;
|
2020-03-25 01:48:54 +00:00
|
|
|
margin: 0 0 1.5rem 0;
|
2020-03-23 00:43:49 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
.heading {
|
2020-03-25 01:48:54 +00:00
|
|
|
text-transform: capitalize;
|
2019-12-01 04:32:47 +00:00
|
|
|
}
|
2020-02-19 03:41:53 +00:00
|
|
|
|
|
|
|
@media(max-width: $breakpoint3) {
|
|
|
|
.tiles {
|
2020-06-28 01:19:09 +00:00
|
|
|
grid-template-columns: repeat(auto-fill, minmax(20rem, .5fr));
|
2020-02-19 03:41:53 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
@media(max-width: $breakpoint) {
|
|
|
|
.tiles {
|
2020-06-28 01:19:09 +00:00
|
|
|
grid-template-columns: repeat(auto-fill, minmax(15rem, 1fr));
|
2020-07-05 02:10:35 +00:00
|
|
|
grid-gap: .5rem;
|
2020-06-28 01:19:09 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
@media(max-width: $breakpoint0) {
|
|
|
|
.tiles {
|
2020-07-05 02:10:35 +00:00
|
|
|
grid-template-columns: repeat(auto-fill, minmax(12rem, 1fr));
|
2020-02-19 03:41:53 +00:00
|
|
|
}
|
|
|
|
}
|
2019-12-01 04:32:47 +00:00
|
|
|
</style>
|