export default defineNuxtConfig({ ssr: false, compatibilityDate: "2024-11-01", devtools: { enabled: true }, // Add startup logging hooks: { 'ready': () => { console.log('🚀 MonacoUSA Portal Nuxt is ready!') console.log('Environment:', process.env.NODE_ENV) console.log('Port:', process.env.NUXT_PORT || process.env.PORT || 3000) }, 'listen': (server, { host, port }) => { console.log(`🌐 Server listening on http://${host}:${port}`) } }, modules: ["vuetify-nuxt-module", "@vueuse/motion/nuxt"], css: ["~/assets/scss/main.scss"], app: { head: { titleTemplate: "%s • MonacoUSA Portal", title: "MonacoUSA Portal", meta: [ { property: "og:title", content: "MonacoUSA Portal" }, { property: "og:image", content: "/MONACOUSA-Flags_376x376.png" }, { name: "twitter:card", content: "summary_large_image" }, { name: "viewport", content: "width=device-width, initial-scale=1" }, { name: "apple-mobile-web-app-capable", content: "yes" }, { name: "apple-mobile-web-app-status-bar-style", content: "default" }, { name: "apple-mobile-web-app-title", content: "MonacoUSA Portal" }, { name: "theme-color", content: "#a31515" }, ], link: [ { rel: "icon", type: "image/png", sizes: "32x32", href: "/favicon-32x32.png" }, { rel: "icon", type: "image/png", sizes: "192x192", href: "/icon-192x192.png" }, { rel: "apple-touch-icon", sizes: "180x180", href: "/apple-touch-icon.png" }, { rel: "shortcut icon", href: "/favicon-32x32.png" }, ], htmlAttrs: { lang: "en", }, }, }, nitro: { experimental: { wasm: true } }, vite: { optimizeDeps: { exclude: ['sharp'] } }, runtimeConfig: { // Server-side configuration keycloak: { issuer: process.env.NUXT_KEYCLOAK_ISSUER || "", clientId: process.env.NUXT_KEYCLOAK_CLIENT_ID || "monacousa-portal", clientSecret: process.env.NUXT_KEYCLOAK_CLIENT_SECRET || "", callbackUrl: process.env.NUXT_KEYCLOAK_CALLBACK_URL || "https://portal.monacousa.org/auth/callback", }, keycloakAdmin: { issuer: process.env.NUXT_KEYCLOAK_ISSUER || "", clientId: process.env.NUXT_KEYCLOAK_ADMIN_CLIENT_ID || "admin-cli", clientSecret: process.env.NUXT_KEYCLOAK_ADMIN_CLIENT_SECRET || "", }, nocodb: { url: process.env.NUXT_NOCODB_URL || "", token: process.env.NUXT_NOCODB_TOKEN || "", baseId: process.env.NUXT_NOCODB_BASE_ID || "", eventsBaseId: process.env.NUXT_NOCODB_EVENTS_BASE_ID || "", eventsTableId: process.env.NUXT_NOCODB_EVENTS_TABLE_ID || "", rsvpTableId: process.env.NUXT_NOCODB_RSVP_TABLE_ID || "", }, minio: { endPoint: process.env.NUXT_MINIO_ENDPOINT || "s3.monacousa.org", port: parseInt(process.env.NUXT_MINIO_PORT || "443"), useSSL: process.env.NUXT_MINIO_USE_SSL !== "false", accessKey: process.env.NUXT_MINIO_ACCESS_KEY || "", secretKey: process.env.NUXT_MINIO_SECRET_KEY || "", bucketName: process.env.NUXT_MINIO_BUCKET_NAME || "monacousa-portal", }, sessionSecret: process.env.NUXT_SESSION_SECRET || "", encryptionKey: process.env.NUXT_ENCRYPTION_KEY || "", jwtSecret: process.env.NUXT_JWT_SECRET || process.env.NUXT_SESSION_SECRET || "", public: { // Client-side configuration appName: "MonacoUSA Portal", domain: process.env.NUXT_PUBLIC_DOMAIN || "https://portal.monacousa.org", keycloakIssuer: process.env.NUXT_KEYCLOAK_ISSUER || "https://auth.monacousa.org/realms/monacousa", motion: { directives: { 'pop-bottom': { initial: { scale: 0, opacity: 0, y: 100 }, visible: { scale: 1, opacity: 1, y: 0, transition: { type: 'spring', stiffness: 250, damping: 25 } } }, 'fade-in': { initial: { opacity: 0 }, enter: { opacity: 1, transition: { duration: 600 } } }, 'slide-up': { initial: { y: 100, opacity: 0 }, enter: { y: 0, opacity: 1, transition: { type: 'spring', stiffness: 100, damping: 20 } } }, 'glass-fade': { initial: { opacity: 0, scale: 0.95, filter: 'blur(10px)' }, enter: { opacity: 1, scale: 1, filter: 'blur(0px)', transition: { duration: 500, type: 'spring', stiffness: 200 } } } } } }, }, vuetify: { vuetifyOptions: { theme: { defaultTheme: "monacousa", themes: { monacousa: { dark: false, colors: { // Monaco Red Spectrum (from design-system.md) primary: "#dc2626", // monaco-red-600 'primary-50': "#fef2f2", 'primary-100': "#fee2e2", 'primary-200': "#fecaca", 'primary-300': "#fca5a5", 'primary-400': "#f87171", 'primary-500': "#ef4444", 'primary-600': "#dc2626", // Primary Brand Color 'primary-700': "#b91c1c", 'primary-800': "#991b1b", 'primary-900': "#7f1d1d", // Neutral Palette secondary: "#ffffff", accent: "#f4f4f5", background: "#ffffff", surface: "#fafafa", 'on-background': "#18181b", 'on-surface': "#18181b", // Semantic Colors error: "#ef4444", warning: "#f59e0b", info: "#0ea5e9", success: "#10b981", // Custom Properties for Glass Effects 'glass-bg': "rgba(255, 255, 255, 0.7)", 'glass-border': "rgba(255, 255, 255, 0.3)", 'glass-dark': "rgba(0, 0, 0, 0.7)", }, variables: { 'border-color': '#e4e4e7', 'border-opacity': 0.12, 'high-emphasis-opacity': 0.87, 'medium-emphasis-opacity': 0.60, 'disabled-opacity': 0.38, 'idle-opacity': 0.04, 'hover-opacity': 0.08, 'focus-opacity': 0.12, 'selected-opacity': 0.12, 'activated-opacity': 0.12, 'pressed-opacity': 0.16, 'dragged-opacity': 0.08, 'shadow-glass': '0 8px 32px rgba(0, 0, 0, 0.1)', 'shadow-monaco': '0 10px 40px rgba(220, 38, 38, 0.15)', }, }, monacousa_dark: { dark: true, colors: { // Dark theme aligned with design system primary: "#ef4444", // Brighter red for dark mode 'primary-600': "#dc2626", 'primary-700': "#b91c1c", secondary: "#fafafa", accent: "#3f3f46", background: "#18181b", // gray-900 surface: "#27272a", // gray-800 'on-background': "#fafafa", 'on-surface': "#f4f4f5", error: "#f87171", warning: "#fbbf24", info: "#38bdf8", success: "#34d399", 'glass-bg': "rgba(0, 0, 0, 0.7)", 'glass-border': "rgba(255, 255, 255, 0.1)", }, }, }, variations: { colors: ['primary', 'secondary', 'accent'], lighten: 4, darken: 4, }, }, defaults: { VCard: { elevation: 0, rounded: 'xl', }, VBtn: { elevation: 0, rounded: 'xl', class: 'text-none font-medium', }, VNavigationDrawer: { elevation: 0, }, VAppBar: { elevation: 0, flat: true, }, VTextField: { variant: 'outlined', rounded: 'xl', }, VSelect: { variant: 'outlined', rounded: 'xl', }, }, }, }, });