const siteFragment = `
    entity {
      id
      name
      slug
      url
	  type
	  independent
	  hasLogo
      parent {
        id
        name
        slug
        url
		type
	    independent
		hasLogo
      }
    }
`;

const sitesFragment = `
    entities {
      id
      name
      slug
      url
	  type
	  independent
	  hasLogo
      parent {
        id
        name
        slug
        url
		type
		independent
		hasLogo
      }
    }
`;

const actorFields = `
        id
        name
        slug
        birthdate: dateOfBirth
        age
        gender
		avatar: avatarMedia {
			id
			path
			thumbnail
			lazy
			sfw: sfwMedia {
				id
				path
				thumbnail
				lazy
			}
		}
		network: entity {
            id
            name
            slug
        }
        birthCountry: countryByBirthCountryAlpha2 {
          alpha2
          name
          alias
        }
`;

const releaseActorsFragment = `
    actors: releasesActors(orderBy: ACTOR_BY_ACTOR_ID__GENDER_ASC) {
      actor {
          ${actorFields}
      }
    }
`;

const releaseTagsFragment = `
    tags: releasesTags(orderBy: TAG_BY_TAG_ID__PRIORITY_DESC) {
      tag {
        name
        priority
        slug
        id
      }
    }
`;

const releasePosterFragment = `
    poster: releasesPosterByReleaseId {
        media {
			id
            index
            path
            thumbnail
            lazy
            comment
            sfw: sfwMedia {
                id
                thumbnail
                lazy
                path
                comment
            }
        }
    }
`;

const releaseCoversFragment = `
    covers: releasesCovers {
        media {
			id
            index
            path
            thumbnail
            lazy
            comment
            sfw: sfwMedia {
                id
                thumbnail
                lazy
                path
                comment
            }
        }
    }
`;

const releasePhotosFragment = `
    photos: releasesPhotos {
        media {
			id
            index
            path
            thumbnail
            lazy
            comment
            sfw: sfwMedia {
                id
                thumbnail
                lazy
                path
                comment
            }
        }
    }
`;

const releaseTrailerFragment = `
    trailer: releasesTrailerByReleaseId {
        media {
			id
            index
            path
            thumbnail
            mime
        }
    }
`;

const releaseTeaserFragment = `
    teaser: releasesTeaserByReleaseId {
        media {
			id
            index
            path
            thumbnail
            mime
        }
    }
`;

const releaseFields = `
    id
    title
    date
	datePrecision
    slug
	shootId
	productionDate
	comment
    createdAt
    url
    ${releaseActorsFragment}
    ${releaseTagsFragment}
    ${releasePosterFragment}
    ${releaseCoversFragment}
    ${siteFragment}
    studio {
        id
        name
        slug
        url
    }
    isNew
`;

const releasesFragment = `
    connection: releasesConnection(
        filter: {
            date: {
                lessThan: $before,
                greaterThan: $after,
            }
            releasesTagsConnection: {
                none: {
                    tag: {
                        slug: {
                            in: $exclude
                        }
                    }
                }
            }
        },
        first: $limit,
		offset: $offset,
        orderBy: $orderBy,
    ) {
		releases: nodes {
			${releaseFields}
		}
		totalCount
    }
`;

const releaseFragment = `
  release(id: $releaseId) {
    id
    title
    description
    date
	datePrecision
    duration
    createdAt
    shootId
	productionDate
	productionLocation
	productionCity
	productionState
	productionCountry: countryByProductionCountryAlpha2 {
		alpha2
		name
		alias
	}
	comment
    url
    ${releaseActorsFragment}
    ${releaseTagsFragment}
    ${releasePosterFragment}
    ${releasePhotosFragment}
    ${releaseCoversFragment}
    ${releaseTrailerFragment}
    ${releaseTeaserFragment}
    ${siteFragment}
	clips {
		id
		title
		description
		duration
		tags: clipsTags {
			tag {
				id
				name
				slug
			}
		}
		poster: clipsPosterByClipId {
			media {
				id
				index
				path
				thumbnail
				lazy
				comment
				sfw: sfwMedia {
					id
					thumbnail
					lazy
					path
					comment
				}
			}
		}
	}
    studio {
        id
        name
        slug
        url
    }
	movies: moviesScenesBySceneId {
	    movie {
			id
			title
			slug
			covers: moviesCovers {
				media {
					id
					index
					path
					thumbnail
					lazy
					comment
					sfw: sfwMedia {
						id
						thumbnail
						lazy
						path
						comment
					}
				}
			}
		}
	}
  }
`;

function getIncludedEntities(router) {
	const includedChannels = router.currentRoute.query.channels ? router.currentRoute.query.channels.split(',') : [];
	const includedNetworks = router.currentRoute.query.networks ? router.currentRoute.query.networks.split(',') : [];

	if (includedChannels.length === 0 && includedNetworks.length === 0) {
		return [];
	}

	return [
		{
			entity: {
				slug: {
					in: includedChannels,
				},
			},
		},
		{
			entity: {
				parent: {
					type: {
						equalTo: 'network',
					},
					slug: {
						in: includedNetworks,
					},
				},
			},
		},
		{
			entity: {
				type: {
					equalTo: 'network',
				},
				slug: {
					in: includedNetworks,
				},
			},
		},
	];
}

function getIncludedActors(router) {
	const includedActors = router.currentRoute.query.actors ? router.currentRoute.query.actors.split(',') : [];

	if (includedActors.length === 0) {
		return [];
	}

	return [
		{
			releasesActorsConnection: {
				some: {
					actor: {
						slug: {
							in: includedActors,
						},
					},
				},
			},
		},
	];
}

export {
	releaseActorsFragment,
	releaseFields,
	releaseTagsFragment,
	releasePosterFragment,
	releasePhotosFragment,
	releaseTrailerFragment,
	releasesFragment,
	releaseFragment,
	siteFragment,
	sitesFragment,
	getIncludedEntities,
	getIncludedActors,
};