mirror of
https://github.com/BradNut/graphbrainz
synced 2025-09-08 17:40:32 +00:00
127 lines
3.4 KiB
JavaScript
127 lines
3.4 KiB
JavaScript
import dashify from 'dashify'
|
|
import { getFields, extendIncludes } from './util'
|
|
|
|
export function includeRelations (params, info) {
|
|
let fields = getFields(info)
|
|
if (info.fieldName !== 'relations') {
|
|
if (fields.relations) {
|
|
fields = getFields(fields.relations)
|
|
} else {
|
|
return params
|
|
}
|
|
}
|
|
if (fields) {
|
|
const relations = Object.keys(fields)
|
|
const includeRels = relations.map(key => `${dashify(key)}-rels`)
|
|
if (includeRels.length) {
|
|
params = {
|
|
...params,
|
|
inc: extendIncludes(params.inc, includeRels)
|
|
}
|
|
}
|
|
}
|
|
return params
|
|
}
|
|
|
|
export function includeSubqueries (params, info) {
|
|
const fields = getFields(info)
|
|
if (fields.artistCredit) {
|
|
params = {
|
|
...params,
|
|
inc: extendIncludes(params.inc, ['artist-credits'])
|
|
}
|
|
}
|
|
return params
|
|
}
|
|
|
|
export function lookupResolver (entityType, extraParams = {}) {
|
|
return (root, { id }, { lookupLoader }, info) => {
|
|
const params = includeRelations(extraParams, info)
|
|
entityType = entityType || dashify(info.fieldName)
|
|
return lookupLoader.load([entityType, id, params])
|
|
}
|
|
}
|
|
|
|
export function browseResolver () {
|
|
return (source, args, { browseLoader }, info) => {
|
|
const pluralName = dashify(info.fieldName)
|
|
let singularName = pluralName
|
|
if (pluralName.endsWith('s')) {
|
|
singularName = pluralName.slice(0, -1)
|
|
}
|
|
const params = args
|
|
return browseLoader.load([singularName, params])
|
|
}
|
|
}
|
|
|
|
export function searchResolver () {
|
|
return (source, args, { searchLoader }, info) => {
|
|
const pluralName = dashify(info.fieldName)
|
|
let singularName = pluralName
|
|
if (pluralName.endsWith('s')) {
|
|
singularName = pluralName.slice(0, -1)
|
|
}
|
|
const { query, ...params } = args
|
|
return searchLoader.load([singularName, query, params])
|
|
}
|
|
}
|
|
|
|
export function relationResolver () {
|
|
return (source, { offset = 0,
|
|
limit,
|
|
direction,
|
|
type,
|
|
typeID }, { lookupLoader }, info) => {
|
|
const targetType = dashify(info.fieldName).replace('-', '_')
|
|
return source.filter(relation => {
|
|
if (relation['target-type'] !== targetType) {
|
|
return false
|
|
}
|
|
if (direction != null && relation.direction !== direction) {
|
|
return false
|
|
}
|
|
if (type != null && relation.type !== type) {
|
|
return false
|
|
}
|
|
if (typeID != null && relation['type-id'] !== typeID) {
|
|
return false
|
|
}
|
|
return true
|
|
}).slice(offset, limit == null ? undefined : offset + limit)
|
|
}
|
|
}
|
|
|
|
export function linkedResolver () {
|
|
return (source, args, { browseLoader }, info) => {
|
|
const pluralName = dashify(info.fieldName)
|
|
let singularName = pluralName
|
|
if (pluralName.endsWith('s')) {
|
|
singularName = pluralName.slice(0, -1)
|
|
}
|
|
const parentEntity = dashify(info.parentType.name)
|
|
let params = {
|
|
[parentEntity]: source.id,
|
|
type: [],
|
|
status: [],
|
|
limit: args.limit,
|
|
offset: args.offset
|
|
}
|
|
params = includeSubqueries(params, info)
|
|
params = includeRelations(params, info)
|
|
if (args.type) {
|
|
params.type.push(args.type)
|
|
}
|
|
if (args.types) {
|
|
params.type.push(...args.types)
|
|
}
|
|
if (args.status) {
|
|
params.status.push(args.status)
|
|
}
|
|
if (args.statuses) {
|
|
params.status.push(...args.statuses)
|
|
}
|
|
return browseLoader.load([singularName, params]).then(list => {
|
|
return list[pluralName]
|
|
})
|
|
}
|
|
}
|