Compare commits

..

No commits in common. "2a51fc82fd01e0b511b82245930fab02e6e823c5" and "97cfca74adf33857dc6072319c6bdec5942df8b5" have entirely different histories.

36 changed files with 50 additions and 152 deletions

View File

@ -319,14 +319,15 @@
v-if="showAlbum" v-if="showAlbum"
:items="actor.photos" :items="actor.photos"
:title="actor.name" :title="actor.name"
:portrait="true" class="portrait"
@close="$router.go(-1)" @close="showAlbum = false"
/> />
<div class="actor-content"> <div class="actor-content">
<Scroll <Scroll
v-if="actor.avatar || (actor.photos && actor.photos.length > 0)" v-if="actor.avatar || (actor.photos && actor.photos.length > 0)"
v-slot="scroll" v-slot="scroll"
:expandable="false"
> >
<Photos <Photos
:actor="actor" :actor="actor"
@ -338,7 +339,7 @@
<button <button
v-if="actor.photos && actor.photos.length > 2" v-if="actor.photos && actor.photos.length > 2"
class="album-toggle" class="album-toggle"
@click="$router.push({ hash: '#album' })" @click="showAlbum = true"
><Icon icon="grid3" />View album</button> ><Icon icon="grid3" />View album</button>
<FilterBar <FilterBar
@ -397,16 +398,6 @@ function sfw() {
return this.$store.state.ui.sfw; return this.$store.state.ui.sfw;
} }
function showAlbum() {
return this.actor.photos?.length > 0 && this.$route.hash === '#album';
}
async function watchRoute(to, from) {
if (to.params.pageNumber !== from.params.pageNumber) {
await this.fetchActor();
}
}
async function mounted() { async function mounted() {
await this.fetchActor(); await this.fetchActor();
@ -432,6 +423,7 @@ export default {
actor: null, actor: null,
releases: null, releases: null,
totalCount: 0, totalCount: 0,
showAlbum: false,
limit: 20, limit: 20,
pageTitle: null, pageTitle: null,
bioExpanded: false, bioExpanded: false,
@ -440,10 +432,9 @@ export default {
}, },
computed: { computed: {
sfw, sfw,
showAlbum,
}, },
watch: { watch: {
$route: watchRoute, $route: fetchActor,
'$store.state.ui.tagFilter': fetchActor, '$store.state.ui.tagFilter': fetchActor,
}, },
mounted, mounted,
@ -719,6 +710,30 @@ export default {
border-bottom: solid 1px var(--shadow-hint); border-bottom: solid 1px var(--shadow-hint);
} }
.album-toggle {
height: fit-content;
display: inline-flex;
align-items: center;
justify-content: center;
padding: .5rem 1rem;
border: none;
border-bottom: solid 1px var(--shadow-hint);
color: var(--shadow);
background: var(--background-dim);
font-size: 1rem;
font-weight: bold;
.icon {
fill: var(--shadow);
margin: -.1rem .5rem 0 0;
}
&:hover {
background: var(--shadow-hint);
cursor: pointer;
}
}
@media(max-width: $breakpoint4) { @media(max-width: $breakpoint4) {
.descriptions-container { .descriptions-container {
display: none; display: none;

View File

@ -11,31 +11,22 @@
/> />
</div> </div>
<div <div class="album-items">
class="album-items"
:class="{ portrait }"
>
<div <div
v-for="item in items" v-for="item in items"
:key="item.id" :key="item.id"
class="item-container" class="item-container"
> >
<a <a
:href="`${path}/${item.path}`" :href="`/media/${item.path}`"
class="item-link" class="item-link"
target="_blank" target="_blank"
> >
<img <img
:src="`${path}/${item.thumbnail}`" :src="`/media/${item.thumbnail}`"
:title="item.comment"
loading="lazy" loading="lazy"
class="item image" class="item image"
> >
<span
v-if="comments && item.comment"
class="item-comment"
>{{ item.comment }}</span>
</a> </a>
</div> </div>
</div> </div>
@ -54,18 +45,6 @@ export default {
type: String, type: String,
default: null, default: null,
}, },
path: {
type: String,
default: '/media',
},
portrait: {
type: Boolean,
default: false,
},
comments: {
type: Boolean,
default: true,
},
}, },
emits: ['close'], emits: ['close'],
}; };
@ -103,7 +82,6 @@ export default {
overflow: hidden; overflow: hidden;
text-overflow: ellipsis; text-overflow: ellipsis;
text-align: center; text-align: center;
text-transform: capitalize;
} }
.close { .close {
@ -127,10 +105,6 @@ export default {
padding: 1rem; padding: 1rem;
margin: auto 0; margin: auto 0;
overflow-y: auto; overflow-y: auto;
&.portrait {
grid-template-columns: repeat(auto-fit, minmax(14rem, 1fr));
}
} }
.item-container { .item-container {
@ -140,50 +114,14 @@ export default {
} }
.item-link { .item-link {
position: relative;
height: 100%; height: 100%;
width: 100%;
margin: 0 0 1rem 0; margin: 0 0 1rem 0;
overflow: hidden;
&:hover .item-comment {
transform: translateY(0);
}
} }
.item { .item {
width: 100%; width: 100%;
} }
.item-comment {
width: 100%;
position: absolute;
bottom: 0;
left: 0;
box-sizing: border-box;
padding: .5rem;
color: var(--text-light);
background: var(--shadow);
font-size: .9rem;
text-shadow: 0 0 3px var(--shadow);
white-space: normal;
line-height: 1.25;
transform: translateY(100%);
transition: transform .25s ease;
}
@media(max-width: $breakpoint-giga) {
.album-items.portrait {
grid-template-columns: repeat(auto-fill, minmax(13rem, 1fr));
}
}
@media(max-width: $breakpoint-mega) {
.album-items.portrait {
grid-template-columns: repeat(auto-fill, minmax(10rem, 1fr));
}
}
@media(max-width: $breakpoint-kilo) { @media(max-width: $breakpoint-kilo) {
.album-items { .album-items {
grid-template-columns: repeat(auto-fill, minmax(18rem, 1fr)); grid-template-columns: repeat(auto-fill, minmax(18rem, 1fr));
@ -196,6 +134,12 @@ export default {
} }
} }
@media(max-width: $breakpoint-small) {
.album-items.portrait {
grid-template-columns: repeat(auto-fill, minmax(7rem, 1fr));
}
}
@media(max-width: $breakpoint-micro) { @media(max-width: $breakpoint-micro) {
.album-items { .album-items {
grid-template-columns: repeat(auto-fill, minmax(10rem, 1fr)); grid-template-columns: repeat(auto-fill, minmax(10rem, 1fr));

View File

@ -79,7 +79,6 @@
<Scroll <Scroll
v-if="entity.children.length > 0" v-if="entity.children.length > 0"
v-slot="scroll" v-slot="scroll"
:expandable="true"
:expanded="expanded" :expanded="expanded"
class="scroll-light" class="scroll-light"
@expand="(state) => expanded = state" @expand="(state) => expanded = state"

View File

@ -22,14 +22,14 @@
<button <button
v-if="release.photos.length > 0" v-if="release.photos.length > 0"
class="album-toggle" class="album-toggle"
@click="$router.push({ hash: '#album' })" @click="showAlbum = true"
><Icon icon="grid3" />View album</button> ><Icon icon="grid3" />View album</button>
<Album <Album
v-if="showAlbum" v-if="showAlbum"
:items="release.photos" :items="release.photos"
:title="release.title" :title="release.title"
@close="$router.go(-1)" @close="showAlbum = false"
/> />
<div class="info column"> <div class="info column">
@ -233,10 +233,6 @@ function pageTitle() {
|| (this.release.actors.length > 0 ? `${this.release.actors.map(actor => actor.name).join(', ')} for ${this.release.entity.name}` : null)); || (this.release.actors.length > 0 ? `${this.release.actors.map(actor => actor.name).join(', ')} for ${this.release.entity.name}` : null));
} }
function showAlbum() {
return this.release.photos?.length > 0 && this.$route.hash === '#album';
}
export default { export default {
components: { components: {
Actor, Actor,
@ -251,12 +247,12 @@ export default {
data() { data() {
return { return {
release: null, release: null,
showAlbum: false,
}; };
}, },
computed: { computed: {
pageTitle, pageTitle,
bannerBackground, bannerBackground,
showAlbum,
}, },
watch: { watch: {
$route: fetchRelease, $route: fetchRelease,

View File

@ -111,7 +111,7 @@ export default {
}, },
expandable: { expandable: {
type: Boolean, type: Boolean,
default: false, default: true,
}, },
expanded: { expanded: {
type: Boolean, type: Boolean,

View File

@ -83,11 +83,10 @@ export default {
<style lang="scss" scoped> <style lang="scss" scoped>
.photos { .photos {
width: 100%; width: 100%;
padding: .5rem 1rem; padding: .5rem 1rem 0 1rem;
box-sizing: border-box; box-sizing: border-box;
white-space: nowrap; white-space: nowrap;
font-size: 0; font-size: 0;
border-bottom: solid 1px var(--shadow-hint);
&::-webkit-scrollbar { &::-webkit-scrollbar {
display: none; display: none;

View File

@ -20,7 +20,9 @@
<Scroll <Scroll
v-if="hasMedia" v-if="hasMedia"
v-slot="scroll" v-slot="scroll"
:expanded="expanded"
class="scroll-dark" class="scroll-dark"
@expand="(state) => expanded = state"
> >
<Photos <Photos
:tag="tag" :tag="tag"
@ -29,21 +31,6 @@
/> />
</Scroll> </Scroll>
<button
v-if="tag.photos && tag.photos.length > 2"
class="album-toggle"
@click="$router.push({ hash: '#album' })"
><Icon icon="grid3" />View album</button>
<Album
v-if="showAlbum"
:items="[tag.poster, ...tag.photos]"
:title="tag.name"
path="/img"
class="portrait"
@close="$router.go(-1)"
/>
<FilterBar <FilterBar
ref="filter" ref="filter"
:fetch-releases="fetchReleases" :fetch-releases="fetchReleases"
@ -70,7 +57,6 @@ import escapeHtml from '../../../src/utils/escape-html';
import FilterBar from '../filters/filter-bar.vue'; import FilterBar from '../filters/filter-bar.vue';
import Photos from './photos.vue'; import Photos from './photos.vue';
import Album from '../album/album.vue';
import Releases from '../releases/releases.vue'; import Releases from '../releases/releases.vue';
import Pagination from '../pagination/pagination.vue'; import Pagination from '../pagination/pagination.vue';
import Scroll from '../scroll/scroll.vue'; import Scroll from '../scroll/scroll.vue';
@ -97,16 +83,6 @@ async function fetchReleases() {
} }
} }
function showAlbum() {
return this.tag.photos?.length > 0 && this.$route.hash === '#album';
}
async function watchRoute(to, from) {
if (to.params.pageNumber !== from.params.pageNumber) {
await this.fetchReleases();
}
}
async function mounted() { async function mounted() {
await this.fetchReleases(); await this.fetchReleases();
this.pageTitle = this.tag.name; this.pageTitle = this.tag.name;
@ -116,7 +92,6 @@ export default {
components: { components: {
FilterBar, FilterBar,
Releases, Releases,
Album,
Photos, Photos,
Pagination, Pagination,
Scroll, Scroll,
@ -133,11 +108,8 @@ export default {
expanded: false, expanded: false,
}; };
}, },
computed: {
showAlbum,
},
watch: { watch: {
$route: watchRoute, $route: fetchReleases,
'$store.state.ui.tagFilter': fetchReleases, '$store.state.ui.tagFilter': fetchReleases,
}, },
mounted, mounted,

View File

@ -137,7 +137,6 @@ async function mounted() {
'gaping', 'gaping',
'squirting', 'squirting',
'oil', 'oil',
'vr',
'bts', 'bts',
], ],
}; };

View File

@ -6,27 +6,3 @@
border: solid 1px var(--shadow-weak); border: solid 1px var(--shadow-weak);
cursor: pointer; cursor: pointer;
} }
.album-toggle {
height: fit-content;
display: inline-flex;
align-items: center;
justify-content: center;
padding: .5rem 1rem;
border: none;
border-bottom: solid 1px var(--shadow-hint);
color: var(--shadow);
background: var(--background-dim);
font-size: 1rem;
font-weight: bold;
.icon {
fill: var(--shadow);
margin: -.1rem .5rem 0 0;
}
&:hover {
background: var(--shadow-hint);
cursor: pointer;
}
}

2
package-lock.json generated
View File

@ -1,6 +1,6 @@
{ {
"name": "traxxx", "name": "traxxx",
"version": "1.164.0", "version": "1.163.0",
"lockfileVersion": 1, "lockfileVersion": 1,
"requires": true, "requires": true,
"dependencies": { "dependencies": {

View File

@ -1,6 +1,6 @@
{ {
"name": "traxxx", "name": "traxxx",
"version": "1.164.0", "version": "1.163.0",
"description": "All the latest porn releases in one place", "description": "All the latest porn releases in one place",
"main": "src/app.js", "main": "src/app.js",
"scripts": { "scripts": {

Binary file not shown.

Before

Width:  |  Height:  |  Size: 11 MiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 12 MiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 12 MiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.8 MiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.8 MiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.7 MiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 6.3 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 6.3 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 6.3 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 8.3 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 8.3 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 8.5 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 6.3 MiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 6.7 MiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 5.7 MiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.4 MiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.3 MiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.3 MiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 26 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 25 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 25 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 38 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 38 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 38 KiB

View File

@ -666,7 +666,6 @@ const tagPosters = [
['toy-dp', 1, 'Krissy Lynn and London River in "Lesbian DP Workout" for LesbianX'], ['toy-dp', 1, 'Krissy Lynn and London River in "Lesbian DP Workout" for LesbianX'],
['trainbang', 'poster', 'Kali Roses in "Passing Me Around" for Blacked'], ['trainbang', 'poster', 'Kali Roses in "Passing Me Around" for Blacked'],
['tap', 3, 'Julia Red in GIO1007 for LegalPorno'], ['tap', 3, 'Julia Red in GIO1007 for LegalPorno'],
['vr', 0, 'Michelle H for MetArt'],
] ]
.map(([slug, fileIndex, comment], index) => ({ .map(([slug, fileIndex, comment], index) => ({
id: `${slug}-${fileIndex}`, id: `${slug}-${fileIndex}`,
@ -861,7 +860,7 @@ const tagPhotos = [
['natural-boobs', 3, 'Violet Starr in "Violet Starr 1st Lesbian Anal" for LesbianX'], ['natural-boobs', 3, 'Violet Starr in "Violet Starr 1st Lesbian Anal" for LesbianX'],
['natural-boobs', 0, 'Valentina Nappi in "Hypnotic Curves" for LesbianX'], ['natural-boobs', 0, 'Valentina Nappi in "Hypnotic Curves" for LesbianX'],
['natural-boobs', 6, 'Blake Blossom in "Naturally Stacked Cutie" for HardX'], ['natural-boobs', 6, 'Blake Blossom in "Naturally Stacked Cutie" for HardX'],
['natural-boobs', 5, 'Chloe B in "Lamour" for MetArt'], ['natural-boobs', 5, 'Chloe B in "Lamour" for Met-Art'],
['natural-boobs', 2, 'Kylie Page for All Girl Massage'], ['natural-boobs', 2, 'Kylie Page for All Girl Massage'],
['nun', 1, 'Penny Pax and Darcie Dolce in "Confessions Of A Sinful Nun" for Sweetheart Video'], ['nun', 1, 'Penny Pax and Darcie Dolce in "Confessions Of A Sinful Nun" for Sweetheart Video'],
['nun', 3, 'Higurashi Rin in "Naughty Nun" for All Gravure'], ['nun', 3, 'Higurashi Rin in "Naughty Nun" for All Gravure'],
@ -896,7 +895,6 @@ const tagPhotos = [
['toy-anal', 0, 'Kira Noir in 1225 for InTheCrack'], ['toy-anal', 0, 'Kira Noir in 1225 for InTheCrack'],
['toy-dp', 3, 'Tori Black, Ana Foxxx, Anikka Albrite, Jenna Sativa and Abigail Mac in "Tori Black\'s Lesbian Gangbang" for LesbianX'], ['toy-dp', 3, 'Tori Black, Ana Foxxx, Anikka Albrite, Jenna Sativa and Abigail Mac in "Tori Black\'s Lesbian Gangbang" for LesbianX'],
['toy-dp', 0, 'Marley Brinx, Ivy Lebelle and Lyra Law in "Marley Brinx First GGDP" for LesbianX'], ['toy-dp', 0, 'Marley Brinx, Ivy Lebelle and Lyra Law in "Marley Brinx First GGDP" for LesbianX'],
['vr', '1a', 'Jenna Fox and Tommy Pistol in "Virtual Reality Jenna Fox Fucks So Real" for Bang Bros'],
] ]
.map(([slug, fileIndex, comment], index) => ({ .map(([slug, fileIndex, comment], index) => ({
id: `${slug}-${fileIndex}`, id: `${slug}-${fileIndex}`,