<template> <div v-if="release" class="content" > <Expand v-if="expanded" class="expand" :expanded="expanded" @expand="(state) => expanded = state" /> <Scroll v-slot="slotProps" class="scroll-light" :expandable="false" > <Media :release="release" :class="{ expanded }" @load="slotProps.loaded" /> </Scroll> <Details :release="release" /> <Expand v-if="release.photos && release.photos.length > 0" class="expand-bottom" :expanded="expanded" @expand="(state) => expanded = state" /> <div class="info column"> <div class="row"> <h2 v-if="release.title" class="title" >{{ release.title }}</h2> <h2 v-else-if="release.actors.length > 0" class="title title-composed" > {{ release.actors.map(actor => actor.name).join(', ') }} for {{ release.entity.name }} <Icon v-tooltip="`This scene has no known official title`" icon="question2" /> </h2> </div> <div v-if="release.tags.length > 0" class="row" > <Tags :tags="release.tags" /> </div> <div class="row associations"> <ul class="actors nolist"> <li v-for="actor in release.actors" :key="actor.id" > <Actor :actor="actor" /> </li> </ul> </div> <div v-if="release.movies && release.movies.length > 0" class="row" > <span class="row-label">Part of</span> <div class="movies"> <router-link v-for="movie in release.movies" :key="`movie-${movie.id}`" :to="{ name: 'movie', params: { releaseId: movie.id, releaseSlug: movie.slug } }" class="movie" > <span class="movie-title">{{ movie.title }}</span> <img :src="`/media/${movie.covers[0].thumbnail}`" class="movie-cover" > </router-link> </div> </div> <Releases v-if="release.scenes && release.scenes.length > 0" :releases="release.scenes" /> <div v-if="release.description" class="row" > <span class="row-label">Description</span> <p class="description">{{ release.description }}</p> </div> <div class="row row-tidbits"> <div v-if="release.duration" class="row-tidbit" > <span class="row-label">Duration</span> <div class="duration">{{ formatDuration(release.duration) }}</div> </div> <div v-if="release.shootId" class="row-tidbit" > <span class="row-label">Shoot #</span> {{ release.shootId }} </div> <div v-if="release.studio" class="row-tidbit" > <span class="row-label">Studio</span> <router-link :to="`/studio/${release.studio.slug}`" class="link studio" >{{ release.studio.name }}</router-link> </div> <div v-if="release.productionDate" class="row-tidbit" > <span class="row-label">Shoot date</span> {{ formatDate(release.productionDate, 'MMMM D, YYYY') }} </div> <div v-if="release.productionLocation" class="row-tidbit" > <span class="row-label">Location</span> <span class="location"> <span v-if="release.productionLocation.city" class="location-segment" >{{ release.productionLocation.city }}, </span> <span v-if="release.productionLocation.state" class="location-segment" >{{ release.productionLocation.state }}, </span> <span v-if="release.productionLocation.country" class="location-segment" >{{ release.productionLocation.country.alias || release.productionLocation.country.name }} <img class="flag" :src="`/img/flags/${release.productionLocation.country.alpha2.toLowerCase()}.svg`" > </span> </span> </div> </div> <div v-if="release.clips && release.clips.length > 0" class="row nolist" > <span class="row-label">Clips</span> <Clips :clips="release.clips" /> </div> <div v-if="release.comment" class="row" > <span class="row-label">Comment</span> <span>{{ release.comment }}</span> </div> <div class="row"> <span class="row-label">Added</span> <router-link :to="`/added/${formatDate(release.createdAt, 'YYYY/MM/DD')}`" :title="`Added on ${formatDate(release.createdAt, 'MMMM D, YYYY HH:mm')}`" class="link added" >{{ release.createdBatchId }}: {{ formatDate(release.createdAt, 'MMMM D, YYYY HH:mm') }}</router-link> </div> </div> </div> </template> <script> import Media from './media.vue'; import Details from './details.vue'; import Tags from './tags.vue'; import Clips from './clips.vue'; import Actor from '../actors/tile.vue'; import Releases from './releases.vue'; import Scroll from '../scroll/scroll.vue'; import Expand from '../expand/expand.vue'; async function fetchRelease() { if (this.$route.name === 'scene') { this.release = await this.$store.dispatch('fetchReleaseById', this.$route.params.releaseId); } if (this.$route.name === 'movie') { this.release = await this.$store.dispatch('fetchMovieById', this.$route.params.releaseId); } } function pageTitle() { return this.release && (this.release.title || (this.release.actors.length > 0 ? `${this.release.actors.map(actor => actor.name).join(', ')} for ${this.release.entity.name}` : null)); } export default { components: { Actor, Details, Media, Scroll, Expand, Releases, Clips, Tags, }, data() { return { release: null, expanded: false, }; }, computed: { pageTitle, }, watch: { $route: fetchRelease, }, mounted: fetchRelease, methods: { fetchRelease, }, }; </script> <style lang="scss" scoped> @import 'breakpoints'; .expand-bottom { border-bottom: solid 1px var(--shadow-hint); } .info { padding: 1rem; border-left: solid 1px var(--shadow-hint); border-right: solid 1px var(--shadow-hint); flex-grow: 1; } .row { margin: 0 0 1.5rem 0; &.associations { align-items: start; } } .row-label { display: block; margin: 0 0 .5rem 0; color: var(--shadow); font-weight: bold; .icon { margin: 0 .5rem 0 0; fill: var(--shadow); } } .row-tidbit { display: inline-block; margin: 0 2rem 0 0; } .title { display: inline-block; margin: 0; .icon { fill: var(--shadow); padding: .25rem; &:hover { fill: var(--primary); cursor: pointer; } } } .title-composed { color: var(--shadow); } .title-shoot { margin: 0 0 0 .5rem; color: var(--shadow); font-size: .9rem; font-weight: bold; } .description { line-height: 1.5; margin: -.25rem 0 0 0; } .actors { display: grid; grid-template-columns: repeat(auto-fill, minmax(10rem, 1fr)); grid-gap: .5rem; flex-grow: 1; flex-wrap: wrap; } .movies { display: grid; grid-template-columns: repeat(auto-fill, minmax(10rem, 1fr)); grid-gap: .5rem; flex-grow: 1; flex-wrap: wrap; } .movie { display: flex; flex-direction: column; background: var(--background); box-shadow: 0 0 3px var(--shadow-weak); color: var(--text); text-decoration: none; &:hover .movie-title { color: var(--primary); } } .movie-cover { width: 100%; } .movie-title { padding: .5rem; font-weight: bold; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; } .flag { height: 1rem; margin: 0 0 -.15rem .1rem; } .link { display: inline-flex; color: var(--link); text-decoration: none; &:hover { color: var(--primary); .icon { fill: var(--primary); } } } .showable { display: none; } @media(max-width: $breakpoint) { .hideable { display: none; } .row .showable { display: block; } .tidbit .showable { display: inline-block; } .actors { grid-template-columns: repeat(auto-fill, minmax(8rem, 1fr)); } } </style>