Skip to content

Load custom .env files depending on your environment in Next.js

License

Notifications You must be signed in to change notification settings

V3RON/next-env-loader

Repository files navigation

next-env-loader

Load custom .env files depending on your environment in Next.js

Description

Usually our apps run in at least three different configurations. With vanilla Next.js it's only possible to load .env.development, .env.production and .env.test, which is insufficient for good amount of use-cases.

This library create an abstraction layer responsible for loading your Dotenv files required for given environment. It uses envs directory by default, but that can be easily changed through configuration object.

Usage

  1. Install this package using your favourite package manager
# NPM
npm install next-env-loader

# Yarn
yarn add next-env-loader

# PNPM
pnpm add next-env-loader
  1. Update your .next.config.js and pass current environment name using environment property of config object
const nextConfig = {}; // Your Next.js config
const nextEnvLoaderConfig = {
  environment: process.env.ENVIRONMENT, // Inform next-env-loader which environment is active
},

module.exports = withNextEnvLoader(nextConfig, nextEnvLoaderConfig);
  1. Run your app and notice similar log entry
info  - Using environment variables from /your-app-dir/envs/.env.dev