traxxx/assets/js/sites/actions.js

146 lines
3.2 KiB
JavaScript
Raw Permalink Normal View History

import { graphql } from '../api';
import { releaseFields } from '../fragments';
2023-07-02 20:21:19 +00:00
import { curateEntity, curateRelease } from '../curate';
import getDateRange from '../get-date-range';
function initSitesActions(store, _router) {
async function fetchSiteBySlug({ _commit }, {
siteSlug,
limit = 10,
pageNumber = 1,
range = 'latest',
}) {
const { before, after, orderBy } = getDateRange(range);
2020-05-26 23:40:10 +00:00
const { site, connection: { releases, totalCount } } = await graphql(`
query Site(
$siteSlug: String!,
$limit:Int = 100,
$offset:Int = 0,
$after:Date = "1900-01-01",
$before:Date = "2100-01-01",
$orderBy:[ReleasesOrderBy!]
2020-01-30 22:41:10 +00:00
$exclude: [String!]
) {
site: entityBySlugAndType(slug: $siteSlug, type: 2) {
name
slug
url
tags: entitiesTags {
2020-01-13 22:45:09 +00:00
tag {
id
slug
name
}
}
network: parent {
id
name
slug
url
}
2020-05-26 23:40:10 +00:00
releasesConnection(
filter: {
2023-07-02 20:21:19 +00:00
effectiveDate: {
lessThan: $before,
greaterThan: $after,
},
releasesTagsConnection: {
none: {
tag: {
slug: {
in: $exclude
}
}
}
}
}
first: $limit
offset: $offset
orderBy: $orderBy
) {
2020-05-26 23:40:10 +00:00
releases: nodes {
${releaseFields}
}
totalCount
}
}
2020-05-26 23:40:10 +00:00
connection: releasesConnection(
first: $limit
offset: $offset
orderBy: $orderBy
filter: {
entity: {
2020-05-26 23:40:10 +00:00
slug: {
equalTo: $siteSlug
}
}
2023-07-02 20:21:19 +00:00
effectiveDate: {
2020-05-26 23:40:10 +00:00
lessThan: $before,
greaterThan: $after
}
releasesTagsConnection: {
none: {
tag: {
slug: {
in: $exclude
}
}
}
}
}
) {
releases: nodes {
${releaseFields}
}
totalCount
}
}
`, {
siteSlug,
limit,
offset: Math.max(0, (pageNumber - 1)) * limit,
after,
before,
orderBy,
exclude: store.state.ui.filter,
});
2020-05-26 23:40:10 +00:00
return {
2023-07-02 20:21:19 +00:00
site: curateEntity(site),
releases: releases.map((release) => curateRelease(release)),
2020-05-26 23:40:10 +00:00
totalCount,
};
}
async function fetchSites({ _commit }, { limit = 100 }) {
const { sites } = await graphql(`
query Sites(
$actorSlug: String!
$limit:Int = 100,
$after:Date = "1900-01-01",
$before:Date = "2100-01-01",
) {
site: entity {
name
slug
url
}
}
`, {
limit,
after: store.getters.after,
before: store.getters.before,
});
return sites;
}
return {
fetchSiteBySlug,
fetchSites,
};
}
export default initSitesActions;