2020-01-02 23:59:02 +00:00
|
|
|
import { graphql } from '../api';
|
2020-01-08 23:23:37 +00:00
|
|
|
import { sitesFragment, releaseFields } from '../fragments';
|
2020-01-02 23:59:02 +00:00
|
|
|
import { curateNetwork } from '../curate';
|
2019-11-10 03:20:22 +00:00
|
|
|
|
2019-11-15 01:37:17 +00:00
|
|
|
function initNetworksActions(store, _router) {
|
2020-01-02 23:59:02 +00:00
|
|
|
async function fetchNetworkBySlug(networkSlug, limit = 100) {
|
2020-01-08 23:23:37 +00:00
|
|
|
const { network, releases } = await graphql(`
|
2020-01-02 23:59:02 +00:00
|
|
|
query Network(
|
|
|
|
$networkSlug: String!
|
|
|
|
$limit:Int = 1000,
|
|
|
|
$after:Date = "1900-01-01",
|
|
|
|
$before:Date = "2100-01-01",
|
2020-02-21 02:51:57 +00:00
|
|
|
$afterTime:Datetime = "1900-01-01",
|
|
|
|
$beforeTime:Datetime = "2100-01-01",
|
2020-03-02 02:41:41 +00:00
|
|
|
$isNew:[Boolean!] = [true,false]
|
2020-01-08 23:23:37 +00:00
|
|
|
$orderBy: [ReleasesOrderBy!]
|
2020-01-30 22:41:10 +00:00
|
|
|
$exclude: [String!]
|
2020-01-02 23:59:02 +00:00
|
|
|
) {
|
|
|
|
network: networkBySlug(slug: $networkSlug) {
|
|
|
|
id
|
|
|
|
name
|
|
|
|
slug
|
|
|
|
url
|
2020-02-20 01:35:23 +00:00
|
|
|
networks: childNetworks(
|
|
|
|
orderBy: NAME_ASC,
|
|
|
|
) {
|
|
|
|
id
|
|
|
|
name
|
|
|
|
slug
|
|
|
|
url
|
|
|
|
}
|
2020-02-02 04:14:58 +00:00
|
|
|
sites(
|
2020-02-03 23:18:53 +00:00
|
|
|
orderBy: [PRIORITY_DESC, NAME_ASC],
|
2020-02-03 01:57:53 +00:00
|
|
|
filter: {
|
2020-02-07 02:40:11 +00:00
|
|
|
show: {
|
2020-02-03 01:57:53 +00:00
|
|
|
equalTo: true,
|
|
|
|
},
|
|
|
|
},
|
2020-02-02 04:14:58 +00:00
|
|
|
) {
|
2020-01-02 23:59:02 +00:00
|
|
|
id
|
|
|
|
name
|
|
|
|
slug
|
|
|
|
url
|
2020-01-08 23:23:37 +00:00
|
|
|
independent
|
2020-02-02 04:14:58 +00:00
|
|
|
priority
|
2020-01-08 23:23:37 +00:00
|
|
|
network {
|
|
|
|
id
|
|
|
|
name
|
|
|
|
slug
|
|
|
|
url
|
|
|
|
}
|
2020-01-02 23:59:02 +00:00
|
|
|
}
|
2020-01-06 04:19:38 +00:00
|
|
|
studios {
|
|
|
|
id
|
|
|
|
name
|
|
|
|
slug
|
|
|
|
url
|
|
|
|
}
|
2020-02-20 01:35:23 +00:00
|
|
|
parent {
|
|
|
|
id
|
|
|
|
name
|
|
|
|
slug
|
|
|
|
url
|
|
|
|
}
|
2020-01-02 23:59:02 +00:00
|
|
|
}
|
2020-01-08 23:23:37 +00:00
|
|
|
releases(
|
|
|
|
first: $limit,
|
|
|
|
orderBy: $orderBy,
|
|
|
|
filter: {
|
2020-02-20 01:35:23 +00:00
|
|
|
site: {
|
|
|
|
or: [
|
|
|
|
{ network: { slug: { equalTo: $networkSlug } } },
|
|
|
|
{ network: { parent: { slug: { equalTo: $networkSlug } } } }
|
|
|
|
]
|
|
|
|
}
|
2020-02-21 02:51:57 +00:00
|
|
|
or: [
|
|
|
|
{
|
|
|
|
date: {
|
|
|
|
lessThan: $before,
|
2020-02-22 02:22:30 +00:00
|
|
|
greaterThan: $after
|
2020-02-21 02:51:57 +00:00
|
|
|
}
|
|
|
|
},
|
|
|
|
{
|
2020-02-22 02:22:30 +00:00
|
|
|
date: {
|
|
|
|
isNull: true
|
|
|
|
},
|
2020-02-21 02:51:57 +00:00
|
|
|
createdAt: {
|
|
|
|
lessThan: $beforeTime,
|
|
|
|
greaterThan: $afterTime,
|
|
|
|
}
|
|
|
|
}
|
2020-03-02 02:41:41 +00:00
|
|
|
]
|
2020-01-30 22:41:10 +00:00
|
|
|
releasesTags: {
|
|
|
|
none: {
|
|
|
|
tag: {
|
|
|
|
slug: {
|
|
|
|
in: $exclude
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2020-03-02 02:41:41 +00:00
|
|
|
isNew: {
|
|
|
|
in: $isNew
|
|
|
|
}
|
2020-01-08 23:23:37 +00:00
|
|
|
}
|
|
|
|
) {
|
|
|
|
${releaseFields}
|
|
|
|
}
|
2020-01-02 23:59:02 +00:00
|
|
|
}
|
|
|
|
`, {
|
|
|
|
networkSlug,
|
|
|
|
limit,
|
|
|
|
after: store.getters.after,
|
|
|
|
before: store.getters.before,
|
2020-02-21 02:51:57 +00:00
|
|
|
afterTime: store.getters.after,
|
|
|
|
beforeTime: store.getters.before,
|
2020-03-02 02:41:41 +00:00
|
|
|
isNew: store.getters.isNew,
|
2020-01-08 23:23:37 +00:00
|
|
|
orderBy: store.state.ui.range === 'upcoming' ? 'DATE_ASC' : 'DATE_DESC',
|
2020-01-30 22:41:10 +00:00
|
|
|
exclude: store.state.ui.filter,
|
2019-11-15 01:37:17 +00:00
|
|
|
});
|
2019-11-10 03:20:22 +00:00
|
|
|
|
2020-01-08 23:23:37 +00:00
|
|
|
return curateNetwork(network, releases);
|
2019-11-10 03:20:22 +00:00
|
|
|
}
|
|
|
|
|
2020-01-02 23:59:02 +00:00
|
|
|
async function fetchNetworks({ _commit }, networkSlug) {
|
|
|
|
if (networkSlug) {
|
|
|
|
return fetchNetworkBySlug(networkSlug);
|
|
|
|
}
|
|
|
|
|
|
|
|
const { networks } = await graphql(`
|
|
|
|
query Networks {
|
2020-01-06 20:49:37 +00:00
|
|
|
networks(orderBy: NAME_ASC) {
|
2020-01-02 23:59:02 +00:00
|
|
|
id
|
|
|
|
name
|
|
|
|
slug
|
|
|
|
url
|
|
|
|
${sitesFragment}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
`);
|
2019-11-10 03:20:22 +00:00
|
|
|
|
2020-01-02 23:59:02 +00:00
|
|
|
return networks.map(network => curateNetwork(network));
|
2019-11-10 03:20:22 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return {
|
|
|
|
fetchNetworks,
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
export default initNetworksActions;
|