# graphql-import [data:image/s3,"s3://crabby-images/e29f8/e29f85bdfa60787c54f756309bf7a1a5073a000a" alt="CircleCI"](https://circleci.com/gh/prisma/graphql-import) [data:image/s3,"s3://crabby-images/d0134/d0134de3c34f4132337f8cfc1a7c43002bd89707" alt="npm version"](https://badge.fury.io/js/graphql-import) Import & export definitions in GraphQL SDL (also refered to as GraphQL modules) > There is also a [`graphql-import-loader`](https://github.com/prisma/graphql-import-loader) for Webpack available. ## Install ```sh yarn add graphql-import ``` ## Usage ```ts import { importSchema } from 'graphql-import' import { makeExecutableSchema } from 'graphql-tools' const typeDefs = importSchema('schema.graphql') const resolvers = {} const schema = makeExecutableSchema({ typeDefs, resolvers }) ``` Assume the following directory structure: ``` . ├── schema.graphql ├── posts.graphql └── comments.graphql ``` `schema.graphql` ```graphql # import Post from "posts.graphql" type Query { posts: [Post] } ``` `posts.graphql` ```graphql # import Comment from 'comments.graphql' type Post { comments: [Comment] id: ID! text: String! tags: [String] } ``` `comments.graphql` ```graphql type Comment { id: ID! text: String! } ``` Running `console.log(importSchema('schema.graphql'))` produces the following output: ```graphql type Query { posts: [Post] } type Post { comments: [Comment] id: ID! text: String! tags: [String] } type Comment { id: ID! text: String! } ``` ## [Full documentation](https://oss.prisma.io/content/graphql-import/overview) ## Related topics & next steps - Static import step as build time - Namespaces - Support importing from HTTP endpoints (or [Links](https://github.com/apollographql/apollo-link)) - Create RFC to add import syntax to GraphQL spec