0.3.0 • Published 6 months ago

@victorandree/graphql-codegen-client-preset-swc-plugin v0.3.0

Weekly downloads
-
License
MIT
Repository
github
Last release
6 months ago

This is an unsupported fork to make the plugin work with new versions of Next.js and "use client" directives. Use at your own peril.

@victorandree/graphql-codegen-client-preset-swc-plugin

When using the @graphql-codegen/client-preset on large scale projects might want to enable code splitting or tree shaking on the client-preset generated files. This is because instead of using the map which contains all GraphQL operations in the project, we can use the specific generated document types.

This plugin works for SWC only.

Installation

yarn add -D @victorandree/graphql-codegen-client-preset-swc-plugin

Usage

You will need to provide the artifactDirectory path that should be the same as the one configured in your codegen.ts

Vite

import { defineConfig } from 'vite'
import react from '@vitejs/plugin-react-swc'

// https://vitejs.dev/config/
export default defineConfig({
  plugins: [
    react({
      plugins: [
        ['@victorandree/graphql-codegen-client-preset-swc-plugin', { artifactDirectory: './src/gql', gqlTagName: 'graphql' }]
      ]
    })
  ]
})

Next.js

const nextConfig = {
  // ...
  experimental: {
    swcPlugins: [
      ['@victorandree/graphql-codegen-client-preset-swc-plugin', { artifactDirectory: './src/gql', gqlTagName: 'graphql' }]
    ]
  }
}

.swcrc

{
  // ...
  jsc: {
    // ...
    experimental: {
      plugins: [
        ['@victorandree/graphql-codegen-client-preset-swc-plugin', { artifactDirectory: './src/gql', gqlTagName: 'graphql' }]
      ]
    }
  }
}

Release

To publish a new version ensure you have done the following:

  • Update the version in package.json
  • Update the CHANGELOG.md with the new version and changes
  • Commit the changes
  • From GitHub Actions, run the Rust plugin workflow
0.3.0

6 months ago

0.2.0

7 months ago

0.1.0

9 months ago