Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/horusgoul/nest-graphql-scalar-adapter
A better way to import external GraphQL scalars into your Nest.js projects.
https://github.com/horusgoul/nest-graphql-scalar-adapter
graphql nestjs nodejs typescript
Last synced: 3 months ago
JSON representation
A better way to import external GraphQL scalars into your Nest.js projects.
- Host: GitHub
- URL: https://github.com/horusgoul/nest-graphql-scalar-adapter
- Owner: HorusGoul
- License: mit
- Created: 2020-09-19T10:35:45.000Z (over 4 years ago)
- Default Branch: main
- Last Pushed: 2021-08-21T08:06:28.000Z (over 3 years ago)
- Last Synced: 2024-10-09T11:26:17.877Z (3 months ago)
- Topics: graphql, nestjs, nodejs, typescript
- Language: TypeScript
- Homepage: https://github.com/horusgoul/nest-graphql-scalar-adapter
- Size: 342 KB
- Stars: 4
- Watchers: 3
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
README
# nest-graphql-scalar-adapter
## Description
A better way to import external GraphQL scalars into your Nest.js projects.
```
npm i nest-graphql-scalar-adapter# or
yarn add nest-graphql-scalar-adapter
```## How to use
We're going to use the `graphql-type-json` package that allows us to add the `JSON` scalar type
in our GraphQL schema.The only thing we need to do is wrap it with the `createFromGraphQLScalar` function!
```ts
import JSON from 'graphql-type-json';
import { createFromGraphQLScalar } from 'nest-graphql-scalar-adapter';export const JSONScalar = createFromGraphQLScalar({ scalar: JSON });
// ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
```We can also give it a custom name using the `name` option of the `createFromGraphQLScalar` configuration:
```ts
export const JSONScalar = createFromGraphQLScalar({
scalar: JSON,
name: 'JSONStatham',
});
```And also a `type`, which is useful when you're using the **Code First** approach:
```ts
export const JSONScalar = createFromGraphQLScalar({
scalar: JSON,
name: 'JSONStatham',// The type that you would use with the `@Scalar` decorator.
type: () => Object,
});
````createFromGraphQLScalar` returns a class that is already decorated with the `@Scalar` decorator. Thanks to this,
we can register our scalars as providers:```ts
...@Module({
providers: [JSONScalar]
})
export class MyModule {}...
```And the scalar is ready! If you're using the **Schema First** remember to add the scalar to your schema like this:
```graphql
scalar JSON
```
~**What's the benefit of doing this instead of adding it to the `GraphQLModule` configuration?**
This approach provides you a better way to add external scalars to your project, as it doesn't require you to
define every single scalar in the `resolvers` configuration of the `GraphQLModule`, and instead allows you to
register it as a provider in any module.