- Category:
Operations
- Rule name:
@graphql-eslint/match-document-filename
- Requires GraphQL Schema:
false
ℹ️ - Requires GraphQL Operations:
false
ℹ️
This rule allows you to enforce that the file name should match the operation name.
# eslint @graphql-eslint/match-document-filename: ['error', { fileExtension: '.gql' }]
# user.gql
type User {
id: ID!
}
# eslint @graphql-eslint/match-document-filename: ['error', { query: 'snake_case' }]
# user_by_id.gql
query UserById {
userById(id: 5) {
id
name
fullName
}
}
# eslint @graphql-eslint/match-document-filename: ['error', { fragment: { style: 'kebab-case', suffix: '.fragment' } }]
# user-fields.fragment.gql
fragment user_fields on User {
id
email
}
# eslint @graphql-eslint/match-document-filename: ['error', { mutation: { style: 'PascalCase', suffix: 'Mutation' } }]
# DeleteUserMutation.gql
mutation DELETE_USER {
deleteUser(id: 5)
}
# eslint @graphql-eslint/match-document-filename: ['error', { fileExtension: '.graphql' }]
# post.gql
type Post {
id: ID!
}
# eslint @graphql-eslint/match-document-filename: ['error', { query: 'PascalCase' }]
# user-by-id.gql
query UserById {
userById(id: 5) {
id
name
fullName
}
}
The schema defines the following properties:
This element must be one of the following enum values:
.gql
.graphql
The object must be one of the following types:
asString
asObject
The object must be one of the following types:
asString
asObject
The object must be one of the following types:
asString
asObject
The object must be one of the following types:
asString
asObject
The schema defines the following additional types:
One of: camelCase
, PascalCase
, snake_case
, UPPER_CASE
, kebab-case
Properties of the asObject
object:
This element must be one of the following enum values:
camelCase
PascalCase
snake_case
UPPER_CASE
kebab-case