Compare commits
No commits in common. "d46ac6206d76e58859d7e96647affde307d4afbb" and "ac66606135ea7ca3c6322adcc12b8cf7ae5fe31f" have entirely different histories.
d46ac6206d
...
ac66606135
|
@ -85,8 +85,6 @@ export default {
|
||||||
}
|
}
|
||||||
|
|
||||||
.content-inner {
|
.content-inner {
|
||||||
display: flex;
|
|
||||||
flex-direction: column;
|
|
||||||
flex-grow: 1;
|
flex-grow: 1;
|
||||||
overflow-y: auto;
|
overflow-y: auto;
|
||||||
overflow-x: hidden;
|
overflow-x: hidden;
|
||||||
|
|
|
@ -112,7 +112,6 @@ export default {
|
||||||
.pagination {
|
.pagination {
|
||||||
display: flex;
|
display: flex;
|
||||||
justify-content: center;
|
justify-content: center;
|
||||||
flex-shrink: 0;
|
|
||||||
overflow: hidden;
|
overflow: hidden;
|
||||||
height: 3rem;
|
height: 3rem;
|
||||||
}
|
}
|
||||||
|
|
|
@ -84,7 +84,6 @@ export default {
|
||||||
}
|
}
|
||||||
|
|
||||||
.releases {
|
.releases {
|
||||||
flex-grow: 1;
|
|
||||||
border-top: solid 1px var(--crease);
|
border-top: solid 1px var(--crease);
|
||||||
|
|
||||||
&.embedded {
|
&.embedded {
|
||||||
|
|
|
@ -30,13 +30,7 @@
|
||||||
</Scroll>
|
</Scroll>
|
||||||
|
|
||||||
<FilterBar :fetch-releases="fetchReleases" />
|
<FilterBar :fetch-releases="fetchReleases" />
|
||||||
<Releases :releases="releases" />
|
<Releases :releases="tag.releases" />
|
||||||
|
|
||||||
<Pagination
|
|
||||||
:items-total="totalCount"
|
|
||||||
:items-per-page="limit"
|
|
||||||
class="pagination-bottom"
|
|
||||||
/>
|
|
||||||
|
|
||||||
<Footer />
|
<Footer />
|
||||||
</div>
|
</div>
|
||||||
|
@ -52,23 +46,16 @@ 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 Releases from '../releases/releases.vue';
|
import Releases from '../releases/releases.vue';
|
||||||
import Pagination from '../pagination/pagination.vue';
|
|
||||||
import Scroll from '../scroll/scroll.vue';
|
import Scroll from '../scroll/scroll.vue';
|
||||||
|
|
||||||
const converter = new Converter();
|
const converter = new Converter();
|
||||||
|
|
||||||
async function fetchReleases() {
|
async function fetchReleases() {
|
||||||
const { tag, releases, totalCount } = await this.$store.dispatch('fetchTagBySlug', {
|
this.tag = await this.$store.dispatch('fetchTagBySlug', {
|
||||||
tagSlug: this.$route.params.tagSlug,
|
tagSlug: this.$route.params.tagSlug,
|
||||||
pageNumber: Number(this.$route.params.pageNumber),
|
|
||||||
limit: this.limit,
|
|
||||||
range: this.$route.params.range,
|
range: this.$route.params.range,
|
||||||
});
|
});
|
||||||
|
|
||||||
this.tag = tag;
|
|
||||||
this.releases = releases;
|
|
||||||
this.totalCount = totalCount;
|
|
||||||
|
|
||||||
this.hasMedia = this.tag.poster || this.tag.photos.length > 0;
|
this.hasMedia = this.tag.poster || this.tag.photos.length > 0;
|
||||||
this.description = this.tag.description && converter.makeHtml(escapeHtml(this.tag.description));
|
this.description = this.tag.description && converter.makeHtml(escapeHtml(this.tag.description));
|
||||||
}
|
}
|
||||||
|
@ -87,7 +74,6 @@ export default {
|
||||||
FilterBar,
|
FilterBar,
|
||||||
Releases,
|
Releases,
|
||||||
Photos,
|
Photos,
|
||||||
Pagination,
|
|
||||||
Scroll,
|
Scroll,
|
||||||
},
|
},
|
||||||
data() {
|
data() {
|
||||||
|
@ -95,8 +81,6 @@ export default {
|
||||||
tag: null,
|
tag: null,
|
||||||
description: null,
|
description: null,
|
||||||
releases: null,
|
releases: null,
|
||||||
totalCount: 0,
|
|
||||||
limit: 15,
|
|
||||||
pageTitle: null,
|
pageTitle: null,
|
||||||
hasMedia: false,
|
hasMedia: false,
|
||||||
expanded: false,
|
expanded: false,
|
||||||
|
|
|
@ -125,12 +125,11 @@ const routes = [
|
||||||
params: {
|
params: {
|
||||||
...from.params,
|
...from.params,
|
||||||
range: 'latest',
|
range: 'latest',
|
||||||
pageNumber: 1,
|
|
||||||
},
|
},
|
||||||
}),
|
}),
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
path: '/tag/:tagSlug/:range/:pageNumber',
|
path: '/tag/:tagSlug/:range',
|
||||||
component: Tag,
|
component: Tag,
|
||||||
name: 'tag',
|
name: 'tag',
|
||||||
},
|
},
|
||||||
|
|
|
@ -2,26 +2,20 @@ import { graphql, get } from '../api';
|
||||||
import {
|
import {
|
||||||
releaseFields,
|
releaseFields,
|
||||||
} from '../fragments';
|
} from '../fragments';
|
||||||
import { curateTag, curateRelease } from '../curate';
|
import { curateTag } from '../curate';
|
||||||
import getDateRange from '../get-date-range';
|
import getDateRange from '../get-date-range';
|
||||||
|
|
||||||
function initTagsActions(store, _router) {
|
function initTagsActions(store, _router) {
|
||||||
async function fetchTagBySlug({ _commit }, {
|
async function fetchTagBySlug({ _commit }, { tagSlug, limit = 100, range = 'latest' }) {
|
||||||
tagSlug,
|
|
||||||
pageNumber = 1,
|
|
||||||
limit = 100,
|
|
||||||
range = 'latest',
|
|
||||||
}) {
|
|
||||||
const { before, after, orderBy } = getDateRange(range);
|
const { before, after, orderBy } = getDateRange(range);
|
||||||
|
|
||||||
const { tagBySlug } = await graphql(`
|
const { tagBySlug } = await graphql(`
|
||||||
query Tag(
|
query Tag(
|
||||||
$tagSlug:String!
|
$tagSlug:String!
|
||||||
$offset: Int = 0,
|
|
||||||
$limit:Int = 1000,
|
$limit:Int = 1000,
|
||||||
$after:Datetime = "1900-01-01",
|
$after:Datetime = "1900-01-01",
|
||||||
$before:Datetime = "2100-01-01",
|
$before:Datetime = "2100-01-01",
|
||||||
$orderBy: [ReleasesOrderBy!],
|
$orderBy: [ReleasesTagsOrderBy!],
|
||||||
$exclude: [String!]
|
$exclude: [String!]
|
||||||
) {
|
) {
|
||||||
tagBySlug(slug:$tagSlug) {
|
tagBySlug(slug:$tagSlug) {
|
||||||
|
@ -63,31 +57,31 @@ function initTagsActions(store, _router) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
scenesConnection(
|
releases: releasesTags(
|
||||||
filter: {
|
filter: {
|
||||||
date: {
|
release: {
|
||||||
lessThan: $before,
|
date: {
|
||||||
greaterThan: $after,
|
lessThan: $before,
|
||||||
},
|
greaterThan: $after,
|
||||||
releasesTagsConnection: {
|
},
|
||||||
none: {
|
releasesTagsConnection: {
|
||||||
tag: {
|
none: {
|
||||||
slug: {
|
tag: {
|
||||||
in: $exclude
|
slug: {
|
||||||
}
|
in: $exclude
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
},
|
},
|
||||||
first: $limit,
|
first: $limit,
|
||||||
orderBy: $orderBy,
|
orderBy: $orderBy,
|
||||||
offset: $offset
|
|
||||||
) {
|
) {
|
||||||
releases: nodes {
|
release {
|
||||||
${releaseFields}
|
${releaseFields}
|
||||||
}
|
}
|
||||||
totalCount
|
}
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
`, {
|
`, {
|
||||||
|
@ -95,16 +89,11 @@ function initTagsActions(store, _router) {
|
||||||
limit,
|
limit,
|
||||||
after,
|
after,
|
||||||
before,
|
before,
|
||||||
orderBy: orderBy === 'DATE_DESC' ? 'DATE_DESC' : 'DATE_ASC',
|
orderBy: orderBy === 'DATE_DESC' ? 'RELEASE_BY_RELEASE_ID__DATE_DESC' : 'RELEASE_BY_RELEASE_ID__DATE_ASC',
|
||||||
offset: Math.max(0, (pageNumber - 1)) * limit,
|
|
||||||
exclude: store.state.ui.filter,
|
exclude: store.state.ui.filter,
|
||||||
});
|
});
|
||||||
|
|
||||||
return {
|
return curateTag(tagBySlug, store);
|
||||||
tag: curateTag(tagBySlug, null, curateRelease),
|
|
||||||
releases: tagBySlug.scenesConnection.releases.map(release => curateRelease(release)),
|
|
||||||
totalCount: tagBySlug.scenesConnection.totalCount,
|
|
||||||
};
|
|
||||||
}
|
}
|
||||||
|
|
||||||
async function fetchTags({ _commit }, {
|
async function fetchTags({ _commit }, {
|
||||||
|
|
|
@ -1031,19 +1031,6 @@ exports.up = knex => Promise.resolve()
|
||||||
END;
|
END;
|
||||||
$$ LANGUAGE SQL STABLE;
|
$$ LANGUAGE SQL STABLE;
|
||||||
|
|
||||||
CREATE FUNCTION tags_scenes(tag tags, selected_tags text[], mode text DEFAULT 'all') RETURNS SETOF releases AS $$
|
|
||||||
SELECT releases.*
|
|
||||||
FROM releases
|
|
||||||
LEFT JOIN
|
|
||||||
releases_actors ON releases_actors.release_id = releases.id
|
|
||||||
LEFT JOIN
|
|
||||||
releases_tags ON releases_tags.release_id = releases.id
|
|
||||||
LEFT JOIN
|
|
||||||
tags ON tags.id = releases_tags.tag_id
|
|
||||||
WHERE releases_tags.tag_id = tag.id
|
|
||||||
GROUP BY releases.id;
|
|
||||||
$$ LANGUAGE SQL STABLE;
|
|
||||||
|
|
||||||
CREATE FUNCTION movies_actors(movie movies) RETURNS SETOF actors AS $$
|
CREATE FUNCTION movies_actors(movie movies) RETURNS SETOF actors AS $$
|
||||||
SELECT actors.*
|
SELECT actors.*
|
||||||
FROM movies_scenes
|
FROM movies_scenes
|
||||||
|
@ -1103,8 +1090,6 @@ exports.up = knex => Promise.resolve()
|
||||||
COMMENT ON FUNCTION actors_tags IS E'@sortable';
|
COMMENT ON FUNCTION actors_tags IS E'@sortable';
|
||||||
COMMENT ON FUNCTION actors_channels IS E'@sortable';
|
COMMENT ON FUNCTION actors_channels IS E'@sortable';
|
||||||
COMMENT ON FUNCTION actors_scenes IS E'@sortable';
|
COMMENT ON FUNCTION actors_scenes IS E'@sortable';
|
||||||
|
|
||||||
COMMENT ON FUNCTION tags_scenes IS E'@sortable';
|
|
||||||
`);
|
`);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
{
|
{
|
||||||
"name": "traxxx",
|
"name": "traxxx",
|
||||||
"version": "1.126.5",
|
"version": "1.126.0",
|
||||||
"lockfileVersion": 1,
|
"lockfileVersion": 1,
|
||||||
"requires": true,
|
"requires": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
{
|
{
|
||||||
"name": "traxxx",
|
"name": "traxxx",
|
||||||
"version": "1.126.5",
|
"version": "1.126.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": {
|
||||||
|
|
Loading…
Reference in New Issue