graphbrainz/src/types/release.js

112 lines
3.5 KiB
JavaScript
Raw Normal View History

import GraphQL from 'graphql';
import { Node } from './node.js';
import { Entity } from './entity.js';
import { ASIN, DateType } from './scalars.js';
import { Media } from './media.js';
import { ReleaseStatus } from './enums.js';
import { ReleaseEvent } from './release-event.js';
2016-08-08 07:54:06 +00:00
import {
2016-08-20 05:59:32 +00:00
id,
2016-08-31 06:33:29 +00:00
mbid,
2016-08-20 05:59:32 +00:00
title,
disambiguation,
fieldWithID,
releaseGroupType,
releaseStatus,
resolveHyphenated,
connectionWithExtras,
linkedQuery,
} from './helpers.js';
import { aliases } from './alias.js';
import { artistCredit, artistCredits } from './artist-credit.js';
import { artists } from './artist.js';
import { collections } from './collection.js';
import { labels } from './label.js';
import { recordings } from './recording.js';
import { relationships } from './relationship.js';
import { releaseGroups } from './release-group.js';
import { tags } from './tag.js';
2016-08-08 07:54:06 +00:00
const { GraphQLObjectType, GraphQLString, GraphQLList } = GraphQL;
export const Release = new GraphQLObjectType({
2016-08-08 07:54:06 +00:00
name: 'Release',
2016-11-26 01:38:32 +00:00
description: `A [release](https://musicbrainz.org/doc/Release) represents the
unique release (i.e. issuing) of a product on a specific date with specific
release information such as the country, label, barcode, packaging, etc. If you
walk into a store and purchase an album or single, theyre each represented in
MusicBrainz as one release.`,
2016-08-31 06:33:29 +00:00
interfaces: () => [Node, Entity],
2016-08-08 07:54:06 +00:00
fields: () => ({
2016-08-20 05:59:32 +00:00
id,
2016-08-31 06:33:29 +00:00
mbid,
2016-08-20 05:59:32 +00:00
title,
disambiguation,
aliases,
2016-08-20 05:59:32 +00:00
artistCredit,
artistCredits,
2016-08-08 07:54:06 +00:00
releaseEvents: {
2016-08-20 05:59:32 +00:00
type: new GraphQLList(ReleaseEvent),
2016-11-26 01:38:32 +00:00
description: 'The release events for this release.',
resolve: resolveHyphenated,
2016-08-08 07:54:06 +00:00
},
2016-11-26 01:38:32 +00:00
date: {
type: DateType,
description: `The [release date](https://musicbrainz.org/doc/Release/Date)
is the date in which a release was made available through some sort of
distribution mechanism.`,
2016-11-26 01:38:32 +00:00
},
country: {
type: GraphQLString,
description: 'The country in which the release was issued.',
2016-11-26 01:38:32 +00:00
},
asin: {
type: ASIN,
description: `The [Amazon Standard Identification Number](https://musicbrainz.org/doc/ASIN)
of the release.`,
},
2016-11-26 01:38:32 +00:00
barcode: {
type: GraphQLString,
description: `The [barcode](https://en.wikipedia.org/wiki/Barcode), if the
release has one. The most common types found on releases are 12-digit
[UPCs](https://en.wikipedia.org/wiki/Universal_Product_Code) and 13-digit
[EANs](https://en.wikipedia.org/wiki/International_Article_Number).`,
2016-11-26 01:38:32 +00:00
},
...fieldWithID('status', {
type: ReleaseStatus,
description: 'The status describes how “official” a release is.',
2016-11-26 01:38:32 +00:00
}),
...fieldWithID('packaging', {
description: `The physical packaging that accompanies the release. See
the [list of packaging](https://musicbrainz.org/doc/Release/Packaging) for more
information.`,
2016-11-26 01:38:32 +00:00
}),
quality: {
type: GraphQLString,
description: `Data quality indicates how good the data for a release is.
It is not a mark of how good or bad the music itself is for that, use
[ratings](https://musicbrainz.org/doc/Rating_System).`,
2016-11-26 01:38:32 +00:00
},
2016-12-12 09:01:40 +00:00
media: {
type: new GraphQLList(Media),
description: 'The media on which the release was distributed.',
2016-12-12 09:01:40 +00:00
},
2016-08-20 05:59:32 +00:00
artists,
labels,
recordings,
releaseGroups,
relationships,
collections,
tags,
}),
});
export const ReleaseConnection = connectionWithExtras(Release);
2016-08-20 05:59:32 +00:00
export const releases = linkedQuery(ReleaseConnection, {
args: {
type: releaseGroupType,
status: releaseStatus,
},
});