Auto generate env file declare for typescript of Vite plugins.
- Install
npm i @yafh/vite-plugin-env-dts
- Add it into vite config file
// vite.config.ts
import envDts from '@yafh/vite-plugin-env-dts'
export default defineConfig({
plugins: [envDts()],
})
- Create your env file,and start
vite
.
- When the
vite
service starts, the plug-in checks the envdir in the vite configuration and loads all env files. - Parse all env files, extract key value pairs that conform to envprefix in the vite configuration, and generate typescript declaration files.
- The generated declaration file is located in
node_modules/@types/env-dts/index.d.ts
.
For example:
.env
VITE_FOO=foo
another=hello
.env.dev
VITE_FOO=foo
VITE_BAR=bar
# multiline comment 1
# multiline comment 2
# multiline comment 3
VITE_COMMENT=comment
VITE_COMMENT_END_OF_LINE=commentEndOfLine #end-of-line comment
.env.dev.local
VITE_FOO=foo.local
VITE_LOCAL=local
.env.prod
VITE_FOO=foo.prod
declare file
/// <reference types="vite/client" />
// Auto-generated by vite-plugin-env
interface ImportMetaEnv {
/**
*
* - `default` foo
* - `dev` foo.local
* - `prod` foo.prod
*/
readonly VITE_FOO: string
/**
*
* - `dev` bar
*/
readonly VITE_BAR?: string
/**
* # multiline comment 1
* # multiline comment 2
* # multiline comment 3
* - `dev` comment
*/
readonly VITE_COMMENT?: string
/**
* #end-of-line comment
* - `dev` commentEndOfLine
*/
readonly VITE_COMMENT_END_OF_LINE?: string
}
- type : boolean
- default : true
Try convert env value to boolean or number.
- enable convert value
env file :
# .env
VITE_FOO=bar
VITE_BOOLEAN=true
VITE_NUMBER=10
# .env.dev
VITE_FOO=2022
VITE_BOOLEAN=true
VITE_NUMBER=10
env object:
// import.meta.env
{
VITE_FOO: 'bar', // or 2022
VITE_BOOLEAN: true,
VITE_NUMBER: 10,
}
declare file:
// @types/env-dts/index.d.ts
interface ImportMetaEnv {
VITE_FOO: string | number;
VITE_BOOLEAN: boolean;
VITE_NUMBER: number;
}
- disable convert value
env file :
VITE_FOO=bar
VITE_BOOLEAN=true
VITE_NUMBER=10
env object:
// import.meta.env
{
VITE_FOO: 'bar',
VITE_BOOLEAN: 'true',
VITE_NUMBER: '10',
}
declare file:
// @types/env-dts/index.d.ts
interface ImportMetaEnv {
VITE_FOO: string;
VITE_BOOLEAN: string;
VITE_NUMBER: string;
}
- type : string
- default : 'utf8'
env file encoding
- type : string
generate declare file in custom path. (eg: typing/env.d.ts
)