ddc2b42672
- Cleaned up imports and formatted code for better readability in invoices-data-table.tsx. - Enhanced invoice interface definitions for clarity. - Improved toast messages for bulk delete and update actions. - Refactored date formatting and status type retrieval for better readability. - Simplified template management in templates page, extracting TemplateList component. - Added registration toggle based on environment variable DISABLE_SIGNUPS. - Updated navbar to conditionally render registration link based on allowRegistration prop. - Enhanced error handling and validation in expenses and settings routers. - Improved PDF export footer handling. - Updated TRPC react integration for cleaner type imports.
110 lines
4.4 KiB
JavaScript
110 lines
4.4 KiB
JavaScript
import { createEnv } from "@t3-oss/env-nextjs";
|
|
import { z } from "zod";
|
|
|
|
export const env = createEnv({
|
|
/**
|
|
* Specify your server-side environment variables schema here. This way you can ensure the app
|
|
* isn't built with invalid env vars.
|
|
*/
|
|
server: {
|
|
AUTH_SECRET:
|
|
process.env.NODE_ENV === "production"
|
|
? z.string()
|
|
: z.string().optional(),
|
|
DATABASE_URL: z.string().url(),
|
|
BETTER_AUTH_URL: z.string().url().optional(),
|
|
RESEND_API_KEY: z.string().min(1).optional(),
|
|
RESEND_DOMAIN: z.string().optional(),
|
|
NODE_ENV: z
|
|
.enum(["development", "test", "production"])
|
|
.default("development"),
|
|
DB_DISABLE_SSL: z.coerce.boolean().optional(),
|
|
DISABLE_SIGNUPS: z.coerce.boolean().optional(),
|
|
// SSO / Authentik (optional)
|
|
AUTHENTIK_ISSUER: z.string().url().optional(),
|
|
AUTHENTIK_CLIENT_ID: z.string().optional(),
|
|
AUTHENTIK_CLIENT_SECRET: z.string().optional(),
|
|
AUTHENTIK_ORIGIN: z.string().url().optional(),
|
|
},
|
|
|
|
/**
|
|
* Specify your client-side environment variables schema here. This way you can ensure the app
|
|
* isn't built with invalid env vars. To expose them to the client, prefix them with
|
|
* `NEXT_PUBLIC_`.
|
|
*/
|
|
client: {
|
|
NEXT_PUBLIC_APP_URL: z.string().url().optional(),
|
|
NEXT_PUBLIC_UMAMI_WEBSITE_ID: z.string().optional(),
|
|
NEXT_PUBLIC_UMAMI_SCRIPT_URL: z.string().url().optional(),
|
|
NEXT_PUBLIC_AUTHENTIK_ENABLED: z.coerce.boolean().optional(),
|
|
NEXT_PUBLIC_BRAND_NAME: z.string().optional(),
|
|
NEXT_PUBLIC_BRAND_TAGLINE: z.string().optional(),
|
|
NEXT_PUBLIC_BRAND_LOGO_TEXT: z.string().optional(),
|
|
NEXT_PUBLIC_BRAND_ICON: z.string().optional(),
|
|
NEXT_PUBLIC_DEFAULT_INTERFACE_THEME: z
|
|
.enum(["beenvoice", "shadcn", "minimal", "editorial"])
|
|
.optional(),
|
|
NEXT_PUBLIC_DEFAULT_FONT: z
|
|
.enum(["brand", "platform", "inter", "serif"])
|
|
.optional(),
|
|
NEXT_PUBLIC_DEFAULT_BODY_FONT: z
|
|
.enum(["brand", "platform", "inter", "serif"])
|
|
.optional(),
|
|
NEXT_PUBLIC_DEFAULT_HEADING_FONT: z
|
|
.enum(["brand", "platform", "inter", "serif"])
|
|
.optional(),
|
|
NEXT_PUBLIC_DEFAULT_RADIUS: z
|
|
.enum(["none", "sm", "md", "lg", "xl"])
|
|
.optional(),
|
|
NEXT_PUBLIC_DEFAULT_SIDEBAR_STYLE: z
|
|
.enum(["floating", "docked"])
|
|
.optional(),
|
|
},
|
|
|
|
/**
|
|
* You can't destruct `process.env` as a regular object in the Next.js edge runtimes (e.g.
|
|
* middlewares) or client-side so we need to destruct manually.
|
|
*/
|
|
runtimeEnv: {
|
|
AUTH_SECRET: process.env.AUTH_SECRET,
|
|
DATABASE_URL: process.env.DATABASE_URL,
|
|
BETTER_AUTH_URL: process.env.BETTER_AUTH_URL,
|
|
RESEND_API_KEY: process.env.RESEND_API_KEY,
|
|
RESEND_DOMAIN: process.env.RESEND_DOMAIN,
|
|
NODE_ENV: process.env.NODE_ENV,
|
|
DB_DISABLE_SSL: process.env.DB_DISABLE_SSL,
|
|
DISABLE_SIGNUPS: process.env.DISABLE_SIGNUPS,
|
|
AUTHENTIK_ISSUER: process.env.AUTHENTIK_ISSUER,
|
|
AUTHENTIK_CLIENT_ID: process.env.AUTHENTIK_CLIENT_ID,
|
|
AUTHENTIK_CLIENT_SECRET: process.env.AUTHENTIK_CLIENT_SECRET,
|
|
AUTHENTIK_ORIGIN: process.env.AUTHENTIK_ORIGIN,
|
|
NEXT_PUBLIC_APP_URL: process.env.NEXT_PUBLIC_APP_URL,
|
|
NEXT_PUBLIC_UMAMI_WEBSITE_ID: process.env.NEXT_PUBLIC_UMAMI_WEBSITE_ID,
|
|
NEXT_PUBLIC_UMAMI_SCRIPT_URL: process.env.NEXT_PUBLIC_UMAMI_SCRIPT_URL,
|
|
NEXT_PUBLIC_AUTHENTIK_ENABLED: process.env.NEXT_PUBLIC_AUTHENTIK_ENABLED,
|
|
NEXT_PUBLIC_BRAND_NAME: process.env.NEXT_PUBLIC_BRAND_NAME,
|
|
NEXT_PUBLIC_BRAND_TAGLINE: process.env.NEXT_PUBLIC_BRAND_TAGLINE,
|
|
NEXT_PUBLIC_BRAND_LOGO_TEXT: process.env.NEXT_PUBLIC_BRAND_LOGO_TEXT,
|
|
NEXT_PUBLIC_BRAND_ICON: process.env.NEXT_PUBLIC_BRAND_ICON,
|
|
NEXT_PUBLIC_DEFAULT_INTERFACE_THEME:
|
|
process.env.NEXT_PUBLIC_DEFAULT_INTERFACE_THEME,
|
|
NEXT_PUBLIC_DEFAULT_FONT: process.env.NEXT_PUBLIC_DEFAULT_FONT,
|
|
NEXT_PUBLIC_DEFAULT_BODY_FONT: process.env.NEXT_PUBLIC_DEFAULT_BODY_FONT,
|
|
NEXT_PUBLIC_DEFAULT_HEADING_FONT:
|
|
process.env.NEXT_PUBLIC_DEFAULT_HEADING_FONT,
|
|
NEXT_PUBLIC_DEFAULT_RADIUS: process.env.NEXT_PUBLIC_DEFAULT_RADIUS,
|
|
NEXT_PUBLIC_DEFAULT_SIDEBAR_STYLE:
|
|
process.env.NEXT_PUBLIC_DEFAULT_SIDEBAR_STYLE,
|
|
},
|
|
/**
|
|
* Run `build` or `dev` with `SKIP_ENV_VALIDATION` to skip env validation. This is especially
|
|
* useful for Docker builds.
|
|
*/
|
|
skipValidation: !!process.env.SKIP_ENV_VALIDATION,
|
|
/**
|
|
* Makes it so that empty strings are treated as undefined. `SOME_VAR: z.string()` and
|
|
* `SOME_VAR=''` will throw an error.
|
|
*/
|
|
emptyStringAsUndefined: true,
|
|
});
|