12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061 |
- 'use strict';
- Object.defineProperty(exports, '__esModule', {
- value: true,
- });
- exports.NoUnusedFragmentsRule = NoUnusedFragmentsRule;
- var _GraphQLError = require('../../error/GraphQLError.js');
- /**
- * No unused fragments
- *
- * A GraphQL document is only valid if all fragment definitions are spread
- * within operations, or spread within other fragments spread within operations.
- *
- * See https://spec.graphql.org/draft/#sec-Fragments-Must-Be-Used
- */
- function NoUnusedFragmentsRule(context) {
- const operationDefs = [];
- const fragmentDefs = [];
- return {
- OperationDefinition(node) {
- operationDefs.push(node);
- return false;
- },
- FragmentDefinition(node) {
- fragmentDefs.push(node);
- return false;
- },
- Document: {
- leave() {
- const fragmentNameUsed = Object.create(null);
- for (const operation of operationDefs) {
- for (const fragment of context.getRecursivelyReferencedFragments(
- operation,
- )) {
- fragmentNameUsed[fragment.name.value] = true;
- }
- }
- for (const fragmentDef of fragmentDefs) {
- const fragName = fragmentDef.name.value;
- if (fragmentNameUsed[fragName] !== true) {
- context.reportError(
- new _GraphQLError.GraphQLError(
- `Fragment "${fragName}" is never used.`,
- {
- nodes: fragmentDef,
- },
- ),
- );
- }
- }
- },
- },
- };
- }
|