Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Typescript Types for import.meta.env

I am now using a framework (vite) that injects environment variables into import.meta.env.

I was previously able to create a file env.d.ts to provide types to process.env

declare global {
  namespace NodeJS {
    interface ProcessEnv {
      GITHUB_AUTH_TOKEN: string;
      NODE_ENV: 'development' | 'production';
      PORT?: string;
      PWD: string;
    }
  }
}

I've tried the following but does not work.

declare global {
  namespace NodeJS {
    interface ImportMeta {
      GITHUB_AUTH_TOKEN: string;
      NODE_ENV: 'development' | 'production';
      PORT?: string;
      PWD: string;
    }
  }
}
like image 644
hangc Avatar asked Feb 04 '21 05:02

hangc


6 Answers

I had similar problems and solved it by

tsconfig.json

{
  ...
  "compilerOptions": {
    ...
    "target": "ESNext",
    "types": ["vite/client"]
  }
}

Have vite installed as a dev dependency.

like image 75
Norfeldt Avatar answered Oct 19 '22 05:10

Norfeldt


It's documented here: https://www.typescriptlang.org/docs/handbook/release-notes/typescript-2-9.html#support-for-importmeta

So you're almost there:

interface ImportMeta {
  env: {
    GITHUB_AUTH_TOKEN: string;
    NODE_ENV: 'development' | 'production';
    PORT?: string;
    PWD: string;
  };
}

But be aware that in vite all environment variables have to be prefixed with VITE_ so neither of those environment variables are available in the application.

like image 12
Philipp Mildenberger Avatar answered Oct 19 '22 05:10

Philipp Mildenberger


I got it to work by using the following -

interface ImportMetaEnv {
  VITE_PORT?: string;
  VITE_AUTH_TOKEN?: string;
}
like image 11
hangc Avatar answered Oct 19 '22 07:10

hangc


According to the documentation here https://vitejs.dev/guide/env-and-mode.html#intellisense you can do the following:

// env.d.ts
interface ImportMetaEnv extends Readonly<Record<string, string>> {
  readonly VITE_APP_TITLE: string
  // more env variables...
}

interface ImportMeta {
  readonly env: ImportMetaEnv
}
like image 6
louis_guitton Avatar answered Oct 19 '22 07:10

louis_guitton


If you are using SvelteKit v1.0.0-next.120 and Vite 2.4.0, env must be a property of ImportMeta in global.d.ts. Here's an example:

interface ImportMeta {
  env: {
    VITE_DATABASE_URL?: string
    VITE_WEB_URL?: string
    VITE_BRAINTREE_GATEWAY?: string
    VITE_BRAINTREE_DESCRIPTOR?: string
    VITE_RECAPTCHA_SECRET_KEY?: string
    VITE_EMAIL_FROM?: string
    VITE_EMAIL_ADMINS?: string
    VITE_SEND_IN_BLUE_KEY?: string
    VITE_SEND_IN_BLUE_URL?: string
    VITE_RECAPTCHA_SITE_KEY?: string
  }
}
like image 3
nstuyvesant Avatar answered Oct 19 '22 06:10

nstuyvesant


The URL to this documentation linked to in the answer above has been updated.

Further, env.d.ts should be placed in your src/ directory and you need a reference string at the top of the file.

A complete, working example is as follows:

/// <reference types="vite/client" />

interface ImportMetaEnv {
  readonly VITE_CUSTOM_ENV_VARIABLE: string
}

interface ImportMeta {
  readonly env: ImportMetaEnv
}

Using a variable prefix other than VITE_

If you don't want to use the default variable prefix, you can change this in your Vite config:

{
  envPrefix: 'YOURPREFIX_',
}
like image 2
lukeic Avatar answered Oct 19 '22 06:10

lukeic